/* Theme Name: Bridals Advice Theme Author: Bridals Advice Version: 1.0 */
/* BASIS */
body {
	font-family: "Inter", sans-serif;
	color: #2c2c2c;
	background: #f6f2ef;
	margin: 0;
}

section {
	background-clip: padding-box;
}

.container {
	max-width: 1200px;
	margin: auto;
	padding: 40px 20px;
}

body .wp-site-blocks h1,
body .wp-site-blocks h2,
body .wp-site-blocks h3,
body .entry-content h1,
body .entry-content h2,
body .entry-content h3,
body .wp-block-heading,
body .wp-block-post-title,
body .entry-title {
	font-family: "Inter", sans-serif !important;
	color: #b68d79 !important;
}

body .wp-site-blocks,
body .entry-content,
body p,
body li {
	font-family: "Inter", sans-serif;
}

/* BUTTON */
.wp-block-button__link {
	background: #9e978e;
	border-radius: 40px;
	padding: 14px 28px;
	color: white;
	text-decoration: none;
}

/* HEADER HERO */
.bridals-hero {
	position: relative;
	background-size: cover;
	background-position: center;
	height: 35vh;
	min-height: 200px;
}

/* NAVIGATION */
.bridals-nav {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 45px;
	padding: 25px 70px;
	z-index: 10;
}

/* LOGO */
.bridals-nav__logo img {
	height: 40px;
	width: auto;
}

/* NAV LINKS */
.bridals-nav__link {
	color: #d3d3d3;
	font-size: 25px;
	font-weight: 600;
	letter-spacing: 0.1rem;
	text-transform: uppercase;
	text-decoration: none;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8);
	transition: opacity 0.2s;
}

.bridals-nav__link:hover {
	opacity: 0.8;
}

/* FOOTER */
.bridals-footer {
	background: #cbb9ac;
	color: #ffffff;
	padding: 60px 20px;
	text-align: center;
}

.bridals-footer a {
	color: #ffffff;
	text-decoration: none;
}

/* HEADER AUF STARTSEITE AUSBLENDEN */
.home header,
.home .site-header {
	display: none !important;
}

