/* MASTRICE Fresh Theme – Light, clean, teal/sky */
:root{
  --bg:#f7fafc; --surface:#ffffff; --ink:#0f172a; --muted:#475569;
  --primary:#0ea5e9; --primary-600:#0284c7; --teal:#06b6d4; --border:#e2e8f0;
  --radius:16px; --container:clamp(18rem, 92vw, 1200px); --shadow:0 12px 40px rgba(2,6,23,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:ui-sans-serif, system-ui, Inter, Segoe UI, Roboto, Arial, sans-serif;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
.container{width:var(--container);margin:0 auto;padding:0 1.2rem}
.section{padding:clamp(2.6rem, 6vw, 5rem) 0}
.section-alt{background:#eef6ff}
h1,h2,h3,h4{line-height:1.15;margin:0 0 .6rem}
h1{font-size:clamp(2.2rem, 2.4vw + 1.2rem, 3rem);font-weight:900;letter-spacing:-.02em}
h2{font-size:clamp(1.6rem, 1.2vw + 1rem, 2rem);font-weight:800}
h3{font-size:clamp(1.15rem, .9vw + .7rem, 1.35rem);font-weight:700}
p{color:var(--muted)}
/* Header */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.75);backdrop-filter: blur(12px);
  border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:72px}
.logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink);font-weight:900}
.logo-obj object{display:inline-block;border:0}
.site-nav ul{display:flex;gap:.4rem;list-style:none;margin:0;padding:0;align-items:center;}
.site-nav a{padding:.7rem 1rem;border-radius:999px;text-decoration:none;color:var(--ink)}
.site-nav a:hover{background:#e0f2fe}
.nav-toggle{display:inline-flex;flex-direction:column;gap:4px;background:transparent;border:0;padding:.6rem;border-radius:12px}
.nav-toggle .nav-toggle-bar{width:26px;height:2px;background:#000}
@media(min-width:980px){.nav-toggle{display:none}.site-nav{display:block !important}}
@media(max-width:979.9px){.site-nav{display:none;position:absolute;right:1rem;top:72px;background:#fff;border:1px solid var(--border);
  border-radius:16px;padding:.6rem;box-shadow:var(--shadow)} .site-nav ul{flex-direction:column;align-items:stretch;width:260px}}
/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.9rem 1.1rem;border-radius:999px;border:1px solid var(--border);
  background:#fff;box-shadow:var(--shadow);text-decoration:none;color:var(--ink);transition:transform .06s ease}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg, var(--primary), var(--teal));color:#fff;border:0;font-weight:900}
.btn-ghost{background:#fff}

/* Hero */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#ffffff,#f7fbff)}
.bg-waves{position:absolute;left:0;right:0;bottom:0;z-index:0;opacity:.45;pointer-events:none; inset: auto 0 0 0; pointer-events:none;}
.bg-waves img{display:block;width:100%;height:auto;max-width:none}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:2rem;align-items:center;padding:2rem 0}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.2rem}
.hero-bullets{display:flex;gap:1rem;flex-wrap:wrap;list-style:none;padding:0;margin:1rem 0 0;color:var(--muted)}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;align-items:stretch}
.stat{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:1rem;text-align:center}
.stat strong{display:block;font-size:1.6rem}
@media(min-width:980px){.hero-inner{grid-template-columns:1.2fr .8fr}}
.accent{background:linear-gradient(135deg,var(--primary),var(--teal));-webkit-background-clip:text;background-clip:text;color:transparent}
/* Strip */
.strip{background:#0ea5e9;color:#fff}
.strip-inner{display:flex;gap:1rem;align-items:center;justify-content:space-between;padding:.9rem 0;flex-wrap:wrap}
.strip .stars{letter-spacing:.3rem;font-weight:900}
/* Cards */
.cards{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1.2rem}
.card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:1.1rem;box-shadow:var(--shadow)}
@media(min-width:760px){.cards{grid-template-columns:repeat(3,1fr)}}
/* Timeline */
.timeline{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:1rem}
.timeline li{display:grid;grid-template-columns:48px 1fr;gap:1rem;background:#fff;border:1px solid var(--border);border-radius:16px;padding:1rem;box-shadow:var(--shadow)}
.timeline li span{display:grid;place-items:center;width:48px;height:48px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--teal));color:#fff;font-weight:900}
/* About */
.about{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center}
.about-media img{border-radius:20px;border:1px solid var(--border);box-shadow:var(--shadow)}
.checks{padding-left:1.2rem}
@media(min-width:980px){.about{grid-template-columns:1fr 1fr}}
/* Referenzen */
.logo-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1.2rem}
.logo-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.2rem;text-align:center;box-shadow:var(--shadow);color:var(--muted)}
@media(min-width:760px){.logo-row{grid-template-columns:repeat(4,1fr)}}
/* FAQ */
.faq details{background:#fff;border:1px solid var(--border);border-radius:12px;padding:.8rem 1rem;margin:.6rem 0;box-shadow:var(--shadow)}
.faq summary{cursor:pointer;font-weight:700}
/* Contact */
.contact{display:grid;grid-template-columns:1fr;gap:1.2rem;align-items:start}
.contact-form{background:#fff;border:1px solid var(--border);border-radius:16px;padding:1rem;box-shadow:var(--shadow)}
.field{margin-bottom:.95rem} label{display:block;font-weight:700;margin-bottom:.35rem}
input,textarea{width:100%;padding:.85rem .9rem;border-radius:.8rem;border:1px solid var(--border);background:#fff;color:var(--ink)}
input:focus,textarea:focus{outline:2px solid var(--primary);outline-offset:2px}
.field.checkbox{display:flex;gap:.6rem;align-items:flex-start}
.field .error{color:#b91c1c;min-height:1.1em;font-size:.9rem}
.form-msg{margin-top:.6rem}
@media(min-width:980px){.contact{grid-template-columns:1.1fr .9fr}}
/* Footer */
.site-footer{background:#fff;border-top:1px solid var(--border);padding:2.2rem 0}
.footer-grid{display:grid;grid-template-columns:1fr;gap:1rem}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links a{text-decoration:none;color:var(--muted)}
.footer-links a:hover{color:var(--ink)}
.footer-bottom{margin-top:1rem;color:var(--muted)}
@media(min-width:980px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
/* A11y */
.skip-link{position:absolute;left:-9999px} .skip-link:focus{left:1rem;top:1rem;background:#fff;color:#000;padding:.5rem .75rem;border-radius:.5rem}
.jobs {
  text-align: center;
}
.job-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.5rem;
  box-shadow: var(--shadow);
  max-width: 600px;
  margin: 1.5rem auto 0;
}
.job-card h3 {
  margin-top: 0;
}
.job-card ul {
  list-style: none;
  padding: 0;
  margin: 1rem 0;
}
.job-card li::before {
  content: "✓ ";
  color: var(--primary);
  font-weight: bold;
}
.testimonials {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.2rem;
  margin-top: 1.2rem;
}
.testimonial {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.5rem;
  box-shadow: var(--shadow);
  text-align: left;
}
.testimonial p {
  font-style: italic;
  margin: 0 0 .8rem;
}
.testimonial .author {
  font-weight: 600;
  color: var(--muted);
}
@media(min-width: 760px) {
  .testimonials { grid-template-columns: repeat(3, 1fr); }
}
html {
  scroll-behavior: smooth;
}
.image-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-top: 2rem;
}

.image-box {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform 0.3s ease;
}

.image-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.image-box:hover {
  transform: scale(1.03);
}

@media (min-width: 760px) {
  .image-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.cookie-banner {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  background: #0f172a; color: #fff;
  padding: 1rem;
  z-index: 1000;
}
.cookie-banner p { margin: 0; }
.cookie-actions { margin-top: .5rem; display: flex; gap: .5rem; }
.cookie-actions button {
  padding: .5rem 1rem;
  border: 0; border-radius: 4px;
  cursor: pointer;
}
.cookie-actions .btn-primary { background:#0ea5e9; color:#fff; }
.cookie-actions .btn { background:#fff; color:#0f172a; }

dialog {
  border: none;
  border-radius: 12px;
  padding: 2rem;
  max-width: 500px;
  width: 90%;
  box-shadow: 0 12px 40px rgba(0,0,0,.3);
}
dialog::backdrop {
  background: rgba(0,0,0,.6);
}
.modal-close {
  position: absolute; top: .6rem; right: .6rem;
  background: transparent; border: 0; font-size: 1.4rem; cursor: pointer;
}
.job-form { display: grid; gap: 1rem; }

.contact-form { background:#fff; border:1px solid var(--border); border-radius:16px; padding:1rem; box-shadow:var(--shadow); }
.field { margin-bottom:.95rem; }
.field .error { color:#b91c1c; min-height:1.1em; font-size:.9rem; }
.form-msg { margin-top:.6rem; font-weight:500; }

/* === Kontaktformular (Formspree, AJAX) === */
:root{
  /* Falls deine Seite schon Variablen hat, werden diese genutzt. */
  --bg: #f7fafc; 
  --surface: #ffffff; 
  --ink: #0f172a; 
  --muted: #475569; 
  --primary: #0ea5e9; 
  --border: #e2e8f0; 
  --radius: 16px; 
  --shadow: 0 12px 40px rgba(2,6,23,.08);
}

#contactForm{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.25rem;
  max-width: 720px;
  margin: 1rem 0;
}

#contactForm label{
  display: block;
  font-weight: 700;
  color: var(--ink);
  margin: .5rem 0 .35rem;
}

#contactForm input,
#contactForm textarea{
  width: 100%;
  padding: .9rem 1rem;
  border: 1px solid var(--border);
  border-radius: .9rem;
  background: #fff;
  color: var(--ink);
  transition: box-shadow .15s ease, border-color .15s ease;
}

#contactForm input:focus,
#contactForm textarea:focus{
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(14,165,233,.2);
}

#contactForm textarea{
  resize: vertical;
  min-height: 140px;
}

/* Checkbox-Zeile */
#contactForm > div{
  margin-top: .5rem;
}

#c_ds_ok{
  width: 1.1rem;
  height: 1.1rem;
  vertical-align: middle;
  margin-right: .5rem;
}

/* Button */
#contactForm button[type="submit"]{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  margin-top: .8rem;
  padding: .9rem 1.1rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: linear-gradient(135deg, var(--primary), #06b6d4);
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  box-shadow: var(--shadow);
  transition: transform .06s ease, filter .15s ease;
}
#contactForm button[type="submit"]:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
}
#contactForm button[disabled]{
  opacity: .65;
  cursor: not-allowed;
}

/* Statusmeldung unter dem Button */
#contactMsg{
  margin-top: .6rem;
  font-weight: 600;
  color: var(--muted);
}

/* Kleinere Bildschirme */
@media (max-width: 640px){
  #contactForm{ padding: 1rem; }
  #contactForm button[type="submit"]{ width: 100%; justify-content: center; }
}

/* Optional: sanfte Pflichtfeld-/Fehler-Anmutung, wenn du später Fehlertexte ergänzt */
#contactForm [aria-invalid="true"]{
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,.15);
}

/* === Zurück nach oben Button (Blau mit sanftem Fade-In) === */
#toTop {
  position: fixed;
  right: 1.4rem;
  bottom: 1.4rem;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: bold;
  color: #fff;
  background: linear-gradient(135deg, #1e3a8a, #0ea5e9); /* Dunkelblau → Hellblau */
  border: none;
  border-radius: 50%;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
  cursor: pointer;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transform: translateY(15px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

#toTop.visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

#toTop:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  filter: brightness(1.15);
}

/* Mobile Anpassung */
@media (max-width: 640px) {
  #toTop {
    right: 1rem;
    bottom: 1rem;
    width: 44px;
    height: 44px;
    font-size: 1.3rem;
  }
}

