/**
 * css for gino
 */

/*
 * Header mobil ausblenden 
 */

@media only screen and (max-width: 1000px) {
    .header_top .container {
        display: none!important;
    }
}

/*
*****************
Headlines
*****************
*/

h4 {
  margin-top: 30px;
}

/*
*****************
Header
*****************
*/

.header_bottom {

  box-shadow: 0 1px 10px rgba(0, 0, 0, .11);
  margin-bottom: 25px;
}

.number {
  font-family: 'd7 - RobotoSlab-SemiBold', sans-serif;
  color: #243258;
  font-size: 24px;
  padding-bottom: 15px;
}


.header_inner_right {
  top: -25px;
  position: absolute;
  right: 0px;
}

@media only screen and (max-width: 1000px) {
  .header_inner_right {
    top: -3px;
    position: absolute;
    right: -90px;
  }
}

@media only screen and (max-width: 944px) {
  .number {
    font-size: 20px;
  }

  .header_inner_right {
    right: -50px;
  }
}

@media only screen and (max-width: 850px) {
  .number {
    font-size: 16px;
  }

  .header_inner_right {
    right: -10px;
  }
}


/*
*****************
Navigation
*****************
*/

nav.main_menu.right {
  padding-top: 20px;
  z-index: 150;
}

.sticky nav.main_menu.right {
  padding-top: 10;
}

header.page_header nav.main_menu ul li a {
  font-family: 'd7 - RobotoSlab-Regular', sans-serif;
  color: #243258;
  font-size: 18px;
  padding-left: 20px;
}

@media only screen and (max-width: 1096px) {
  header.page_header nav.main_menu ul li a {
    padding-left: 10px;
  }
}

/*
*****************
Hero Container
*****************
*/

.eyebrow {
  font-family: 'd7 - RobotoSlab-SemiBold', sans-serif;
  color: #243258;
  font-size: 30px;
}

@media (max-width: 640px) {
  .eyebrow {
    font-family: 'd7 - RobotoSlab-SemiBold', sans-serif;
    color: #243258;
    font-size: 20px;
  }
}

.hero-bg {
  background-color: #f8f2f2;
  background-image: url("/wp-content/uploads/2026/01/bg-hero.webp");
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 90% auto;
  border-radius: 25px;
  margin: 0 30px;
}


.hero h1 {
  font-family: 'd7 - RobotoSlab-SemiBold', sans-serif;
  color: #243258;
  font-size: clamp(26px, 3.8vw + 0.4rem, 62px);
  line-height: 1.15;
  padding-right: 10%;
}

.hero-txt-block {
  padding-top: 10%;
}

.hero-neg {
  margin-top: -28%;
}

.hero-neg img {
  width: 87%;
  transition: all 0.3s ease;
  /* weiche Animation */
}

/* Hover-Effekt */
.hero-neg img:hover {
  transform: scale(1.03);
}

/* Responsive */
@media (max-width:750px) {

  .hero-bg {
    background-image: url("/wp-content/uploads/2026/01/bg-hero.webp");
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: 90% auto;

    border-radius: 25px;
    margin: 0 10px;
  }

  .hero-neg {
    margin-top: 30px;
  }

  .hero-neg img {
    width: 100%;
  }
}

.hero-text-space-b {
  padding-bottom: 4%;
}

/*
*****************
Buttons
*****************
*/

.qbutton.white.default {
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.08),
    0 10px 20px rgba(0, 0, 0, 0.12);
}

.qbutton {
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.08),
    0 10px 20px rgba(0, 0, 0, 0.12);
}


/*
*****************
Hintergründe
*****************
*/

.bg1 {
  background: linear-gradient(to bottom, #ffffff 0%, #fcf9f9 100%);
  border-radius: 25px;

  margin: 0 30px;
  /*Abstand links & rechts */
  padding: 30px;
}


/* Responsive */
@media (max-width: 900px) {
  .bg1 {
    margin: 0 0px;
    /*Abstand links & rechts */
    padding: 0px;
  }
}

.bg-full div.section {
  background: #fcf9f9;
  border-radius: 25px;

  margin: 0 30px;
  /*Abstand links & rechts */
  padding: 30px;
}

/* Responsive */
@media (max-width: 900px) {
  .bg-full div.section {
    margin: 0 0px;
    /*Abstand links & rechts */
    padding: 0px;
  }
}


/*
*****************
Grid Startseite Serviceblock
*****************
*/

.service-grid {
  display: grid !important;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 32px;

  max-width: 1400px;
  margin: 0 auto;
  padding: 0 40px;
}

/* große linke Karte */
.service-grid .big {
  grid-row: 1 / span 2;
}

/* Karten allgemein */
.service-card {
  position: relative;
  border-radius: 40px;
  overflow: hidden;
  min-height: 280px;

  display: flex;
  align-items: flex-end;

  background-size: cover;
  background-position: center;
  color: #fff;
}

/* Overlay Gradient */
.service-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,
      rgba(20, 35, 80, 0.95),
      rgba(20, 35, 80, 0.35));
}

