/*
 * Startseite Obsthof Stockinger
 * Child-Theme-Version: 5.7.5
 * Build: 2026-06-29.5
 * Wird nach my-nova.css geladen und eignet sich fuer OPC/Composer-Inhalte.
 */

:root {
    --stockinger-cream: #fff7e8;
    --stockinger-cream-2: #f4ead4;
    --stockinger-cream-3: #edf1dc;
    --stockinger-green: #23451f;
    --stockinger-green-2: #3f6b24;
    --stockinger-green-3: #6f8f37;
    --stockinger-red: #8e2328;
    --stockinger-gold: #d7a642;
    --stockinger-ink: #263126;
    --stockinger-muted: #6c7468;
    --stockinger-border: rgba(35, 69, 31, 0.14);
    --stockinger-shadow: 0 18px 50px rgba(35, 69, 31, 0.13);
}

/*
 * Build 20260629.3: starke OPC/JTL-Overrides.
 * Muss am Dateiende stehen, damit NOVA-Buttonfarben nicht gelb/grau durchsetzen.
 */
.os-opc-page,
.os-opc-page .opc-Container,
.os-opc-page .opc-container,
.os-opc-page .opc-GridLayout {
    background-color: transparent !important;
}

.os-opc-page {
    background: linear-gradient(180deg, #fffaf0 0%, #f8efd9 100%) !important;
}

.os-opc-page .os-hero,
.os-hero {
    background:
        radial-gradient(circle at 88% 28%, rgba(216, 77, 66, 0.14), transparent 18rem),
        radial-gradient(circle at 72% 18%, rgba(215, 166, 66, 0.2), transparent 24rem),
        linear-gradient(105deg, #fff9ec 0%, #f8edd6 44%, #edf2dc 100%) !important;
}

.os-opc-page .btn-primary,
.os-opc-page a.btn-primary,
.os-opc-page button.btn-primary,
.os-opc-page .opc-Button .btn-primary,
.os-opc-page .os-button-primary .btn,
.os-opc-page .os-button-primary a,
.os-opc-page .os-button-primary button {
    color: #ffffff !important;
    background-color: #23451f !important;
    background-image: none !important;
    border-color: #23451f !important;
    box-shadow: 0 12px 24px rgba(35, 69, 31, 0.24) !important;
}

.os-opc-page .btn-primary:hover,
.os-opc-page a.btn-primary:hover,
.os-opc-page button.btn-primary:hover,
.os-opc-page .opc-Button .btn-primary:hover,
.os-opc-page .os-button-primary .btn:hover,
.os-opc-page .os-button-primary a:hover,
.os-opc-page .os-button-primary button:hover {
    color: #ffffff !important;
    background-color: #172f15 !important;
    border-color: #172f15 !important;
}

.os-opc-page .btn-secondary,
.os-opc-page a.btn-secondary,
.os-opc-page button.btn-secondary,
.os-opc-page .opc-Button .btn-secondary,
.os-opc-page .os-button-secondary .btn,
.os-opc-page .os-button-secondary a,
.os-opc-page .os-button-secondary button {
    color: #23451f !important;
    background-color: #eef4e4 !important;
    background-image: none !important;
    border-color: #6f8f37 !important;
    box-shadow: none !important;
}

.os-opc-page .btn-secondary:hover,
.os-opc-page a.btn-secondary:hover,
.os-opc-page button.btn-secondary:hover,
.os-opc-page .opc-Button .btn-secondary:hover,
.os-opc-page .os-button-secondary .btn:hover,
.os-opc-page .os-button-secondary a:hover,
.os-opc-page .os-button-secondary button:hover {
    color: #23451f !important;
    background-color: #f7fbef !important;
    border-color: #23451f !important;
}

.stockinger-home {
    color: var(--stockinger-ink);
    background: linear-gradient(180deg, #fffaf0 0%, #f8efd9 100%);
    overflow: hidden;
}

.stockinger-home a {
    text-decoration: none;
}

.stockinger-home .home-section {
    padding: 4rem 0;
}

.stockinger-home .home-section-header {
    max-width: 760px;
    margin: 0 auto 2rem;
    text-align: center;
}

.stockinger-home .home-eyebrow {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--stockinger-green-2);
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

.stockinger-home h1,
.stockinger-home h2,
.stockinger-home h3 {
    color: var(--stockinger-green);
    line-height: 1.08;
}

.stockinger-home h1 {
    margin: 0 0 1rem;
    font-size: clamp(2.35rem, 6vw, 4.95rem);
    max-width: 12ch;
}

.stockinger-home h2 {
    margin: 0 0 0.75rem;
    font-size: clamp(2rem, 4vw, 3.15rem);
}

.stockinger-home h3 {
    margin: 0 0 0.45rem;
    font-size: 1.25rem;
}

.stockinger-home p {
    color: var(--stockinger-muted);
    font-size: 1rem;
    line-height: 1.7;
}

.stockinger-home .home-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3rem;
    padding: 0.85rem 1.25rem;
    border-radius: 999px;
    font-weight: 700;
    line-height: 1.2;
    transition: transform 160ms ease, box-shadow 160ms ease, background-color 160ms ease;
}

.stockinger-home .home-btn:hover,
.stockinger-home .home-btn:focus {
    transform: translateY(-1px);
    text-decoration: none;
}

.stockinger-home .home-btn-primary {
    color: #fff;
    background: var(--stockinger-green);
    box-shadow: 0 12px 24px rgba(35, 69, 31, 0.24);
}

.stockinger-home .home-btn-primary:hover,
.stockinger-home .home-btn-primary:focus {
    color: #fff;
    background: #172f15;
}

.stockinger-home .home-btn-secondary {
    color: var(--stockinger-green);
    background: #eef4e4;
    border: 1px solid rgba(63, 107, 36, 0.34);
}

.home-hero {
    position: relative;
    padding: clamp(2rem, 5vw, 4.5rem) 0 3rem;
    background:
        radial-gradient(circle at 82% 20%, rgba(215, 166, 66, 0.18), transparent 28rem),
        linear-gradient(135deg, #fff9ec 0%, #f8edd6 47%, #edf2dc 100%);
}

.home-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(255, 253, 248, 0.94) 0%, rgba(255, 253, 248, 0.62) 44%, rgba(255, 253, 248, 0.12) 100%),
        repeating-linear-gradient(110deg, rgba(31, 63, 36, 0.04), rgba(31, 63, 36, 0.04) 1px, transparent 1px, transparent 18px);
    pointer-events: none;
}

.home-hero-inner {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
}

.home-hero-copy {
    max-width: 680px;
}

.home-hero-copy p {
    max-width: 640px;
    margin-bottom: 1.4rem;
    color: #4d5b4d;
    font-size: clamp(1rem, 2vw, 1.18rem);
}

.home-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.home-hero-visual {
    position: relative;
    min-height: clamp(320px, 42vw, 520px);
    border-radius: 2rem 0.6rem 2rem 0.6rem;
    background:
        linear-gradient(rgba(31, 63, 36, 0.12), rgba(31, 63, 36, 0.1)),
        radial-gradient(circle at 24% 24%, #d84d42 0 7%, transparent 8%),
        radial-gradient(circle at 36% 28%, #f1c64a 0 9%, transparent 10%),
        radial-gradient(circle at 46% 18%, #b52c32 0 8%, transparent 9%),
        radial-gradient(circle at 68% 31%, #e7b24c 0 10%, transparent 11%),
        linear-gradient(135deg, #f8e8bc, #dae2af 52%, #49682a);
    box-shadow: var(--stockinger-shadow);
    overflow: hidden;
}

.home-hero-visual::before {
    content: "";
    position: absolute;
    right: 7%;
    bottom: 8%;
    width: 52%;
    height: 48%;
    border-radius: 1.2rem;
    background:
        linear-gradient(90deg, rgba(142, 35, 40, 0.9), rgba(101, 25, 31, 0.9)),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.2) 1px, transparent 1px, transparent 15px);
    box-shadow: 0 16px 36px rgba(31, 63, 36, 0.28);
}

.home-hero-visual::after {
    content: "Bag-in-Box & Direktsaft";
    position: absolute;
    right: 10%;
    bottom: 21%;
    max-width: 12rem;
    color: #fff;
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1.15;
    text-align: center;
}

.home-hero-badge {
    position: absolute;
    right: -1rem;
    top: 12%;
    display: grid;
    place-items: center;
    width: 8rem;
    height: 8rem;
    padding: 1rem;
    border-radius: 50%;
    color: var(--stockinger-green);
    background: #fffdf8;
    border: 8px solid rgba(69, 107, 33, 0.22);
    font-weight: 800;
    line-height: 1.15;
    text-align: center;
    box-shadow: 0 12px 26px rgba(31, 63, 36, 0.18);
}

.home-trust {
    position: relative;
    z-index: 2;
    margin-top: -1.6rem;
}

.home-trust-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    border: 1px solid var(--stockinger-border);
    border-radius: 1rem;
    background: rgba(255, 253, 248, 0.96);
    box-shadow: 0 14px 34px rgba(31, 63, 36, 0.12);
    overflow: hidden;
}

.home-trust-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.85rem;
    align-items: center;
    padding: 1.1rem;
    border-right: 1px solid var(--stockinger-border);
}

.home-trust-item:last-child {
    border-right: 0;
}

.home-trust-icon {
    display: grid;
    place-items: center;
    width: 2.85rem;
    height: 2.85rem;
    border-radius: 50%;
    color: var(--stockinger-green-2);
    background: #edf3df;
    font-size: 1.35rem;
}

.home-trust-item strong {
    display: block;
    color: var(--stockinger-green);
    font-size: 0.98rem;
}

.home-trust-item span {
    color: var(--stockinger-muted);
    font-size: 0.88rem;
}

.home-categories {
    background: #fffdf8;
}

.home-category-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 1rem;
}

.home-category-card {
    position: relative;
    display: flex;
    min-height: 18rem;
    padding: 1rem;
    border-radius: 1rem;
    overflow: hidden;
    background: var(--stockinger-green);
    box-shadow: 0 12px 28px rgba(31, 63, 36, 0.16);
}

.home-category-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(31, 63, 36, 0.08), rgba(31, 63, 36, 0.88)),
        var(--category-bg, linear-gradient(135deg, #7a9a35, #263126));
    transform: scale(1.02);
}

.home-category-card > div {
    position: relative;
    z-index: 1;
    align-self: flex-end;
}

.home-category-card h3 {
    color: #fff;
}

.home-category-card p {
    margin-bottom: 0.8rem;
    color: rgba(255, 255, 255, 0.84);
    font-size: 0.92rem;
}

.home-category-card .home-card-link {
    color: #fff;
    font-weight: 800;
}

.home-category-apple { --category-bg: radial-gradient(circle at 32% 20%, #f5c24a 0 12%, transparent 13%), radial-gradient(circle at 62% 32%, #c63f35 0 14%, transparent 15%), linear-gradient(135deg, #6b8e2b, #263126); }
.home-category-aronia { --category-bg: radial-gradient(circle at 40% 25%, #231533 0 16%, transparent 17%), radial-gradient(circle at 66% 38%, #4d1b55 0 14%, transparent 15%), linear-gradient(135deg, #6a254f, #263126); }
.home-category-grape { --category-bg: radial-gradient(circle at 34% 26%, #7c2555 0 13%, transparent 14%), radial-gradient(circle at 58% 42%, #d7a642 0 14%, transparent 15%), linear-gradient(135deg, #4e6b2f, #263126); }
.home-category-cherry { --category-bg: radial-gradient(circle at 36% 24%, #a3182b 0 15%, transparent 16%), radial-gradient(circle at 62% 38%, #d6424f 0 12%, transparent 13%), linear-gradient(135deg, #7b1f2d, #263126); }
.home-category-beet { --category-bg: radial-gradient(circle at 48% 30%, #76243f 0 20%, transparent 21%), linear-gradient(135deg, #8e2328, #263126); }
.home-category-pomegranate { --category-bg: radial-gradient(circle at 44% 27%, #b52c32 0 17%, transparent 18%), radial-gradient(circle at 64% 36%, #f0b866 0 10%, transparent 11%), linear-gradient(135deg, #a02d33, #263126); }

.home-category-actions {
    margin-top: 1.35rem;
    text-align: center;
}

.home-feature-split {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: center;
}

.home-bib {
    background: linear-gradient(180deg, #fffdf8, var(--stockinger-cream));
}

.home-bib-panel,
.home-contract-panel,
.home-about-panel,
.home-newsletter-panel {
    border: 1px solid var(--stockinger-border);
    border-radius: 1.2rem;
    background: rgba(255, 253, 248, 0.9);
    box-shadow: 0 14px 34px rgba(31, 63, 36, 0.1);
}

.home-bib-panel {
    padding: clamp(1.5rem, 4vw, 2.4rem);
}

.home-bib-list {
    display: grid;
    gap: 0.75rem;
    margin: 1.25rem 0 0;
    padding: 0;
    list-style: none;
}

.home-bib-list li {
    position: relative;
    padding-left: 2rem;
    color: var(--stockinger-ink);
    font-weight: 700;
}

.home-bib-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.25rem;
    width: 1.2rem;
    height: 1.2rem;
    border-radius: 50%;
    background: var(--stockinger-green-2);
    box-shadow: inset 0 0 0 0.32rem #e7efd9;
}

.home-bib-visual,
.home-about-visual {
    min-height: 24rem;
    border-radius: 1.3rem;
    background:
        radial-gradient(circle at 24% 18%, rgba(215, 166, 66, 0.82) 0 12%, transparent 13%),
        radial-gradient(circle at 42% 28%, rgba(142, 35, 40, 0.88) 0 12%, transparent 13%),
        linear-gradient(135deg, #f5e7c3, #96a55e 54%, #263126);
    box-shadow: var(--stockinger-shadow);
}

.home-products {
    background: #fffdf8;
}

.home-products-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.home-product-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border: 1px solid var(--stockinger-border);
    border-radius: 1rem;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 12px 26px rgba(31, 63, 36, 0.09);
}

.home-product-thumb {
    min-height: 12rem;
    background:
        radial-gradient(circle at 34% 30%, rgba(215, 166, 66, 0.85) 0 13%, transparent 14%),
        radial-gradient(circle at 58% 42%, rgba(142, 35, 40, 0.85) 0 13%, transparent 14%),
        linear-gradient(135deg, #edf2d7, #78923f);
}

.home-product-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    padding: 1.15rem;
}

.home-product-body p {
    flex: 1;
    margin-bottom: 1rem;
    font-size: 0.94rem;
}

.home-price-note {
    display: block;
    margin-bottom: 0.85rem;
    color: var(--stockinger-red);
    font-weight: 800;
}

.home-contract-filling {
    background: linear-gradient(135deg, var(--stockinger-green) 0%, #314f2b 100%);
}

.home-contract-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1.5rem;
    align-items: center;
    padding: clamp(1.5rem, 4vw, 2.5rem);
    background: rgba(255, 253, 248, 0.96);
}

.home-contract-panel h2 {
    max-width: 840px;
}

.home-contract-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.home-about {
    background: var(--stockinger-cream);
}

.home-about-panel {
    padding: clamp(1.5rem, 4vw, 2.4rem);
}

.home-about-visual {
    background:
        linear-gradient(90deg, rgba(31, 63, 36, 0.18), rgba(31, 63, 36, 0.02)),
        repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.28) 1px, transparent 1px, transparent 26px),
        linear-gradient(135deg, #e5d1a6, #8a9c4e 52%, #263126);
}

.home-newsletter {
    background: #fffdf8;
}

.home-newsletter-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
    gap: 1.5rem;
    align-items: center;
    padding: clamp(1.4rem, 4vw, 2.2rem);
}

.home-newsletter-form {
    display: flex;
    gap: 0.65rem;
}

.home-newsletter-form input {
    flex: 1;
    min-width: 0;
    height: 3rem;
    border: 1px solid var(--stockinger-border);
    border-radius: 999px;
    padding: 0 1rem;
    background: #fff;
}

.home-footer-links {
    padding: 3rem 0;
    color: #e8eddc;
    background: var(--stockinger-green);
}

.home-footer-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.5rem;
}

.home-footer-links h3 {
    color: #fff;
    font-size: 1rem;
}

.home-footer-links ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.home-footer-links li + li {
    margin-top: 0.45rem;
}

.home-footer-links a {
    color: rgba(255, 255, 255, 0.8);
}

.home-footer-links a:hover,
.home-footer-links a:focus {
    color: #fff;
}

@media (max-width: 1199.98px) {
    .home-category-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .home-products-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .home-hero-inner,
    .home-feature-split,
    .home-contract-panel,
    .home-newsletter-panel {
        grid-template-columns: 1fr;
    }

    .stockinger-home h1 {
        max-width: 100%;
    }

    .home-trust-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .home-trust-item:nth-child(2n) {
        border-right: 0;
    }

    .home-contract-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 767.98px) {
    .stockinger-home .home-section {
        padding: 3rem 0;
    }

    .home-hero {
        padding-top: 2rem;
    }

    .home-hero-actions,
    .home-newsletter-form {
        flex-direction: column;
    }

    .stockinger-home .home-btn {
        width: 100%;
    }

    .home-hero-visual {
        min-height: 22rem;
        border-radius: 1.2rem;
    }

    .home-hero-badge {
        right: 1rem;
        top: 1rem;
        width: 6.7rem;
        height: 6.7rem;
        font-size: 0.85rem;
    }

    .home-trust {
        margin-top: 0;
    }

    .home-trust-grid,
    .home-category-grid,
    .home-products-grid,
    .home-footer-grid {
        grid-template-columns: 1fr;
    }

    .home-trust-item {
        border-right: 0;
        border-bottom: 1px solid var(--stockinger-border);
    }

    .home-trust-item:last-child {
        border-bottom: 0;
    }

    .home-category-card {
        min-height: 15rem;
    }
}

/*
 * OPC-Portlets-Modus
 * Diese Klassen sind fuer echte JTL-OPC-Portlets gedacht. Sie koennen in den
 * erweiterten Einstellungen der jeweiligen Container/Portlets als CSS-Klasse
 * eingetragen werden.
 */

.os-opc-page {
    background: linear-gradient(180deg, #fffaf0 0%, #f8efd9 100%);
    color: var(--stockinger-ink);
}

.os-opc-page > .opc-Container,
.os-opc-page > .opc-Container > .opc-container,
.os-opc-page .container {
    max-width: none;
}

.os-opc-page .opc-Container,
.os-opc-page .opc-GridLayout,
.os-opc-page .opc-Portlet {
    box-sizing: border-box;
}

.os-section {
    padding-top: 4rem;
    padding-bottom: 4rem;
}

.os-section > .opc-container,
.os-section > .container,
.os-hero > .opc-container,
.os-hero > .container,
.os-trust-band > .opc-container,
.os-trust-band > .container {
    max-width: 1240px;
    margin-right: auto;
    margin-left: auto;
    padding-right: 1rem;
    padding-left: 1rem;
}

.os-section-cream {
    background: linear-gradient(180deg, var(--stockinger-cream) 0%, var(--stockinger-cream-2) 100%);
}

.os-section-green {
    background: linear-gradient(135deg, var(--stockinger-green) 0%, #314f2b 100%);
}

.os-section-header {
    max-width: 760px;
    margin-right: auto;
    margin-bottom: 2rem;
    margin-left: auto;
    text-align: center;
}

.os-section-header h2,
.os-hero-copy h1,
.os-card-title h3 {
    color: var(--stockinger-green);
    line-height: 1.08;
}

.os-section-header h2 {
    font-size: clamp(2rem, 4vw, 3.15rem);
}

.os-section-header p,
.os-hero-copy p,
.os-card-text p {
    color: var(--stockinger-muted);
    font-size: 1rem;
    line-height: 1.7;
}

.os-eyebrow {
    color: var(--stockinger-green-2);
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

.os-hero {
    position: relative;
    padding-top: clamp(2rem, 5vw, 4.5rem);
    padding-bottom: clamp(3rem, 5vw, 5rem);
    min-height: 620px;
    background:
        radial-gradient(circle at 88% 28%, rgba(216, 77, 66, 0.14), transparent 18rem),
        radial-gradient(circle at 72% 18%, rgba(215, 166, 66, 0.2), transparent 24rem),
        linear-gradient(105deg, #fff9ec 0%, #f8edd6 44%, #edf2dc 100%);
    overflow: hidden;
}

.os-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(255, 253, 248, 0.97) 0%, rgba(255, 253, 248, 0.74) 44%, rgba(255, 253, 248, 0.18) 100%),
        radial-gradient(circle at 76% 44%, rgba(142, 35, 40, 0.18) 0 5.5rem, transparent 5.7rem),
        radial-gradient(circle at 86% 40%, rgba(240, 182, 68, 0.22) 0 4.8rem, transparent 5rem),
        radial-gradient(circle at 68% 52%, rgba(196, 63, 53, 0.2) 0 4.2rem, transparent 4.4rem),
        repeating-linear-gradient(110deg, rgba(31, 63, 36, 0.035), rgba(31, 63, 36, 0.035) 1px, transparent 1px, transparent 18px);
    pointer-events: none;
}

.os-hero::after {
    content: "";
    position: absolute;
    right: -4rem;
    bottom: -4rem;
    width: min(34vw, 24rem);
    height: min(34vw, 24rem);
    border-radius: 50%;
    background:
        radial-gradient(circle at 40% 35%, #f6d45d 0 15%, transparent 16%),
        radial-gradient(circle at 58% 46%, #c7473d 0 18%, transparent 19%),
        radial-gradient(circle at 34% 58%, #8e2328 0 14%, transparent 15%),
        radial-gradient(circle at 50% 50%, rgba(215, 166, 66, 0.28), transparent 70%);
    pointer-events: none;
}

.os-hero > * {
    position: relative;
}

.os-hero-copy h1 {
    margin: 0 0 1rem;
    font-size: clamp(2.35rem, 6vw, 4.95rem);
    max-width: 11ch;
    font-weight: 700;
}

.os-hero-copy p {
    max-width: 640px;
    font-size: clamp(1rem, 2vw, 1.18rem);
}

.os-hero-image,
.os-image-card {
    min-height: 28rem;
    border-radius: 0 0 0 4rem;
    background:
        linear-gradient(rgba(31, 63, 36, 0.12), rgba(31, 63, 36, 0.1)),
        var(--os-image-url, none),
        radial-gradient(circle at 24% 24%, #d84d42 0 9%, transparent 10%),
        radial-gradient(circle at 36% 28%, #f1c64a 0 11%, transparent 12%),
        radial-gradient(circle at 46% 18%, #b52c32 0 10%, transparent 11%),
        radial-gradient(circle at 68% 31%, #e7b24c 0 12%, transparent 13%),
        linear-gradient(135deg, #f8e8bc, #dae2af 45%, #49682a);
    background-position: center;
    background-size: cover;
    box-shadow: var(--stockinger-shadow);
    overflow: hidden;
}

.os-hero-image {
    position: relative;
    margin-top: -1.5rem;
    transform: translateX(1.5rem);
    --os-image-url: url("../../opc-assets/stockinger-hero-juice-orchard.png");
}

.os-bib-image {
    --os-image-url: url("../../opc-assets/stockinger-bag-in-box.png");
}

.os-about-image {
    --os-image-url: url("../../opc-assets/stockinger-farm-press-house.png");
}

.os-hero-image::before {
    content: "Direkt vom Erzeuger";
    position: absolute;
    right: 2rem;
    bottom: 2rem;
    display: grid;
    place-items: center;
    width: 8.5rem;
    height: 8.5rem;
    padding: 1rem;
    border-radius: 50%;
    color: var(--stockinger-green);
    background: #fffdf8;
    border: 8px solid rgba(69, 107, 33, 0.22);
    font-weight: 800;
    line-height: 1.15;
    text-align: center;
    box-shadow: 0 12px 26px rgba(31, 63, 36, 0.18);
}

.os-hero-image img,
.os-image-card img,
.os-category-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.os-button-primary a,
.os-button-secondary a,
.os-button-primary button,
.os-button-secondary button,
.os-native-button a,
.os-native-button button,
.os-native-button .btn,
.os-opc-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3rem;
    padding: 0.85rem 1.25rem;
    border: 1px solid transparent;
    border-radius: 999px;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none !important;
    white-space: normal;
}

.os-button-primary,
.os-button-secondary,
.os-native-button {
    display: inline-flex;
}

.os-button-primary p,
.os-button-secondary p {
    margin: 0;
}

.os-button-primary a,
.os-button-primary button,
.os-button-primary .btn,
.os-opc-btn-primary {
    color: #fff !important;
    background: var(--stockinger-green) !important;
    border-color: var(--stockinger-green) !important;
    box-shadow: 0 12px 24px rgba(35, 69, 31, 0.24);
}

.os-button-secondary a,
.os-button-secondary button,
.os-button-secondary .btn,
.os-opc-btn-secondary {
    color: var(--stockinger-green) !important;
    background: #eef4e4 !important;
    border-color: rgba(63, 107, 36, 0.34) !important;
}

.os-button-primary a:hover,
.os-button-primary button:hover,
.os-button-primary .btn:hover,
.os-opc-btn-primary:hover {
    color: #fff !important;
    background: #172f15 !important;
    border-color: #172f15 !important;
    transform: translateY(-1px);
}

.os-button-secondary a:hover,
.os-button-secondary button:hover,
.os-button-secondary .btn:hover,
.os-opc-btn-secondary:hover {
    color: var(--stockinger-green) !important;
    background: #f7fbef !important;
    border-color: rgba(35, 69, 31, 0.44) !important;
    transform: translateY(-1px);
}

.os-trust-band {
    position: relative;
    z-index: 3;
    max-width: 1240px;
    margin: -2.35rem auto 0;
    border: 1px solid var(--stockinger-border);
    border-radius: 0;
    background: rgba(255, 253, 248, 0.96);
    box-shadow: 0 14px 34px rgba(31, 63, 36, 0.12);
    overflow: hidden;
}

.os-trust-item {
    min-height: 7rem;
    padding: 1.25rem;
    border-right: 1px solid var(--stockinger-border);
}

.os-trust-item h3,
.os-trust-item strong {
    color: var(--stockinger-green);
    font-size: 1rem;
}

.os-trust-item p {
    margin-bottom: 0;
    color: var(--stockinger-muted);
    font-size: 0.88rem;
}

.os-category-card,
.os-product-focus-card {
    min-height: 100%;
    border: 1px solid var(--stockinger-border);
    border-radius: 1rem;
    background: #fff;
    box-shadow: 0 12px 26px rgba(31, 63, 36, 0.09);
    overflow: hidden;
}

.os-category-card {
    position: relative;
    min-height: 15.5rem;
    background: var(--stockinger-green);
}

.os-category-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--os-card-bg, linear-gradient(135deg, #7a9a35, #263126));
    transform: scale(1.02);
}

.os-category-card .opc-Image,
.os-category-card .opc-Image img,
.os-category-card img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.os-category-card > .card-body,
.os-category-card .panel-body,
.os-category-card .opc-portlet,
.os-category-card .opc-Portlet {
    position: relative;
}

.os-category-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(31, 63, 36, 0.08), rgba(31, 63, 36, 0.86));
    pointer-events: none;
}

.os-category-card .opc-Text,
.os-category-card .opc-RichText,
.os-category-card .opc-Button,
.os-category-card .opc-Heading {
    position: relative;
    z-index: 1;
}

.os-category-card .opc-Heading,
.os-category-card .opc-Text {
    padding-right: 1rem;
    padding-left: 1rem;
}

.os-category-card .opc-Heading {
    padding-top: 8.5rem;
}

.os-category-card h3,
.os-category-card p,
.os-category-card a {
    color: #fff !important;
}

.os-cat-apple { --os-card-bg: url("../../opc-assets/stockinger-cat-apple.png"), radial-gradient(circle at 32% 20%, #f5c24a 0 12%, transparent 13%), linear-gradient(135deg, #6b8e2b, #263126); }
.os-cat-aronia { --os-card-bg: url("../../opc-assets/stockinger-cat-aronia.png"), radial-gradient(circle at 40% 25%, #231533 0 16%, transparent 17%), linear-gradient(135deg, #6a254f, #263126); }
.os-cat-grape { --os-card-bg: url("../../opc-assets/stockinger-cat-grape.png"), radial-gradient(circle at 34% 26%, #7c2555 0 13%, transparent 14%), linear-gradient(135deg, #4e6b2f, #263126); }
.os-cat-cherry { --os-card-bg: url("../../opc-assets/stockinger-cat-cherry.png"), radial-gradient(circle at 36% 24%, #a3182b 0 15%, transparent 16%), linear-gradient(135deg, #7b1f2d, #263126); }
.os-cat-beet { --os-card-bg: url("../../opc-assets/stockinger-cat-beet.png"), radial-gradient(circle at 48% 30%, #76243f 0 20%, transparent 21%), linear-gradient(135deg, #8e2328, #263126); }
.os-cat-pomegranate { --os-card-bg: url("../../opc-assets/stockinger-cat-pomegranate.png"), radial-gradient(circle at 44% 27%, #b52c32 0 17%, transparent 18%), linear-gradient(135deg, #a02d33, #263126); }

.os-bib-panel,
.os-about-panel,
.os-newsletter-panel {
    padding: clamp(1.5rem, 4vw, 2.4rem);
    border: 1px solid var(--stockinger-border);
    border-radius: 1.2rem;
    background: rgba(255, 253, 248, 0.9);
    box-shadow: 0 14px 34px rgba(31, 63, 36, 0.1);
}

.os-contract-panel {
    padding: clamp(1.5rem, 4vw, 2.5rem);
    border: 1px solid var(--stockinger-border);
    border-radius: 1.2rem;
    background: rgba(255, 253, 248, 0.96);
    box-shadow: 0 14px 34px rgba(31, 63, 36, 0.1);
}

.os-product-stream {
    --jtl-card-radius: 1rem;
    margin-top: 2rem;
}

.os-product-month {
    padding: 1.25rem;
    border: 1px solid rgba(63, 107, 36, 0.18);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, #fffdf7 0%, #f1ead4 100%);
    box-shadow: 0 14px 34px rgba(35, 69, 31, 0.1);
}

.os-aronia-stream,
.os-apple-stream {
    padding-top: 0.5rem;
}

.os-product-stream .product-wrapper,
.os-product-stream .productbox,
.os-product-stream .productbox-inner {
    border-radius: 1rem;
}

@media (max-width: 767.98px) {
    .os-section {
        padding-top: 3rem;
        padding-bottom: 3rem;
    }

    .os-trust-band {
        margin-top: 0;
    }

    .os-hero-image,
    .os-image-card {
        min-height: 20rem;
        border-radius: 1.2rem;
        margin-top: 1rem;
        transform: none;
    }

    .os-hero {
        min-height: auto;
    }

    .os-hero-copy h1 {
        max-width: 100%;
    }

    .os-trust-item {
        border-right: 0;
        border-bottom: 1px solid var(--stockinger-border);
    }

    .os-button-primary a,
    .os-button-secondary a,
    .os-button-primary button,
    .os-button-secondary button,
    .os-opc-btn {
        width: 100%;
    }

    .os-button-primary,
    .os-button-secondary {
        display: flex;
        width: 100%;
    }
}

/*
 * Build 20260629.3 final override: bewusst am Dateiende.
 */
html body .os-opc-page,
html body .os-opc-page .opc-Container,
html body .os-opc-page .opc-container,
html body .os-opc-page .opc-GridLayout {
    background-color: transparent !important;
}

html body .os-opc-page {
    background: linear-gradient(180deg, #fffaf0 0%, #f8efd9 100%) !important;
}

html body .os-opc-page .os-hero,
html body .os-hero {
    background:
        radial-gradient(circle at 88% 28%, rgba(216, 77, 66, 0.14), transparent 18rem),
        radial-gradient(circle at 72% 18%, rgba(215, 166, 66, 0.2), transparent 24rem),
        linear-gradient(105deg, #fff9ec 0%, #f8edd6 44%, #edf2dc 100%) !important;
}

html body .os-opc-page .btn-primary,
html body .os-opc-page a.btn-primary,
html body .os-opc-page button.btn-primary,
html body .os-opc-page .opc-Button .btn-primary,
html body .os-opc-page .os-button-primary .btn,
html body .os-opc-page .os-button-primary a,
html body .os-opc-page .os-button-primary button {
    color: #ffffff !important;
    background-color: #23451f !important;
    background-image: none !important;
    border-color: #23451f !important;
    box-shadow: 0 12px 24px rgba(35, 69, 31, 0.24) !important;
}

html body .os-opc-page .btn-primary:hover,
html body .os-opc-page a.btn-primary:hover,
html body .os-opc-page button.btn-primary:hover,
html body .os-opc-page .opc-Button .btn-primary:hover,
html body .os-opc-page .os-button-primary .btn:hover,
html body .os-opc-page .os-button-primary a:hover,
html body .os-opc-page .os-button-primary button:hover {
    color: #ffffff !important;
    background-color: #172f15 !important;
    border-color: #172f15 !important;
}

html body .os-opc-page .btn-secondary,
html body .os-opc-page a.btn-secondary,
html body .os-opc-page button.btn-secondary,
html body .os-opc-page .opc-Button .btn-secondary,
html body .os-opc-page .os-button-secondary .btn,
html body .os-opc-page .os-button-secondary a,
html body .os-opc-page .os-button-secondary button {
    color: #23451f !important;
    background-color: #eef4e4 !important;
    background-image: none !important;
    border-color: #6f8f37 !important;
    box-shadow: none !important;
}

/*
 * Build 20260629.4 final: weisser Hintergrund, damit Produktbilder neutral wirken.
 */
html body .stockinger-home,
html body .os-opc-page,
html body .os-opc-page .opc-Container,
html body .os-opc-page .opc-container,
html body .os-opc-page .opc-GridLayout,
html body .os-opc-page .opc-Portlet,
html body .os-section,
html body .os-section-cream,
html body .os-hero {
    background: #ffffff !important;
    background-color: #ffffff !important;
}

html body .os-trust-band,
html body .os-bib-panel,
html body .os-about-panel,
html body .os-newsletter-panel,
html body .os-contract-panel {
    background: #ffffff !important;
    background-color: #ffffff !important;
}

/*
 * Build 20260629.5 final layout pass:
 * bessere Proportionen, Facts-Kacheln, Kartenraender und Abschnittsabstaende.
 */
html body .os-opc-page {
    --os-page-max: 1420px;
    --os-section-y: clamp(2.75rem, 4.5vw, 4.75rem);
}

html body .os-opc-page .os-section,
html body .os-opc-page .os-section-cream,
html body .os-opc-page .os-section-green {
    padding-top: var(--os-section-y) !important;
    padding-bottom: var(--os-section-y) !important;
}

html body .os-opc-page .os-section > .opc-container,
html body .os-opc-page .os-section > .container,
html body .os-opc-page .os-hero > .opc-container,
html body .os-opc-page .os-hero > .container,
html body .os-opc-page .os-trust-band > .opc-container,
html body .os-opc-page .os-trust-band > .container {
    max-width: var(--os-page-max) !important;
    padding-right: clamp(1rem, 2vw, 1.5rem) !important;
    padding-left: clamp(1rem, 2vw, 1.5rem) !important;
}

html body .os-opc-page .os-section-header {
    max-width: 780px !important;
    margin-bottom: clamp(1.5rem, 2.5vw, 2.25rem) !important;
}

html body .os-opc-page .os-section-header h2 {
    margin-bottom: 0.75rem !important;
    font-size: clamp(1.85rem, 2.4vw, 2.6rem) !important;
    line-height: 1.16 !important;
}

html body .os-opc-page .os-section-header p {
    margin-bottom: 0 !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
}

html body .os-opc-page .os-hero {
    min-height: 0 !important;
    padding-top: clamp(2rem, 3vw, 3.25rem) !important;
    padding-bottom: clamp(2rem, 3.5vw, 3.5rem) !important;
}

html body .os-opc-page .os-hero-copy h1 {
    max-width: 13ch !important;
    margin-bottom: 1rem !important;
    font-size: clamp(2.25rem, 3.6vw, 4.1rem) !important;
    line-height: 1.08 !important;
}

html body .os-opc-page .os-hero-copy p {
    max-width: 620px !important;
    margin-bottom: 1.35rem !important;
    font-size: clamp(1rem, 1.1vw, 1.15rem) !important;
}

html body .os-opc-page .os-hero-image,
html body .os-opc-page .os-image-card {
    min-height: 0 !important;
    height: auto !important;
    max-height: 520px !important;
    overflow: hidden !important;
}

html body .os-opc-page .os-hero-image img,
html body .os-opc-page .os-image-card img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-height: 520px !important;
    object-fit: cover !important;
}

html body .os-opc-page .os-trust-band {
    max-width: var(--os-page-max) !important;
    margin: clamp(1.5rem, 2.5vw, 2.5rem) auto clamp(2rem, 3vw, 3rem) !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
}

html body .os-opc-page .os-trust-band .row,
html body .os-opc-page .os-trust-band .opc-row {
    row-gap: 1rem !important;
}

html body .os-opc-page .os-trust-item {
    position: relative !important;
    min-height: 8.25rem !important;
    height: 100% !important;
    padding: 1.35rem 1.35rem 1.25rem 5rem !important;
    border: 1px solid rgba(35, 69, 31, 0.13) !important;
    border-radius: 0.75rem !important;
    background: linear-gradient(180deg, #ffffff 0%, #fbfdf7 100%) !important;
    box-shadow: 0 12px 28px rgba(35, 69, 31, 0.08) !important;
}

html body .os-opc-page .os-trust-item::before {
    content: "" !important;
    position: absolute !important;
    top: 1.35rem !important;
    left: 1.35rem !important;
    width: 2.7rem !important;
    height: 2.7rem !important;
    border-radius: 50% !important;
    background:
        radial-gradient(circle at 50% 50%, #ffffff 0 34%, transparent 36%),
        linear-gradient(135deg, #6f8f37 0%, #23451f 100%) !important;
    box-shadow: inset 0 0 0 0.35rem rgba(255, 255, 255, 0.45) !important;
}

html body .os-opc-page .os-trust-item h3 {
    margin-bottom: 0.35rem !important;
    color: #23451f !important;
    font-size: 1.08rem !important;
    line-height: 1.25 !important;
}

html body .os-opc-page .os-trust-item p {
    margin-bottom: 0 !important;
    color: #596257 !important;
    font-size: 0.95rem !important;
    line-height: 1.55 !important;
}

html body .os-opc-page .os-category-card {
    min-height: 0 !important;
    padding: 1rem !important;
    border: 1px solid rgba(35, 69, 31, 0.1) !important;
    border-radius: 0.75rem !important;
    background: #ffffff !important;
    box-shadow: 0 10px 24px rgba(35, 69, 31, 0.06) !important;
    overflow: hidden !important;
}

html body .os-opc-page .os-category-card::before,
html body .os-opc-page .os-category-card::after {
    display: none !important;
}

html body .os-opc-page .os-category-card .opc-Image,
html body .os-opc-page .os-category-card img {
    width: 100% !important;
    aspect-ratio: 1.1 / 1 !important;
    height: auto !important;
    max-height: 260px !important;
    border-radius: 0.45rem !important;
    object-fit: cover !important;
}

html body .os-opc-page .os-category-card .opc-Heading,
html body .os-opc-page .os-category-card .opc-Text {
    padding-right: 0 !important;
    padding-left: 0 !important;
}

html body .os-opc-page .os-category-card .opc-Heading {
    padding-top: 0.85rem !important;
}

html body .os-opc-page .os-category-card h3 {
    margin-bottom: 0.45rem !important;
    color: #343a34 !important;
    font-size: 1.12rem !important;
    line-height: 1.25 !important;
}

html body .os-opc-page .os-category-card p {
    margin-bottom: 1rem !important;
    color: #596257 !important;
    font-size: 0.94rem !important;
    line-height: 1.5 !important;
}

html body .os-opc-page .os-category-card a:not(.btn) {
    color: #343a34 !important;
}

html body .os-opc-page .os-bib-panel {
    min-height: 0 !important;
    padding: clamp(1.75rem, 3vw, 2.5rem) !important;
    border-radius: 0.75rem !important;
}

html body .os-opc-page .os-bib-image,
html body .os-opc-page .os-bib-image img {
    max-height: 460px !important;
    object-fit: cover !important;
}

html body .os-opc-page .os-product-stream {
    max-width: var(--os-page-max) !important;
    margin: 1.25rem auto 0 !important;
}

html body .os-opc-page .os-product-month {
    max-width: 920px !important;
    margin-right: auto !important;
    margin-left: auto !important;
    padding: 1.5rem !important;
    border-radius: 0.85rem !important;
}

html body .os-opc-page .os-product-stream .productbox,
html body .os-opc-page .os-product-stream .product-wrapper {
    max-width: 280px !important;
    margin-right: auto !important;
    margin-left: auto !important;
}

html body .os-opc-page .os-product-stream img {
    max-height: 300px !important;
    width: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
}

@media (max-width: 991.98px) {
    html body .os-opc-page {
        --os-section-y: 2.5rem;
    }

    html body .os-opc-page .os-trust-item {
        padding-left: 4.6rem !important;
    }
}

@media (max-width: 767.98px) {
    html body .os-opc-page .os-trust-band {
        margin-top: 1.25rem !important;
        margin-bottom: 1.75rem !important;
    }

    html body .os-opc-page .os-category-card .opc-Image,
    html body .os-opc-page .os-category-card img {
        max-height: 220px !important;
    }
}
