/*
Theme Name: Hofheinz Classic Onepager
Theme URI: https://example.com
Author: WordPressGPT
Description: Classic/PHP Onepager Theme mit Dual-CTA (Anfrage + Karriere)
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
Text Domain: hofheinz-classic
*/

:root{
  --teal:#00AEB5;
  --text:#1E1E1E;
  --muted:#F5F6F7;
  --white:#FFFFFF;
  --career:#0F2A2D;

  --radius:16px;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --container: 1200px;

  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 24px;
  --s-6: 32px;
  --s-7: 48px;
  --s-8: 64px;
  --s-9: 96px;

  --speed: 200ms;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif;
  color: var(--text);
  background: var(--white);
  line-height:1.6;
}

a{ color:inherit; text-decoration:none; }
a:focus{ outline: 3px solid rgba(0,174,181,.35); outline-offset: 2px; border-radius: 8px; }

.container{
  width: min(var(--container), calc(100% - 48px));
  margin: 0 auto;
}

.section{
  padding: var(--s-9) 0;
}
.section.muted{ background: var(--muted); }
.section.career{
  background: var(--career);
  color: var(--white);
}

h1{ font-size: clamp(32px, 4vw, 56px); line-height:1.1; margin:0 0 var(--s-5); }
h2{ font-size: clamp(26px, 3vw, 40px); line-height:1.2; margin:0 0 var(--s-6); }
h3{ font-size: 22px; margin:0 0 var(--s-3); }
p{ margin:0 0 var(--s-5); font-size: 18px; }
.small{ font-size:14px; opacity:.9; }

.grid{
  display:grid;
  gap: var(--s-5);
}
.grid.two{ grid-template-columns: repeat(2, minmax(0,1fr)); }
.grid.three{ grid-template-columns: repeat(3, minmax(0,1fr)); }
.grid.four{ grid-template-columns: repeat(4, minmax(0,1fr)); }
@media (max-width: 900px){
  .grid.two, .grid.three, .grid.four{ grid-template-columns: 1fr; }
  .section{ padding: var(--s-8) 0; }
  p{ font-size:16px; }
}

.card{
  background: var(--white);
  border-radius: var(--radius);
  padding: var(--s-6);
  box-shadow: var(--shadow);
  transition: transform var(--speed) ease, box-shadow var(--speed) ease;
}
.card:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(0,0,0,.10);
}
.section.career .card{ color: var(--text); }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 18px;
  border-radius: 12px;
  font-weight: 700;
  border: 1px solid transparent;
  transition: transform var(--speed) ease, background var(--speed) ease, border-color var(--speed) ease;
  cursor:pointer;
}
.btn:hover{ transform: translateY(-1px); }
.btn.primary{ background: var(--teal); color: var(--white); }
.btn.outline{ background: transparent; border-color: rgba(0,174,181,.65); color: var(--teal); }
.section.career .btn.outline{ border-color: rgba(255,255,255,.45); color: var(--white); }

.trust{
  display:flex;
  flex-wrap:wrap;
  gap: 10px 14px;
  margin-top: var(--s-5);
}
.trust span{
  font-size: 14px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.04);
}
.section.career .trust span{ background: rgba(255,255,255,.10); }

.site-header{
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: var(--s-5);
  padding: 14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 220px;
}
.brand img{ height: 40px; width:auto; display:block; }

.nav{
  display:flex;
  align-items:center;
  gap: 18px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.nav a{
  font-size: 14px;
  opacity:.9;
}
.nav a:hover{ opacity:1; }

.header-ctas{
  display:flex;
  gap: 10px;
  align-items:center;
  flex-wrap:wrap;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: var(--s-7);
  align-items:center;
}
.hero-media{
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
  background: #dfeff0;
  min-height: 360px;
}
.hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
@media (max-width: 900px){
  .hero-grid{ grid-template-columns: 1fr; }
  .brand{ min-width:auto; }
}

.footer{
  background: var(--muted);
  padding: var(--s-7) 0;
}
.footer-grid{
  display:grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: var(--s-6);
}
@media (max-width: 900px){
  .footer-grid{ grid-template-columns: 1fr; }
}

.kv{
  display:flex;
  flex-direction:column;
  gap: 8px;
}
.kv strong{ font-size:14px; }
.kv span{ font-size:14px; opacity:.9; }

.notice{
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(0,0,0,.04);
}

.section.career .notice{ background: rgba(255,255,255,.10); }

/* WordPress custom-logo output */
.custom-logo-link img{
  height: 40px;
  width: auto;
  display:block;
}/* =========================
   MOBILE NAV (Hamburger)
========================= */

.nav-toggle{
  display:none;
  background: transparent;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
}

.nav-toggle:focus{ outline: 3px solid rgba(0,174,181,.35); outline-offset: 2px; }

.mobile-nav{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: none;
  z-index: 2000;
}

.mobile-nav.is-open{ display:block; }

.mobile-nav__panel{
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: min(86vw, 360px);
  background: var(--white);
  padding: 18px;
  box-shadow: -20px 0 60px rgba(0,0,0,.18);
  display:flex;
  flex-direction: column;
  gap: 14px;
}

.mobile-nav__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}

.mobile-nav__close{
  background: transparent;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
}

.mobile-nav__links{
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 6px;
}

.mobile-nav__links a{
  padding: 12px 12px;
  border-radius: 12px;
  background: rgba(0,0,0,.04);
  font-weight: 700;
}

.mobile-nav__ctas{
  margin-top: auto;
  display:flex;
  flex-direction: column;
  gap: 10px;
}

@media (max-width: 900px){
  /* Header: kompakt */
  .header-inner{
    padding: 10px 0;
  }

  .brand img{ height: 34px; }

  /* Desktop-Navi & Header-CTAs ausblenden */
  .nav, .header-ctas{ display:none; }

  /* Hamburger anzeigen */
  .nav-toggle{ display:inline-flex; }

  /* Hero kompakter */
  .section{ padding: var(--s-8) 0; }
  h1{ font-size: clamp(28px, 9vw, 42px); }
  .hero-grid{ gap: var(--s-6); }
  .hero-media{ min-height: 240px; }
}