/* Text */
.service-card .wpb_wrapper {
  position: relative;
  padding: 32px;
}

.service-card h3 {
  margin: 0 0 12px;
  font-size: 28px;
}

.service-card p {
  margin: 0;
  font-size: 16px;
  line-height: 1.5;
}

/* Karte ohne Bild */
.service-card.solid::before {
  background: #22325a;
}

/* Responsive */
@media (max-width: 900px) {
  .service-grid {
    grid-template-columns: 1fr;
  }

  .service-grid .big {
    grid-row: auto;
  }
}

/*
*****************
Card-Slider
*****************
*/

/* =========================
   Text links Abstand
========================= */

.card-slider-txt-left {
  padding-top: 6%;
}

/* =========================
   Slider Grundlayout
========================= */

.cardslider {
  position: relative;
  overflow: visible;
  padding-bottom: 200px;
  /* etwas mehr Luft nach unten */
  padding-left: 20px;
  /* 🔥 mehr Raum für Schatten */
  padding-right: 20px;
}

/* Swiper selbst darf clippen */
.cardslider .swiper {
  overflow: hidden;
}

.swiper-wrapper {
  height: 600px !important;
  padding-right: 10px;
}

/* =========================
   Card Grundlayout
========================= */

.cardslider .card {
  background: transparent;
  border-radius: 18px;
  overflow: visible;
  display: flex;
  flex-direction: column;
  height: 100%;
  text-align: center;
}

/* =========================
   Bild + Schatten
========================= */

.cardslider .card img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 18px;
  box-shadow: 0 5px 16px rgba(0, 0, 0, 0.18);
  transition: box-shadow 0.3s ease;
}

/* Hover: NUR Schatten verstärken */
@media (hover: hover) {
  .cardslider .card:hover img {
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.38);
  }
}

/* =========================
   Content-Abstände
========================= */

.cardslider .card h3 {
  margin-top: 1.8rem;
  margin-bottom: 0.6rem;
}

.cardslider .card p {
  margin: 0 auto;
  max-width: 90%;
}

/* =========================
   Pfeil-Navigation
========================= */

.cardslider .swiper-button-next,
.cardslider .swiper-button-prev {
  position: absolute;
  top: auto;
  bottom: 10px;
  /* 🔥 klar unter dem Text */
  width: 44px;
  height: 44px;
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18);
  color: #1e2a55;
  transition: box-shadow 0.2s ease, opacity 0.2s ease;
}

/* rechts unten nebeneinander */
.cardslider .swiper-button-prev {
  right: 64px;
  left: auto;
}

.cardslider .swiper-button-next {
  right: 10px;
}

/* Pfeil-Icons */
.cardslider .swiper-button-next::after,
.cardslider .swiper-button-prev::after {
  font-size: 18px;
  font-weight: 600;
}

/* Hover Pfeile */
@media (hover: hover) {

  .cardslider .swiper-button-next:hover,
  .cardslider .swiper-button-prev:hover {
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.26);
    opacity: 0.9;
  }
}

/* Disabled */
.cardslider .swiper-button-disabled {
  opacity: 0.35;
  pointer-events: none;
}

.card-link {
  display: block;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

/* =========================
   Mobile Anpassung
========================= */

@media (max-width: 768px) {
  .cardslider {
    padding-bottom: 150px;
  }

  .cardslider .swiper-button-next,
  .cardslider .swiper-button-prev {
    bottom: 56px;
  }
}

@media (max-width: 500px) {
  .cardslider .swiper-slide {
    width: 100% !important;
  }

  .cardslider .swiper-button-next,
  .cardslider .swiper-button-prev {
    bottom: 18px !important;
  }
}


/*
*****************
Cards Serviceblock
*****************
*/

.service-cards {
  display: grid;
  grid-template-columns: 1.5fr 1.5fr;
  gap: 24px;
}

.service-cards__right {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 24px;
}

.service-card {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  display: block;
  color: #fff;
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.18);
}

/* Bild */
.service-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  z-index: 0;
  pointer-events: none;
  will-change: transform;
}

