/*
 * JuBo Events & more – Startseite
 * Gold Luxe / Mobile First / OceanWP Child Theme
 * Typografie-Feintuning: ruhige Desktop-Hierarchie + kontrollierter Mobile-Abgleich
 * Abstands-Feintuning V6: 1280px Container + einheitliche Section-Abstände als freigegebene Basis
 * Kleines Feintuning: CTA-Boom-Hover, Brand-Kachel-Abstände, Mobile-Bildreihenfolge, warmere Abschnittstrennung, Section-Header-Eyebrow-Testkorrektur
 */

.jubo-home {
	--jubo-white-rock: #e7e7d9;
	--jubo-bombay: #b4babc;
	--jubo-dim-gray: #67646c;
	--jubo-chicago: #545c56;
	--jubo-zeus: #272119;
	--jubo-deco: #dad99b;
	--jubo-golden-dream: #f4dd30;
	--jubo-dark-goldenrod: #b7890a;
	--jubo-shadow: #81744e;
	--jubo-raw-umber: #6f5113;
	--jubo-radius-lg: 30px;
	--jubo-radius-md: 22px;
	--jubo-radius-sm: 14px;
	--jubo-shadow-soft: 0 24px 70px rgba(39, 33, 25, 0.14);
	--jubo-shadow-dark: 0 26px 80px rgba(0, 0, 0, 0.28);
	--jubo-container: 1280px;
	background: var(--jubo-white-rock);
	color: var(--jubo-zeus);
	font-size: 16px;
	line-height: 1.65;
	overflow: hidden;
}