.ba-hero {
	position: relative;
	width: 100vw;
	height: 100vh;
	margin-left: calc(-50vw + 50%);
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* entfernt Abstand über dem ersten Block */
.home .entry-content>*:first-child {
	margin-top: 0 !important;
	padding-top: 0 !important;
}

.ba-nav {
	position: absolute;
	top: 30px;
	right: 40px;
	z-index: 20;
	display: flex;
	align-items: center;
	gap: 2rem;
}

/* Logo clean */
.ba-nav__logo {
	border: none;
	background: none;
	padding: 0;
}

.ba-nav__logo img {
	height: 42px;
}

/* Links */
.ba-nav__link {
	color: rgba(255, 255, 255, 0.9);
	text-decoration: none;
	font-size: 0.85rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: all 0.3s;
}

.ba-nav__link:hover {
	color: #fff;
	text-decoration: underline;
	text-underline-offset: 4px;
}

.ba-nav {
	backdrop-filter: blur(6px);
}

.ba-pricing__cards {
	display: flex;
	justify-content: center;
	align-items: stretch;
	gap: 40px;
	flex-wrap: nowrap;
}

.ba-pricing__card {
	width: 300px;
}

/* Mobile wieder umbrechen */
@media (max-width: 900px) {
	.ba-pricing__cards {
		flex-wrap: wrap;
	}
}

.ba-intro {
	background: linear-gradient(rgba(214, 181, 165, 0.55), rgba(214, 181, 165, 0.35)) !important;
	color: #8b6a4f !important;
	padding: 2.5rem 1.25rem !important;
	margin: 0 !important;
}

.ba-intro p {
	max-width: 900px;
	margin: 0 auto 0.75rem !important;
	font-size: 1rem !important;
	line-height: 1.7;
	text-align: center;
}

/* ===== FULLWIDTH FIX STARTSEITE ===== */
.home .container,
.home .entry-content,
.home .content-area,
.home main {
	max-width: 100% !important;
	width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* ===== ABSCHLUSSBILD ===== */
.ba-final-wrap {
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	margin-right: calc(-50vw + 50%);
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

.ba-final-image {
	width: 100%;
	height: 150px;
	object-fit: cover;
	display: block;
}

/* Footer bündig */
footer,
.site-footer,
.bridals-footer {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	padding-top: 40px;
	padding-bottom: 40px;
}

/* ===== GLOBAL SPACING RESET (nur Startseite) ===== */
.home .entry-content,
.home .entry-content>* {
	margin-bottom: 0 !important;
}

/* entfernt alle Zwischenräume zwischen Sections */
.home section {
	margin: 0 !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

/* Bilder ohne Inline-Gap */
.home img {
	display: block;
}

/* ===== BA-INTRO (Lovable-Match) ===== */
.ba-intro {
	background: linear-gradient(rgba(214, 181, 165, .55), rgba(214, 181, 165, .35));
	color: #8b6a4f;
	padding: 60px 20px;
	/* mehr Luft */
	text-align: center;
}

.ba-intro p {
	max-width: 800px;
	margin: 0 auto 18px;
	line-height: 1.7;
	font-size: 1.1rem;
}

/* entfernt letzten Abstand vor Footer */
.home .entry-content>*:last-child {
	margin-bottom: 0 !important;
}

.home .ba-section {
	padding-top: 60px;
	padding-bottom: 60px;
}

/* ===== BODY / WRAPPER RESET ===== */
html,
body {
	margin: 0 !important;
	padding: 0 !important;
	background: #f6f2ef !important;
}

/* WordPress Block Wrapper */
.wp-site-blocks {
	margin: 0 !important;
	padding: 0 !important;
}

/* KILLT ALLES UNTER DEM FOOTER */
body::after {
	content: "";
	display: block;
	height: 0;
	margin: 0;
	padding: 0;
}

/* TRUST → Abstand nach unten reduzieren */
.ba-trust {
	padding-bottom: 20px !important;
	margin-bottom: 0 !important;
}

.ba-trust__grid {
	align-items: start !important;
}

.ba-trust__num {
	display: block;
	height: 60px;
}

.ba-trust__label {
	min-height: 80px;
}

/* ALLE Abstände zwischen Sektionen entfernen */
.home section,
.home .ba-intro,
.home .ba-trust {
	margin-bottom: 0 !important;
	margin-top: 0 !important;
}

/* ===== FINAL WORDPRESS GAP KILLER ===== */
.wp-site-blocks,
.is-layout-flow,
.is-layout-constrained {
	gap: 0 !important;
}

/* entfernt den automatischen Abstand zwischen Blöcken */
.is-layout-flow>*+* {
	margin-block-start: 0 !important;
}

/* entfernt WP Block Spacing komplett */
.wp-block-group,
.wp-block-cover,
.wp-block-image,
.wp-block-columns {
	margin: 0 !important;
	padding: 0 !important;
}

/* ganz wichtig für Sections */
.home main>* {
	margin: 0 !important;
}

/* killt ALLE WP Wrapper Abstände */
.home .entry-content,
.home main,
.home .wp-site-blocks {
	display: block;
}

/* verhindert Abstand zwischen deinen Sections */
.home main>section {
	margin: 0 !important;
}

.ba-hero .ba-btn-rose:hover {
  background: rgba(255,255,255,0.15);
  border: 2px solid #fff;
  color: #fff;
}

/* NUR im Hero transparent */
.ba-hero .ba-btn-rose {
	background: transparent;
	border: 2px solid #fff;
	color: #fff;
}

.wp-site-blocks,
.is-layout-flow,
.is-layout-constrained {
	gap: 0 !important;
}

/* entfernt den automatischen Abstand zwischen Blöcken */
.is-layout-flow>*+* {
	margin-block-start: 0 !important;
}

/* entfernt WP Block Spacing komplett */
.wp-block-group,
.wp-block-cover,
.wp-block-image,
.wp-block-columns {
	margin: 0 !important;
	padding: 0 !important;
}

/* ganz wichtig für Sections */
.home main>* {
	margin: 0 !important;
}

/* killt ALLE WP Wrapper Abstände */
.home .entry-content,
.home main,
.home .wp-site-blocks {
	display: block;
}

/* verhindert Abstand zwischen deinen Sections */
.home main>section {
	margin: 0 !important;
}

/* ===== FINAL BANNER FIX (WORKS 100%) ===== */
#pricing {
	padding: 0 !important;
	margin: 0 !important;
}

#pricing img.ba-pricing__banner {
	width: 100vw !important;
	max-width: 100vw !important;
	height: 460px !important;
	object-fit: cover !important;
	margin-left: calc(-50vw + 50%) !important;
	margin-right: calc(-50vw + 50%) !important;
	display: block !important;
}

.ba-pricing {
  background: linear-gradient(
    rgba(224,198,177,0.95),
    rgba(224,198,177,0.75)
  );
  
  padding-top: 100px;
  padding-bottom: 100px;
}

/* Überschrift */
.ba-pricing h2 {
	color: #6b4f3a !important;
}

/* PRICING BUTTON FINAL FIX */
.ba-pricing .wp-block-button__link {
  background: #b68d79 !important;
  color: #fff !important;
  border-radius: 40px !important;
  padding: 14px 28px !important;
  text-decoration: none !important;

  transition: all 0.3s ease !important;
}

/* HOVER */
.ba-pricing .wp-block-button__link:hover {
  background: #a67c68 !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}

.ba-pricing__card--premium .wp-block-button__link {
  background: #ffffff !important;
  color: #b68d79 !important;
  border: 2px solid #b68d79 !important;
}

.ba-pricing__card--premium .wp-block-button__link:hover {
  background: #b68d79 !important;
  color: #fff !important;
}

.no-hero {
  background-image: none !important;
  height: 0 !important;
  min-height: 0 !important;
}

.bridals-hero.no-hero {
  padding-bottom: 60px;
}

 /* ── Design Tokens ── */
    :root {
      --primary: 15, 30%, 55%;
      --primary-fg: 0, 0%, 100%;
      --foreground: 20, 20%, 20%;
      --muted-fg: 20, 15%, 45%;
      --accent: 345, 70%, 85%;
      --rose-gold: 15, 50%, 75%;
      --rose-deep: 345, 60%, 65%;
      --champagne: 30, 30%, 95%;
      --warm-gray: 20, 10%, 40%;
      --card-foreground: 20, 20%, 20%;
    }
    /* ── Google Fonts ── */
    @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:wght@300;400;700&family=Sacramento&display=swap');
    /* ── Global ── */
    body {
      font-family: 'Inter', system-ui, sans-serif;
      color: hsl(var(--foreground));
      margin: 0;
    }

    .ba-section {
      padding: 5rem 1.25rem;
    }

    .ba-container {
      max-width: 1800px;
      margin: 0 auto;
    }

    .ba-btn {
      display: inline-block;
      padding: 0.875rem 1.75rem;
      border-radius: 9999px;
      font-weight: 500;
      text-decoration: none;
      transition: all 0.3s;
      font-size: 1rem;
    }

    .ba-btn:hover {
      transform: scale(1.05);
      box-shadow: 0 8px 24px rgba(0, 0, 0, .15);
    }

    .ba-btn-rose {
      background: hsl(var(--rose-gold));
      color: #fff;
    }

    .ba-btn-rose:hover {
      background: hsl(var(--rose-deep));
      color: #fff;
    }

    .ba-btn-outline {
      border: 2px solid #fff;
      color: #fff;
    }

    .ba-btn-outline:hover {
      background: rgba(255, 255, 255, .2);
      color: #fff;
    }
    /* ── Hero ── */
    .ba-hero {
      position: relative;
      background-size: cover;
      background-position: center;
      padding: 160px 1.25rem;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .ba-hero__box {
      max-width: 700px;
      padding: 2.5rem;
      border-radius: 20px;
      color: #fff;
      background: linear-gradient(rgba(139, 106, 79, .75), rgba(139, 106, 79, .6));
      text-align: center;
      display: flex;
      flex-direction: column;
      align-items: center;
    }

    .ba-hero__box h1 {
      font-family: 'Playfair Display', serif;
      font-size: 62px;
      font-weight: 300;
      margin: 0 0 1rem;
      line-height: 1.1;
    }

    .ba-hero__box h1 .ba-script-a {
      font-family: 'Sacramento', cursive;
      font-size: 1.15em;
    }

    .ba-hero__text {
      text-align: left;
    }

    .ba-hero__text p {
      font-size: 1.125rem;
      line-height: 1.6;
      margin: 0 0 1rem;
    }

    .ba-hero__text p:first-child {
      font-size: 1.375rem;
      font-weight: 500;
      text-align: center;
    }

    .ba-hero__buttons {
      display: flex;
      gap: 1rem;
      justify-content: center;
      flex-wrap: wrap;
    }

    /* ── Trust ── */
    .ba-trust {
      background: #fff;
      padding: 3rem 1rem;
      border-bottom: 1px solid #f3f3f3;
    }

    .ba-trust__grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 2rem;
      max-width: 900px;
      margin: 0 auto;
      text-align: center;
    }

    .ba-trust__num {
      font-size: 3.5rem;
      font-weight: 700;
      color: hsl(var(--primary));
    }

    .ba-trust__label {
      color: hsl(var(--muted-fg));
      font-size: 1.125rem;
    }

    /* ── Bridal Intro ── */
    .ba-intro {
      background: linear-gradient(rgba(214, 181, 165, .55), rgba(214, 181, 165, .35));
      color: #8b6a4f;
      padding: 2.5rem 1.25rem;
    }

    .ba-intro p {
      max-width: 900px;
      margin: 0 auto .75rem;
      line-height: 1.7;
      text-align: left;
    }

    /* ── Pricing ── */
    .ba-pricing {
      background: #f6f2ef;
    }

    .ba-pricing__banner {
      width: 100%;
      height: 320px;
      object-fit: cover;
      display: block;
    }

    .ba-pricing__cards {
      display: flex;
      gap: 30px;
      justify-content: center;
      flex-wrap: wrap;
      align-items: stretch;
    }

    .ba-pricing__card {
      background: #fff;
      padding: 35px;
      width: 320px;
      border-radius: 22px;
      box-shadow: 0 10px 25px rgba(0, 0, 0, .08);
      text-align: left;
      display: flex;
      flex-direction: column;
      transition: all .3s;
    }

    .ba-pricing__card:hover {
      transform: scale(1.05);
      box-shadow: 0 15px 35px rgba(0, 0, 0, .15);
    }

    .ba-pricing__card--premium {
      border: 2px solid hsl(var(--primary));
    }

    .ba-pricing__card h3 {
      font-size: 1.5rem;
      font-weight: 600;
      margin: 0 0 .5rem;
    }

    .ba-pricing__card .subtitle {
      font-size: .875rem;
      color: hsl(var(--muted-fg));
      font-style: italic;
      margin: 0 0 1rem;
    }

    .ba-pricing__card ul {
      list-style: none;
      padding: 0;
      margin: 0 0 1.25rem;
    }

    .ba-pricing__card li {
      display: flex;
      align-items: flex-start;
      gap: .5rem;
      font-size: .875rem;
      color: hsl(var(--muted-fg));
      margin-bottom: .5rem;
    }

    .ba-pricing__card li::before {
      content: '✓';
      color: hsl(var(--primary));
      font-weight: 700;
      flex-shrink: 0;
      margin-top: 1px;
    }

    .ba-pricing__card .note {
      font-size: .875rem;
      color: hsl(var(--muted-fg));
      font-style: italic;
      margin: 0 0 1rem;
    }

    .ba-pricing__price {
      font-size: 1.875rem;
      font-weight: 700;
      color: hsl(var(--primary));
      text-align: center;
      margin: 1.25rem 0;
      margin-top: auto;
    }

    /* ── About ── */
    .ba-about {
      background: hsl(var(--champagne));
    }

    .ba-about__grid {
      display: grid;
      grid-template-columns: 1fr 1.5fr;
      gap: 3rem;
      align-items: center;
      max-width: 1000px;
      margin: 0 auto;
    }

    .ba-about__img {
      width: 320px;
      height: 320px;
      border-radius: 50%;
      object-fit: cover;
      box-shadow: 0 10px 25px rgba(0, 0, 0, .12);
      margin: 0 auto;
    }

    .ba-about__text {
      font-size: 1.25rem;
      color: hsl(var(--warm-gray));
      line-height: 1.6;
    }

    .ba-about__text p {
      margin: 0 0 1.5rem;
    }

    /* ── Testimonials ── */
    .ba-testimonials {
      background: hsl(25, 25%, 95%);
      padding: 5rem 1.25rem;
    }

    .ba-testimonials__header {
      text-align: center;
      margin-bottom: 2.5rem;
    }

    .ba-testimonials__header h2 {
      font-size: 2.25rem;
      font-weight: 700;
      color: hsl(var(--foreground));
      margin: 0 0 1rem;
    }

    .ba-testimonials__divider {
      width: 10rem;
      height: 4px;
      background: hsl(var(--accent));
      margin: 0 auto;
      border-radius: 9999px;
    }

    .ba-testimonials__layout {
      display: flex;
      gap: 2rem;
      align-items: center;
    }

    .ba-testimonials__featured {
      flex-shrink: 0;
      width: 320px;
    }

    .ba-testimonial-card {
      background: #fff;
      padding: 2rem;
      border-radius: 22px;
      box-shadow: 0 10px 25px rgba(0, 0, 0, .08);
      border: 1px solid hsl(var(--accent) / .2);
      width: 320px;
      min-height: 256px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      flex-shrink: 0;
    }

    .ba-testimonial-card .stars {
      color: hsl(var(--accent));
      margin-bottom: .75rem;
      font-size: 1.25rem;
    }

    .ba-testimonial-card blockquote {
      font-size: .875rem;
      font-style: italic;
      color: hsl(var(--card-foreground));
      line-height: 1.6;
      margin: 0;
    }

    .ba-testimonial-card cite {
      display: block;
      margin-top: 1rem;
      font-weight: 600;
      color: hsl(var(--accent));
      font-style: normal;
    }

    .ba-testimonials__scroll-wrap {
      overflow: hidden;
      flex: 1;
    }

    .ba-testimonials__scroll {
      display: flex;
      gap: 1.5rem;
      animation: ba-scroll 40s linear infinite;
    }

    .ba-testimonials__scroll:hover {
      animation-play-state: paused;
    }

    @keyframes ba-scroll {
      0% {
        transform: translateX(0);
      }

      100% {
        transform: translateX(-50%);
      }
    }

    /* ── Bottom CTA ── */
    .ba-bottom-cta {
      background: hsl(var(--champagne));
      padding: 4rem 1.25rem;
    }

    .ba-bottom-cta__grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1.5rem;
      max-width: 1000px;
      margin: 0 auto;
    }

    .ba-bottom-cta__card {
      background: #fff;
      border: 1px solid hsl(var(--accent) / .2);
      border-radius: 1rem;
      padding: 2rem;
      text-align: center;
      display: flex;
      flex-direction: column;
      align-items: center;
    }

    .ba-bottom-cta__card .inner {
      flex: 1;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: .75rem;
    }

    .ba-bottom-cta__card h2 {
      font-size: 1.5rem;
      font-weight: 600;
      color: hsl(var(--foreground));
      margin: 0;
    }

    .ba-bottom-cta__card p {
      font-size: .875rem;
      color: hsl(var(--muted-fg));
      line-height: 1.6;
      margin: 0;
    }

    .ba-bottom-cta__card .btn-wrap {
      margin-top: 1.5rem;
    }

    /* ── Responsive ── */
    @media (max-width: 768px) {
      .ba-hero__box h1 {
        font-size: 38px;
      }

      .ba-trust__grid {
        grid-template-columns: 1fr;
      }

      .ba-trust__num {
        font-size: 2.5rem;
      }

      .ba-about__grid {
        grid-template-columns: 1fr;
        text-align: center;
      }

      .ba-about__img {
        width: 256px;
        height: 256px;
      }

      .ba-pricing__banner {
        height: 256px;
      }

      .ba-bottom-cta__grid {
        grid-template-columns: 1fr;
      }

      .ba-testimonials__featured {
        display: none;
      }

      .ba-nav {
        gap: 2rem;
      }

      .ba-nav__logo img {
        height: 40px;
      }
    }

.bridals-nav__logo {
  margin-right: 40px !important;
}
/* ===== HERO FIX SAUBER ===== */

/* Hero bleibt mittig */
.ba-hero__box {
  align-items: center;
  text-align: center;
}

/* Buttons sauber nebeneinander mit Abstand */
.ba-hero__buttons {
  display: flex;
  gap: 30px;
  justify-content: center;
  margin-top: 30px;
  flex-wrap: wrap;
}

/* Hover überlappt nicht mehr */
.ba-btn {
  position: relative;
  z-index: 1;
}

.ba-btn:hover {
  transform: scale(1.05);
  z-index: 2;
}


/* ===== NAV FIX ===== */

.bridals-nav {
  display: flex;
  justify-content: flex-end;
  padding: 20px 60px;
}

/* Container */
.nav-right {
  display: flex;
  align-items: center;
  gap: 40px;
}

/* Logo Abstand */
.bridals-nav__logo {
  margin-right: 20px;
}

/* Schrift größer + mehr Luft */
.bridals-nav__link {
  font-size: 1rem;
  letter-spacing: 0.08em;
}

/* ===== HERO FIX SAUBER ===== */

/* Hero bleibt mittig */
.ba-hero__box {
  align-items: center;
  text-align: center;
}

/* Buttons sauber nebeneinander mit Abstand */
.ba-hero__buttons {
  display: flex;
  gap: 30px;
  justify-content: center;
  margin-top: 30px;
  flex-wrap: wrap;
}

/* Hover überlappt nicht mehr */
.ba-btn {
  position: relative;
  z-index: 1;
}

.ba-btn:hover {
  transform: scale(1.05);
  z-index: 2;
}


/* ===== NAV FIX ===== */

.bridals-nav {
  display: flex;
  justify-content: flex-end;
  padding: 20px 60px;
}

/* Container */
.nav-right {
  display: flex;
  align-items: center;
  gap: 40px;
}

/* Schrift größer + mehr Luft */
.bridals-nav__link {
  font-size: 1rem;
  letter-spacing: 0.08em;
}

/* Hover */
.ba-btn:hover,
.button-primary:hover,
.wpforms-submit:hover {
  background-color: #8c644e !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(0,0,0,0.15);
}

/* BANNER WRAPPER */
.ba-pricing-banner-wrap {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
}

/* BANNER */
.ba-pricing__banner {
  width: 100%;
  height: 45vh;
  min-height: 420px;
  max-height: 700px;

  object-fit: cover;
  display: block;
}