/* Overlay – IMMER aktiv */
.service-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
      rgba(20, 30, 60, 0.35) 0%,
      rgba(20, 30, 60, 0.85) 100%);
  z-index: 1;
  pointer-events: none;
  /* 🔥 Overlay darf Hover nicht beeinflussen */
}

/* Content */
.service-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 28px;
  z-index: 2;
}

.service-card__content h3 {
  font-size: 1.6rem;
  margin-bottom: 0.6rem;
  color: #fff;
}

.service-card__content p {
  font-size: 1rem;
  line-height: 1.5;
  max-width: 90%;
  color: #fff;
}

/* Hover: NUR Bild-Zoom */
@media (hover: hover) {
  .service-card img {
    transition: transform 0.6s ease-out;
  }

  .service-card:hover img {
    transform: scale(1.04);
  }

  /* ❌ KEIN Hover-Overlay mehr */
}

/* Responsive */
@media (max-width: 991px) {
  .service-cards {
    grid-template-columns: 1fr;
  }

  .service-cards__right {
    grid-template-rows: auto;
  }
}

/*
*****************
Produkt-Kategorien Grid
*****************
*/

.product-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.product-card {
  background: #fff;
  border-radius: 18px;
  padding: 18px;
  text-align: center;
  text-decoration: none;
  color: #243258;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.08);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.product-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 14px;
  margin-bottom: 16px;
  transition: transform 0.4s ease;
}

.product-card h3 {
  font-size: 1.1rem;
  margin-bottom: 0.4rem;
}

.product-card p {
  font-size: 0.95rem;
  line-height: 1.5;
}

/* Hover */
@media (hover: hover) {
  .product-card:hover {
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.15);
    transform: translateY(-4px);
  }

  .product-card:hover img {
    transform: scale(1.06);
  }
}

/* Responsive */
@media (max-width: 1200px) {
  .product-cards {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 900px) {
  .product-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 560px) {
  .product-cards {
    grid-template-columns: 1fr;
  }
}

/*
*****************
Blog Cards
*****************
*/

.blog-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.blog-card {
  background: #fff;
  border-radius: 22px;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

@media (hover: hover) {
  .blog-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 22px 48px rgba(0, 0, 0, 0.14);
  }
}

/* Bild */
.blog-card__image {
  padding: 16px;
}

.blog-card__image img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 18px;
  display: block;
}

/* Content */
.blog-card__content {
  padding: 8px 20px 24px;
}

.blog-card__content h3 {
  font-size: 1.15rem;
  line-height: 1.35;
  margin-bottom: 0.6rem;
  color: #243258;
}

.blog-card__content p {
  font-size: 0.95rem;
  line-height: 1.5;
  color: #444;
}

/* Responsive */
@media (max-width: 1200px) {
  .blog-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .blog-cards {
    grid-template-columns: 1fr;
  }
}

/*
*****************
IMG Space
*****************
*/

.img-space-1 {
  margin-top: 50px;
}

/*
*****************
Listen
*****************
*/

ol {
  list-style-position: outside;
  padding-left: 1.6em;
  margin-left: 0;
  margin-top: 30px;
}

li {
  margin-top: 15px;
}

/*
*****************
Price Card
*****************
*/

.price-card {
  background: #ffffff;
  border-radius: 20px;
  padding: 32px;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.12);
  max-width: 900px;
}

.price-card__title {
  font-size: 1.6rem;
  margin-bottom: 24px;
  color: #1e2a55;
}

/* Tabelle */
.price-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
}

.price-table thead th {
  text-align: left;
  padding: 14px 12px;
  font-weight: 600;
  color: #1e2a55;
  border-bottom: 2px solid #eef0f4;
}

.price-table tbody td {
  padding: 14px 12px;
  color: #222;
}

/* Zebra-Streifen */
.price-table tbody tr:nth-child(even) {
  background: #f6f7f9;
}

/* Hover dezent */
.price-table tbody tr:hover {
  background: #eef1f6;
}

/* Zusatzinfos */
.price-card__extras {
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid #eceef3;
}

.price-card__extras div {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-size: 0.95rem;
}

.price-card__extras strong {
  font-weight: 600;
}

/* Mobile */
@media (max-width: 768px) {
  .price-card {
    padding: 24px;
  }

  .price-table thead {
    display: none;
  }

  .price-table tr {
    display: block;
    margin-bottom: 12px;
    background: #f6f7f9;
    border-radius: 12px;
    padding: 12px;
  }

  .price-table td {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
  }

  .price-table td::before {
    content: attr(data-label);
    font-weight: 600;
    color: #1e2a55;
  }
}

/*
*****************
Reparatur Formular
*****************
*/