.jubo-home *, .jubo-home *::before, .jubo-home *::after { box-sizing: border-box; }
.jubo-home a { color: inherit; text-decoration: none; }
.jubo-home-container { width: min(calc(100% - clamp(116px, 12vw, 180px)), var(--jubo-container)); margin-inline: auto; }
.jubo-home-section { position: relative; padding: clamp(58px, 6vw, 90px) 0; }
.jubo-home-section--light { background: radial-gradient(circle at 10% 10%, rgba(183, 137, 10, 0.09), transparent 30%), var(--jubo-white-rock); }
.jubo-home-section--warm { background: radial-gradient(circle at 12% 8%, rgba(183, 137, 10, 0.18), transparent 31%), linear-gradient(135deg, rgba(218, 217, 155, 0.9), rgba(231, 231, 217, 0.72) 52%, rgba(183, 137, 10, 0.16)), var(--jubo-deco); box-shadow: inset 0 1px 0 rgba(183, 137, 10, 0.16), inset 0 -1px 0 rgba(39, 33, 25, 0.08); }
.jubo-home-section--dark { background: radial-gradient(circle at top right, rgba(183, 137, 10, 0.17), transparent 34%), linear-gradient(135deg, var(--jubo-zeus), #17130f); color: var(--jubo-white-rock); }
.jubo-home-section--green { background: linear-gradient(135deg, rgba(84, 92, 86, 0.98), rgba(39, 33, 25, 0.95)), var(--jubo-chicago); color: var(--jubo-white-rock); }
.jubo-home-section--final { background: radial-gradient(circle at 50% 0%, rgba(244, 221, 48, 0.13), transparent 34%), var(--jubo-zeus); color: var(--jubo-white-rock); padding-bottom: clamp(58px, 6vw, 90px); }
.jubo-home-eyebrow { margin: 0 0 clamp(16px, 1.35vw, 20px); color: var(--jubo-dark-goldenrod); font-size: clamp(14px, 1.05vw, 19px); font-weight: 800; letter-spacing: .09em; line-height: 1.35; text-transform: uppercase; }
.jubo-home-section--dark .jubo-home-eyebrow, .jubo-home-section--green .jubo-home-eyebrow, .jubo-home-section--final .jubo-home-eyebrow, .jubo-home-hero .jubo-home-eyebrow { color: var(--jubo-deco); }
.jubo-home h1, .jubo-home h2, .jubo-home h3, .jubo-home p { margin-top: 0; }
.jubo-home p, .jubo-home li { font-size: clamp(15.75px, .85vw, 16.5px); line-height: 1.66; }
.jubo-home small, .jubo-home figcaption { font-size: 14px; line-height: 1.5; }
.jubo-home h1, .jubo-home h2 { color: inherit; font-weight: 650; letter-spacing: -.045em; line-height: 1; }
.jubo-home h1 { max-width: 880px; margin-bottom: 26px; font-size: clamp(50px, 6vw, 80px); }
.jubo-home h2 { margin-bottom: 24px; font-size: clamp(38px, 4.6vw, 70px); }
.jubo-home h3 { margin-bottom: 14px; color: inherit; font-size: clamp(20px, 1.55vw, 25px); font-weight: 650; line-height: 1.18; letter-spacing: -.02em; }
.jubo-home-section-intro { max-width: 760px; }
.jubo-home-section-intro > p:not(.jubo-home-eyebrow), .jubo-home-section-header p:not(.jubo-home-eyebrow) { max-width: 720px; margin-bottom: 0; color: rgba(39,33,25,.76); font-size: clamp(16px, 1.15vw, 18px); line-height: 1.62; }
.jubo-home-section--dark .jubo-home-section-intro > p:not(.jubo-home-eyebrow), .jubo-home-section--dark .jubo-home-section-header p:not(.jubo-home-eyebrow), .jubo-home-section--green .jubo-home-section-intro > p:not(.jubo-home-eyebrow), .jubo-home-section--final .jubo-home-section-intro > p:not(.jubo-home-eyebrow) { color: rgba(231,231,217,.78); }
.jubo-home-section-intro--center { margin-inline: auto; text-align: center; }
.jubo-home-section-intro--center > p:not(.jubo-home-eyebrow) { margin-inline: auto; }
.jubo-home-section-header { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: clamp(24px, 4vw, 40px); align-items: end; margin-bottom: clamp(28px,4vw,44px); }
.jubo-home-section-header__action { display: flex; justify-content: flex-end; }
.jubo-home-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.jubo-home-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 52px; padding: 15px 26px; border: 1px solid transparent; border-radius: 999px; font-size: clamp(15.5px, .82vw, 17px); font-weight: 800; letter-spacing: .065em; line-height: 1.2; text-transform: uppercase; transition: transform .18s ease, background-color .18s ease, border-color .18s ease, color .18s ease; }
.jubo-home-btn:hover, .jubo-home-btn:focus-visible { transform: translateY(-2px); }
.jubo-home-btn--primary { background: var(--jubo-dark-goldenrod); color: var(--jubo-white-rock); box-shadow: 0 16px 34px rgba(111,81,19,.22); }
.jubo-home-btn--primary:hover, .jubo-home-btn--primary:focus-visible { background: var(--jubo-raw-umber); color: var(--jubo-white-rock); }
.jubo-home-btn--secondary { border-color: rgba(231,231,217,.54); background: rgba(231,231,217,.09); color: var(--jubo-white-rock); backdrop-filter: blur(14px); }
.jubo-home .jubo-home-btn { position: relative; overflow: hidden; isolation: isolate; transition: transform .28s cubic-bezier(.22,1,.36,1), box-shadow .28s ease, background-color .28s ease, border-color .28s ease, color .28s ease; }
.jubo-home .jubo-home-btn::before { content: ""; position: absolute; inset: -2px; z-index: -1; border-radius: inherit; background: radial-gradient(circle at 50% 50%, rgba(244,221,48,.32), transparent 56%); opacity: 0; transform: scale(.72); transition: opacity .28s ease, transform .38s cubic-bezier(.22,1,.36,1); }
.jubo-home .jubo-home-btn::after { content: ""; position: absolute; top: -42%; bottom: -42%; left: -68%; width: 46%; background: linear-gradient(105deg, transparent 0%, rgba(255,255,255,.18) 38%, rgba(255,255,255,.52) 50%, rgba(255,255,255,.16) 62%, transparent 100%); opacity: 0; transform: skewX(-18deg); pointer-events: none; }
.jubo-home .jubo-home-btn:hover, .jubo-home .jubo-home-btn:focus-visible { transform: translateY(-4px) scale(1.018); }
.jubo-home .jubo-home-btn:hover::before, .jubo-home .jubo-home-btn:focus-visible::before { opacity: 1; transform: scale(1); }
.jubo-home .jubo-home-btn:hover::after, .jubo-home .jubo-home-btn:focus-visible::after { left: 122%; opacity: 1; transition: left .58s cubic-bezier(.22,1,.36,1), opacity .18s ease; }
.jubo-home .jubo-home-btn--primary { box-shadow: 0 18px 38px rgba(111,81,19,.28), 0 0 0 1px rgba(244,221,48,.08); }
.jubo-home .jubo-home-btn--primary:hover, .jubo-home .jubo-home-btn--primary:focus-visible { background: linear-gradient(135deg, var(--jubo-dark-goldenrod), var(--jubo-raw-umber)); box-shadow: 0 24px 54px rgba(111,81,19,.36), 0 0 0 1px rgba(244,221,48,.22), 0 0 34px rgba(183,137,10,.2); }
.jubo-home .jubo-home-btn--secondary:hover, .jubo-home .jubo-home-btn--secondary:focus-visible { border-color: rgba(218,217,155,.86); background: rgba(231,231,217,.16); box-shadow: 0 20px 42px rgba(0,0,0,.24), 0 0 0 1px rgba(218,217,155,.12); }

.jubo-home-section--light .jubo-home-btn--secondary, .jubo-home-section--warm .jubo-home-btn--secondary { border-color: rgba(39,33,25,.2); background: transparent; color: var(--jubo-zeus); }
.jubo-home-section--light .jubo-home-btn--secondary:hover, .jubo-home-section--light .jubo-home-btn--secondary:focus-visible, .jubo-home-section--warm .jubo-home-btn--secondary:hover, .jubo-home-section--warm .jubo-home-btn--secondary:focus-visible { border-color: rgba(183,137,10,.62); background: rgba(183,137,10,.08); color: var(--jubo-zeus); box-shadow: 0 18px 38px rgba(111,81,19,.14), 0 0 0 1px rgba(183,137,10,.1); }
.jubo-home-text-link { display: inline-flex; align-items: center; gap: 8px; margin-top: 12px; color: var(--jubo-dark-goldenrod); font-size: clamp(14px, .72vw, 15.5px); font-weight: 800; letter-spacing: .075em; line-height: 1.35; text-transform: uppercase; }
.jubo-home-text-link::after { content: ""; width: 28px; height: 1px; background: currentColor; transition: width .18s ease; }
.jubo-home-text-link:hover::after, .jubo-home-text-link:focus-visible::after { width: 44px; }

.jubo-home-hero { position: relative; display: flex; min-height: clamp(500px, 68vh, 640px); align-items: center; background: var(--jubo-zeus); color: var(--jubo-white-rock); isolation: isolate; }
.jubo-home-hero__media, .jubo-home-hero__overlay, .jubo-home-hero__picture, .jubo-home-hero__picture img, .jubo-home-hero__fallback { position: absolute; inset: 0; width: 100%; height: 100%; }
.jubo-home-hero__media { z-index: -3; overflow: hidden; }
.jubo-home-hero__picture img { object-fit: cover; transform: scale(1.02); }
.jubo-home-hero__fallback { background: radial-gradient(circle at 70% 18%, rgba(244,221,48,.16), transparent 24%), linear-gradient(135deg, rgba(111,81,19,.95), rgba(39,33,25,.98) 56%), var(--jubo-zeus); }
.jubo-home-hero__overlay { z-index: -2; background: linear-gradient(90deg, rgba(39,33,25,.92) 0%, rgba(39,33,25,.74) 42%, rgba(39,33,25,.38) 100%), linear-gradient(180deg, rgba(39,33,25,.2), rgba(39,33,25,.74)); }
.jubo-home-hero__inner { padding: clamp(58px, 6vw, 90px) 0; }
.jubo-home-hero__content { max-width: 860px; }
.jubo-home-hero__lead { max-width: 690px; margin-bottom: 0; color: rgba(231,231,217,.86); font-size: clamp(16px, 1.15vw, 18px); line-height: 1.58; }
.jubo-home-microcopy { margin-top: 24px; color: rgba(218,217,155,.84); font-size: clamp(14.5px, .72vw, 15.5px); line-height: 1.55; letter-spacing: .02em; }
.jubo-home-card-grid { display: grid; gap: clamp(20px, 2vw, 24px); margin-top: clamp(28px,4vw,44px); }
.jubo-home-card-grid--three { grid-template-columns: repeat(3, minmax(0,1fr)); }
.jubo-home-card, .jubo-home-product-card, .jubo-home-event-card, .jubo-home-path-card, .jubo-home-trust-item { position: relative; border: 1px solid rgba(39,33,25,.1); border-radius: var(--jubo-radius-md); background: rgba(255,255,255,.34); box-shadow: var(--jubo-shadow-soft); overflow: hidden; }
.jubo-home-card--quiet { padding: clamp(22px,2.6vw,30px); background: rgba(231,231,217,.78); }
.jubo-home-card__number { display: inline-flex; margin-bottom: clamp(8px, .7vw, 12px); color: var(--jubo-dark-goldenrod); font-size: clamp(14px, 1.05vw, 19px); font-weight: 800; letter-spacing: .09em; line-height: 1.35; }
.jubo-home-card p, .jubo-home-product-card p, .jubo-home-event-card p, .jubo-home-path-card p, .jubo-home-trust-item p, .jubo-home-benefit p { margin-bottom: 0; color: rgba(39,33,25,.72); font-size: clamp(15.75px, .85vw, 16.5px); line-height: 1.68; }
.jubo-home-section--dark .jubo-home-event-card p, .jubo-home-section--green .jubo-home-trust-item p, .jubo-home-section--final .jubo-home-path-card p { color: rgba(231,231,217,.72); }
.jubo-home-events__layout { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: clamp(24px, 4vw, 48px); }
.jubo-home-events__side { display: grid; gap: clamp(20px, 2.2vw, 24px); }
.jubo-home-event-card { display: grid; grid-template-columns: 42% minmax(0,1fr); min-height: 260px; border-color: rgba(231,231,217,.14); background: rgba(231,231,217,.06); box-shadow: var(--jubo-shadow-dark); }
.jubo-home-event-card--featured { grid-template-columns: 1fr; min-height: 100%; }
.jubo-home-event-card__media, .jubo-home-product-card__media, .jubo-home-feature__media { position: relative; display: block; min-height: 220px; overflow: hidden; background: rgba(183,137,10,.12); }
.jubo-home-event-card--featured .jubo-home-event-card__media { min-height: 390px; }
.jubo-home-img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform .42s ease; }
.jubo-home-event-card:hover .jubo-home-img, .jubo-home-product-card:hover .jubo-home-img { transform: scale(1.045); }
.jubo-home-media-placeholder { position: relative; min-height: 100%; background: radial-gradient(circle at 70% 15%, rgba(244,221,48,.15), transparent 28%), linear-gradient(135deg, rgba(84,92,86,.94), rgba(39,33,25,.98)); }
.jubo-home-media-placeholder span { position: absolute; inset: auto 22px 22px 22px; height: 1px; background: rgba(218,217,155,.54); }
.jubo-home-event-card__content { padding: clamp(22px,2.8vw,32px); }
.jubo-home-event-card h3 a, .jubo-home-product-card h3 a { color: inherit; }
.jubo-home-card-meta { margin-bottom: clamp(16px, 1.2vw, 20px); color: var(--jubo-deco) !important; font-size: clamp(14px, 1.05vw, 19px); font-weight: 800; letter-spacing: .09em; line-height: 1.35; text-transform: uppercase; }
.jubo-home-feature { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: clamp(24px, 4vw, 48px); align-items: center; }
.jubo-home-feature__content { max-width: 690px; }
.jubo-home-feature__content > p:not(.jubo-home-eyebrow) { margin-bottom: 26px; color: rgba(39,33,25,.75); font-size: clamp(16px, 1.15vw, 18px); line-height: 1.62; }
.jubo-home-feature__media { min-height: clamp(330px,44vw,560px); border: 1px solid rgba(111,81,19,.18); border-radius: var(--jubo-radius-lg); box-shadow: var(--jubo-shadow-soft); }
.jubo-home-benefits { display: grid; gap: 14px; margin: 26px 0 30px; }
.jubo-home-benefit { padding: 18px 24px; border-left: 2px solid var(--jubo-dark-goldenrod); }
.jubo-home-product-card { background: rgba(255,255,255,.4); }
.jubo-home-product-card__media { min-height: 280px; }
.jubo-home-product-card__content { padding: clamp(22px,2.6vw,30px); }
.jubo-home-trust__layout { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: clamp(24px, 4vw, 48px); align-items: start; }
.jubo-home-trust__items { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 22px; }
.jubo-home-trust-item { padding: clamp(22px,2.6vw,30px); border-color: rgba(231,231,217,.14); background: rgba(231,231,217,.07); box-shadow: none; }
.jubo-home-trust-item__marker { display: block; width: 38px; height: 2px; margin-bottom: 24px; background: var(--jubo-dark-goldenrod); }
.jubo-home-final__box { padding: clamp(30px,6vw,66px); border: 1px solid rgba(218,217,155,.18); border-radius: var(--jubo-radius-lg); background: linear-gradient(135deg, rgba(231,231,217,.08), rgba(183,137,10,.08)), rgba(231,231,217,.04); box-shadow: var(--jubo-shadow-dark); }
.jubo-home-final__paths { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 22px; margin-top: clamp(28px,4vw,44px); }
.jubo-home-path-card { padding: clamp(22px,2.6vw,30px); border-color: rgba(218,217,155,.16); background: rgba(231,231,217,.06); box-shadow: none; }
.jubo-home-path-card .jubo-home-text-link { color: var(--jubo-deco); }