/*
=========================
Formular Layout
=========================
*/

.form-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 24px;
}

@media (max-width: 991px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
}

.wpcf7 input[type="text"], .wpcf7 input[type="email"], .wpcf7 input[type="tel"], .wpcf7 textarea {
    border: 1.5px solid #cfd5e2;
    background-color: #ffffff;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
    color: #000;
    font-size: 16px;
	font-family: 'd7 - Manrope-Regular', sans-serif;
}

input.wpcf7-form-control.wpcf7-date, input.wpcf7-form-control.wpcf7-number, input.wpcf7-form-control.wpcf7-quiz, input.wpcf7-form-control.wpcf7-text, select.wpcf7-form-control.wpcf7-select, textarea.wpcf7-form-control.wpcf7-textarea {
	    color: #000;
    font-size: 16px;
	font-family: 'd7 - Manrope-Regular', sans-serif;
}

/*
=========================
Formular Cards
=========================
*/

.form-card {
  background: #ffffff;
  border-radius: 20px;
  padding: 24px;
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.08);
}

.form-card--full {
  margin-top: 24px;
}

/*
=========================
Überschriften
=========================
*/

.form-card h3 {
  margin-top: 0;
  margin-bottom: 1rem;
  font-size: 1.4rem;
  color: #1e2a55;
}

/*
=========================
Labels & Felder
=========================
*/

.wpcf7 label {
  display: block;
  margin-bottom: 14px;
  font-weight: 500;
  color: #243258;
}

/* Sichtbare Grund-Outline für Inputs & Textareas */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
  border: 1.5px solid #cfd5e2;
  /* klare, aber weiche Linie */
  background-color: #ffffff;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}

.wpcf7 textarea {
  min-height: 120px;
  resize: vertical;
}

/*
=========================
Focus State
=========================
*/

.wpcf7 input:focus,
.wpcf7 textarea:focus {
  outline: none;
  border-color: #1e2a55;
  box-shadow: 0 0 0 3px rgba(30, 42, 85, 0.15);
}

/*
=========================
File Upload
=========================
*/

.wpcf7 input[type="file"] {
  margin-top: 8px;
  font-size: 14px;
}

/*
=========================
Datenschutz
=========================
*/

.form-datenschutz {
  margin: 20px 0;
}

.form-datenschutz a {
  text-decoration: underline;
}

/*
=========================
Submit Button
=========================
*/

.wpcf7 input[type="submit"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(30, 42, 85, 0.4);
}

/*
=========================
Hinweise
=========================
*/

.form-hinweis {
  margin-top: 20px;
  font-size: 14px;
  color: #555;
}

.form-pflicht {
  margin-top: 8px;
  font-size: 13px;
  color: #777;
}

/* =========================
   Preis-/Lieferkosten Card
========================= */

.price-table-card {
  background: #ffffff;
  /* 🔥 wirklich weiß */
  border-radius: 22px;
  padding: 36px;
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.14);
  max-width: 100%;
}

/* Headline */
.price-table-card h3 {
  margin-bottom: 14px;
  color: #1e2a55;
}

/* Intro Text */
.price-table-hint {
  font-size: 0.95rem;
  color: #555;
  margin-bottom: 28px;
}

/* Wrapper gegen Overflow */
.price-table-wrapper {
  overflow-x: auto;
}

/* =========================
   Tabelle
========================= */

.price-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
  background: #ffffff;
}

/* Zellen */
.price-table th,
.price-table td {
  padding: 14px 16px;
  text-align: center;
  white-space: nowrap;
}

/* Kopfzeile */
.price-table thead th {
  background: #f3f5fa;
  /* leichtes Grau */
  color: #1e2a55;
  font-weight: 600;
  border-bottom: 2px solid #e2e6f0;
  text-align: center;
}

/* Zebra */
.price-table tbody tr:nth-child(even) {
  background: #f8f9fc;
}

/* Hover */
.price-table tbody tr:hover {
  background: #eef2ff;
}

/* Erste Spalte hervorheben */
.price-table td:first-child,
.price-table th:first-child {
  text-align: left;
  font-weight: 600;
  color: #1e2a55;
}

/* =========================
   Zusatzinfos unten
========================= */

.price-table-notes {
  margin-top: 32px;
}

.price-table-notes h4 {
  margin-bottom: 10px;
  color: #1e2a55;
}

.price-table-notes ul {
  padding-left: 18px;
  margin-bottom: 14px;
}

.price-table-notes li {
  margin-bottom: 6px;
  color: #333;
}

.price-table-footnote {
  font-size: 0.9rem;
  color: #666;
}