/* Die 01/02/03-Marker in der Markenversprechen-Sektion sitzen jetzt deutlich näher an der jeweiligen Überschrift. */
.jubo-home .jubo_home_brand_item_1_title,
.jubo-home .jubo_home_brand_item_2_title,
.jubo-home .jubo_home_brand_item_3_title,
.jubo-home [class~="jubo_home_brand_item_1_title"],
.jubo-home [class~="jubo_home_brand_item_2_title"],
.jubo-home [class~="jubo_home_brand_item_3_title"] { margin-top: 0 !important; }

@media (max-width: 1024px) {
	.jubo-home-section-header, .jubo-home-feature, .jubo-home-trust__layout { grid-template-columns: 1fr; }
	.jubo-home-section-header__action { justify-content: flex-start; }
	.jubo-home-card-grid--three, .jubo-home-final__paths, .jubo-home-events__layout { grid-template-columns: 1fr; }
	.jubo-home-event-card--featured .jubo-home-event-card__media { min-height: 330px; }
}

@media (max-width: 767px) {
	.jubo-home { font-size: 15px; line-height: 1.62; }
	.jubo-home-container { width: min(calc(100% - clamp(36px, 9vw, 54px)), var(--jubo-container)); }
	.jubo-home-section { padding: 54px 0; }
	.jubo-home-section--final { padding-bottom: 54px; }
	.jubo-home-hero { min-height: 480px; }
	.jubo-home-hero__inner { padding: 54px 0; }
	.jubo-home-hero__overlay { background: linear-gradient(180deg, rgba(39,33,25,.58), rgba(39,33,25,.94) 72%), linear-gradient(90deg, rgba(39,33,25,.58), rgba(39,33,25,.72)); }
	.jubo-home h1 { margin-bottom: 22px; font-size: clamp(38px, 10vw, 50px); line-height: 1.03; }
	.jubo-home h2 { margin-bottom: 20px; font-size: clamp(28px, 7.6vw, 38px); line-height: 1.04; }
	.jubo-home h3 { margin-bottom: 12px; font-size: clamp(20px, 5.3vw, 23px); line-height: 1.2; }
	.jubo-home p, .jubo-home li { font-size: clamp(15px, 3.6vw, 15.75px); line-height: 1.64; }
	.jubo-home-eyebrow { margin-bottom: 15px; font-size: clamp(13px, 3.2vw, 14px); letter-spacing: .08em; }
	.jubo-home-section-intro > p:not(.jubo-home-eyebrow), .jubo-home-section-header p:not(.jubo-home-eyebrow), .jubo-home-feature__content > p:not(.jubo-home-eyebrow) { font-size: clamp(15.25px, 3.8vw, 16px); line-height: 1.62; }
	.jubo-home-hero__lead { font-size: clamp(15.5px, 4vw, 16.5px); line-height: 1.6; }
	.jubo-home-microcopy { font-size: clamp(14px, 3.5vw, 14.75px); line-height: 1.55; }
	.jubo-home-card p, .jubo-home-product-card p, .jubo-home-event-card p, .jubo-home-path-card p, .jubo-home-trust-item p, .jubo-home-benefit p { font-size: clamp(15px, 3.6vw, 15.75px); line-height: 1.66; }
	.jubo-home-card-meta { margin-bottom: 15px; font-size: clamp(13px, 3.2vw, 14px); letter-spacing: .08em; line-height: 1.35; }
	.jubo-home-card__number { font-size: clamp(13px, 3.2vw, 14px); letter-spacing: .08em; line-height: 1.35; }
	.jubo-home-text-link { font-size: clamp(13.25px, 3.3vw, 14.5px); letter-spacing: .07em; line-height: 1.35; }
	.jubo-home-actions { display: grid; }
	.jubo-home-btn { width: 100%; min-height: 52px; padding: 15px 22px; font-size: clamp(15px, 3.8vw, 16px); letter-spacing: .06em; }
	.jubo-home-section-intro--center { text-align: left; }
	.jubo-home-event-card { grid-template-columns: 1fr; min-height: auto; }
	.jubo-home-event-card__media, .jubo-home-product-card__media, .jubo-home-event-card--featured .jubo-home-event-card__media { min-height: 250px; }
	.jubo-home-feature__media { min-height: 300px; order: 0; }
	.jubo-home-trust__items { grid-template-columns: 1fr; }
	.jubo-home-final__box { padding: 24px 20px; border-radius: 24px; }
}

@media (prefers-reduced-motion: reduce) {
	.jubo-home .jubo-home-btn, .jubo-home .jubo-home-btn::before, .jubo-home .jubo-home-btn::after { transition: none; }
	.jubo-home .jubo-home-btn::after { display: none; }
}

@media (max-width: 480px) {
	.jubo-home-container { width: min(calc(100% - 36px), var(--jubo-container)); }
	.jubo-home h1 { font-size: clamp(36px, 9.8vw, 44px); }
	.jubo-home h2 { font-size: clamp(28px, 7.6vw, 34px); }
	.jubo-home-section-intro > p:not(.jubo-home-eyebrow), .jubo-home-section-header p:not(.jubo-home-eyebrow), .jubo-home-feature__content > p:not(.jubo-home-eyebrow), .jubo-home-hero__lead { font-size: 15.25px; }
	.jubo-home-card p, .jubo-home-product-card p, .jubo-home-event-card p, .jubo-home-path-card p, .jubo-home-trust-item p, .jubo-home-benefit p { font-size: 15px; }
}
