/* ==========================================================================
   Papaya Loquat — campaign.css
   Static rules only. Dynamic rules (image paths, $page_zoom breakpoints)
   live in the inline <style> block in index.php.
   ========================================================================== */

:root {
    /* Brand palette */
    --c-gold:         #B2965F;
    --c-gold-mid:     #bb9944;
    --c-gold-light:   rgba(175, 152, 102, 0.18);
    --c-text:         #102143;
    --c-text-2:        #2A1D14;
    --c-white:        #ffffff;
    --c-teal:         #2a7a6a;
    --c-teal-light:   rgba(42, 122, 106, 0.12);
    --c-yellow:       #f5c842;
    --c-yellow-dark:  #e8a800;
    --c-orange:       #e07820;
    --c-dark:         #1a1a1a;
    --c-cream:        #f5f0e8;
    /* XD-matched design tokens */
    --c-headline:     #8B734B;   /* section titles */
    --c-body:         #707070;   /* body paragraphs */
    --c-accent:       #00A77F;   /* teal — note names, accents */
    --c-accent-2:     #C9A856;   /* light gold — text on green S4 */
    --c-teal-dark:    #047259;   /* gradient button end */
    --c-green-box:    #0E4F51;   /* S4 slide gradient top */
    --c-green-mint:   #9DD4B5;   /* S4 slide gradient bottom + dots */
    --c-arrow:        #463A32;   /* prev/next arrow color */
    --transition:     0.22s ease-in-out;
    /* Swiper tokens */
    --swiper-navigation-color: #463A32;
    --swiper-pagination-color: #9DD4B5;
    --swiper-pagination-bullet-inactive-color: rgba(157, 212, 181, 0.7);
    --swiper-pagination-bullet-width:  10px;
    --swiper-pagination-bullet-height: 10px;
	--swiper-pagination-bullet-inactive-opacity: 0.85;
	    --swiper-navigation-size: 4em;
}

.campaignLP-container {
    text-transform: none;
    font-weight: normal;
    color: var(--c-text);
    position: relative;
    font-size: 1em;
    font-family: "Josefin Sans", sans-serif;
	text-align: center;
}
body[dir="rtl"] .campaignLP-container { font-family: inherit; }
.campaignLP-container .innerContainer { margin: 0 auto; }
.campaignLP-container img { max-width: 100%; }
.campaignLP-container .breadcrumbs { display: none; }

.campaignLP-container p{
text-align: inherit;
}
.campaignLP-section {
    font-size: 1.25em;
    position: relative;
    text-align: center;
    padding: 2em 0;
    overflow: hidden;
    box-sizing: border-box;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.campaignLP-section > * { box-sizing: border-box; }
.campaignLP-section .text-container { padding: 0; }

.campaignLP-section .pretitle {
    display: inline-block;
    position: relative;
    color: var(--c-gold);
    font-size: 0.8em;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin-bottom: 0.6em;
}
.campaignLP-section .pretitle::before,
.campaignLP-section .pretitle::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 0.6em; height: 1px;
    background: var(--c-gold);
    transform: translateY(-50%);
}
.campaignLP-section .pretitle::before { right: calc(100% + 0.5em); }
.campaignLP-section .pretitle::after  { left:  calc(100% + 0.5em); }
body[dir="rtl"] .campaignLP-section .pretitle::before { right: auto; left:  calc(100% + 0.5em); }
body[dir="rtl"] .campaignLP-section .pretitle::after  { left:  auto; right: calc(100% + 0.5em); }

.campaignLP-section .title {
    color: var(--c-headline);
    font-size: 2em;
    line-height: 1.2;
    margin: 0.3em 0;
    font-weight: 500;
    font-family: 'Petrona', serif;
    letter-spacing: -0.01em;
    text-align: center;
}
body[dir="rtl"] .campaignLP-section .title { font-family: inherit; }

.campaignLP-section .paragraph {
    color: var(--c-body);
    font-size: 1em;
    margin: 0 0 1em;
    line-height: 1.375;
    text-align: center;
}

a.campaign-button {
    position: relative;
    display: inline-block;
    max-width: 90%;
    color: var(--c-teal);
    font-size: 1em;
	line-height: 1; 
    font-weight: 300;
    padding: 0.5em 2em;
    margin-top: 1.25em;
    text-decoration: none;
    border: 0px none transparent;
    border-radius: 1em;
    background: var(--c-white);
    letter-spacing: 0;
    text-transform: none;
    transition: color var(--transition), background var(--transition), border-color var(--transition);
    cursor: pointer;
	font-family: 'Petrona', serif;
	font-style: italic;
}
body[dir="rtl"] .campaign-button {font-family: inherit; font-style: normal;}
a.campaign-button:hover,
a.campaign-button:focus-visible {
    color: var(--c-white);
    background: var(--c-teal);
    text-decoration: none;
}
a.campaign-button--fill {
    color: var(--c-white);
    background: var(--c-orange);
    border-color: var(--c-orange);
}
a.campaign-button--fill:hover,
a.campaign-button--fill:focus-visible {
    background: #c86a1a;
    border-color: #c86a1a;
    color: var(--c-white);
    opacity: 1;
}
a.campaign-button.accent-btn {
    background: linear-gradient(to bottom, var(--c-accent), var(--c-teal-dark));
    color: var(--c-white);
	text-decoration: none;
}
a.campaign-button.accent-btn:hover,
a.campaign-button.accent-btn:focus-visible {
    background: linear-gradient(to bottom, #00c090, var(--c-accent));
    color: var(--c-white);
	text-decoration: none;
}


.swiper-button-prev,.swiper-button-next {appearance: none;border: 0px none transparent;	background: transparent; width: var(--swiper-navigation-size);}
.swiper-button-prev::after,
.swiper-button-next::after { display: none; }
.swiper-button-prev::before,
.swiper-button-next::before {
    content: '';
    display: block;
    width: 2em; height: 2em;
    border-top: 2px solid var(--c-gold);
    border-left: 2px solid var(--c-gold);
}
.swiper-button-prev::before { transform: rotate(-45deg) translate(0.1em, 0.1em); }
.swiper-button-next::before { transform: rotate(135deg) translate(-0.1em, -0.1em); }
body[dir="rtl"] .swiper-button-prev::before { transform: rotate(135deg) translate(-0.1em, -0.1em); }
body[dir="rtl"] .swiper-button-next::before { transform: rotate(-45deg) translate(0.1em, 0.1em); }
.swiper-pagination-bullet:hover, .swiper-pagination-bullet:focus-visible{background: var(--c-gold);}


@keyframes campaignLP_swingLeaf {
    0%   { transform: rotate(0); }
    25%   { transform: rotate(-2deg); }
    50%   { transform: rotate(0); }
    75%   { transform: rotate(2deg); }
    100%   { transform: rotate(0); }
}


.s1-hero {
    background-color: #FFD238;
    display: flex;
	align-items: center;
    justify-content: center;
    padding: 8% 5%;
    position: relative;
    overflow: hidden;
}
.s1-hero__inner {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    width: 100%;
    max-width: 70em;
    margin: 0 auto;
    padding: 5% 5% 20%;
    box-sizing: border-box;
}
.s1-hero__text {
    max-width: 100%;
    width: 30em;
    text-align: center;
    color: var(--c-text-2);
}
.s1-hero .pretitle {color: var(--c-text-2); font-size: 1em; line-height: 1; letter-spacing: 0;}
.s1-hero .pretitle::before,
.s1-hero .pretitle::after { display: none;}

.s1-hero__title {
    font-family: 'Petrona', serif;
    font-style: italic;
    font-size: clamp(2em, 5vw, 4em);
    font-weight: 900;
    color: var(--c-gold);
    line-height: 1;
    margin: 0;
    text-align: center;
}
body[dir="rtl"] .s1-hero__title { font-family: inherit; font-style: normal; }
.s1-hero__title img {width: 20em; max-width: 100%; margin: 0 auto; height: auto;}

.s1-hero__subtitle {
    font-size: 1.25em;
    color: var(--c-text-2);
    margin: 0.5em 0 0.25em 0;
    line-height: 1.125;
    text-align: center;
	text-transform: uppercase;
	letter-spacing: 0;
}



.s1-hero__game-badge {
    position: absolute;
    bottom: 1.5em;
    right: 1.5em;
    z-index: 3;
    background: var(--c-yellow);
    border-radius: 1em;
    padding: 0.75em 1.25em;
    max-width: 16em;
    text-align: center;
    box-shadow: 0 4px 16px rgba(0,0,0,0.18);
}
body[dir="rtl"] .s1-hero__game-badge { right: auto; left: 1.5em; }
.s1-hero__game-badge-text {
    font-size: 0.72em;
    color: var(--c-text);
    font-weight: 600;
    margin: 0 0 0.4em;
    line-height: 1.4;
}
.s1-hero__game-badge-cta {
    font-size: 0.72em;
    color: var(--c-teal);
    font-weight: 700;
    text-decoration: underline;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}


.s1-hero__deco {
    position: absolute;
    pointer-events: none;
    z-index: 1;
}
.s1-hero__deco--parrot-flying {
    width: clamp(6em, 10vw, 12em);
    height: auto;
    top: 8%;
    left: 3%;
}
.s1-hero__deco--parrot {
    width: clamp(5em, 8vw, 10em);
    height: auto;
    bottom: 12%;
    right: 5%;
}
body[dir="rtl"] .s1-hero__deco--parrot-flying { left: auto; right: 3%; }
body[dir="rtl"] .s1-hero__deco--parrot        { right: auto; left: 5%; }


.s2-story {
    background: linear-gradient(180deg,rgba(255, 230, 124, 1) 0%, rgba(255, 255, 255, 1) 50%, rgba(255, 255, 255, 1) 100%);
    padding: 4em 0;
    position: relative;
    overflow: visible;
}
/* Separator bottom of S2 */
.s2-story::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 29px;
    background-repeat: repeat-x;
    background-size: auto 100%;
    pointer-events: none;
    z-index: auto;
}
.s2-story .title    { color: var(--c-headline); }
.s2-story .paragraph { color: var(--c-body); }

.s2-story__leaf {
    position: absolute;
    
    z-index: 1;
    pointer-events: none;
    width: clamp(10em, 30vw, 30em);
    height: auto;
	display: none;
}
.s2-story__leaf--l {top: 0; left: 0;  transform: rotate(8deg); transform-origin: 0% 0%; animation: campaignLP_swingLeaf 2s linear 0s infinite;  }
.s2-story__leaf--r {top: 2vw; right: 0;  transform: rotate(8deg); transform-origin: 100% 20%; animation: campaignLP_swingLeaf 2s linear 0s infinite;  }


.s2-story__layout {
    display: flex;
    align-items: stretch;
    position: relative;
    z-index: 2;
}

/* Side image columns */
.s2-story__side {
    flex: 0 0 33%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2em 0;
    position: relative;
    overflow: visible;
}
.s2-story__side-img {
    width: 70%;
    height: auto;
    border-radius: 4vw;
    display: block;
	clip-path: inset(2px 2px 2px 2px); 
}
.s2-story__side-img--a {
    align-self: flex-start;
    position: relative;
    z-index: 1;
}
.s2-story__side-img--b {
    width: 100%;
    align-self: flex-end;
    margin-top: -4vw;
    position: relative;
    z-index: 2;
}
.s2-story__side--r .s2-story__side-img--a {width: 70%; align-self: flex-end;     margin-right: 0; }
.s2-story__side--r .s2-story__side-img--b {width: 50%;  align-self: flex-start; margin-left: 0;margin-top: -21vw; }

/* Center column */
.s2-story__main {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 2em;
    text-align: center;
    min-width: 0;
}
.s2-story__intro          { margin-bottom: 1.5em; width: 100%; }
.s2-story__collection-header { margin-bottom: 1em; width: 100%; }
.s2-story__perfumer {
    font-size: 0.875em;
	text-align: center;
    color: var(--c-orange);
    margin: 0.25em 0 0;
	font-weight: bold;
}

/* Product Swiper */
.s2-story__swiper-wrap { width: 100%; position: relative; margin-top: 1.5em; }
.s2-story__swiper      { padding-bottom: 3em !important; overflow: hidden; }
.s2-story__swiper .swiper-slide { width: 100%; height: auto; }

/* Product source: off-screen but renderable so images pre-load */
.s2-products__source {
    position: absolute;
    left: -9999px;
    width: 1px; height: 1px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

/* System product cards in Swiper */
.s2-story .swiper-slide .article_cell { position: relative; width: 100%; box-sizing: border-box; }
.s2-story .article_name_container a   { color: var(--c-headline); font-weight: 700; }
.s2-story .article_photo_link         { border-radius: 0.5em; position: relative; display: block; }
.s2-story .addToBasketTabButtons      { position: relative !important; display: block !important; opacity: 1 !important; }

@media (max-width: 640px) {
    .s2-story__side  { display: none; }
    .s2-story__main  { padding: 0 1em; }
}

/* --------------------------------------------------------------------------
   7. SECTION 3 – THE SCENT
   -------------------------------------------------------------------------- */
.s3-scent {
    background-color: var(--c-white);
	min-height: 50vw;
	padding-top:0;
}
.s3-scent .title    { color: var(--c-headline); }
.s3-scent .paragraph { color: var(--c-body); }
.s3-scent .pretitle { color: var(--c-headline); }

.s3-scent .paragraph b { color: var(--c-orange); }

.s3-scent__media_wrapper {
	position: relative;
}
.s3-scent__media {
    position: relative;
}
.s3-scent__media-img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 1em;
}

.s3-scent__notes {position: relative;padding-bottom: 3em;}
.s3-scent__note {
    position: relative;
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(2px);
	border: 0.125em solid #fff;
    border-radius: 2em;
    padding: 0.9em 1em;
	width: 100%;
	box-sizing: border-box;
    text-align: center;
    box-shadow: 0 4px 20px rgba(0,0,0,0.12);
	display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    align-content: center;
	grid-column-gap: 1em;
	grid-row-gap: 1em;
	margin-bottom: 1em;
}
.s3-scent__note-img-wrap {
    width: 12em; max-width: 100%;
	height: auto;
    display: block;
    margin: 0 auto;
	text-align: center;
}
.s3-scent__note-img-wrap img { width: 100%; height: auto; }

.s3-scent__note--2 .s3-scent__note-img-wrap {max-width: 90%;}
.s3-scent__note--3 .s3-scent__note-img-wrap {max-width: 70%;}

.s3-scent__note-txt-wrap {
	flex-grow: 1;
    width: auto;
    display: block;
    margin: 0 auto;
	text-align: center;
	flex: 1;
}
.s3-scent__note-name {
    font-family: 'Petrona', serif;
	letter-spacing: -0.01em;
    font-size: 1.5em;
    color: var(--c-accent);
    margin: 0 0 0.15em;
    font-weight: 500;
	text-align: center;
}
body[dir="rtl"] .s3-scent__note-name { font-family: inherit; }
.s3-scent__note-type {
    font-size: 0.75em;
    color: var(--c-gold);
    font-weight: 300;
    text-transform: uppercase;
    margin: 0 0 0.2em;
	text-align: center;
}
.s3-scent__note-desc {
    font-size: 0.75em;
    color: var(--c-body);
    margin: 1em 0 0 0;
    line-height: 1.4;
	text-align: center;
}

.s3-shop-button-container {
		position: relative;
		min-width: 30%;
}

/* --------------------------------------------------------------------------
   8. SECTION 4 – THE BODY RITUAL
   -------------------------------------------------------------------------- */
.s4-ritual {
    padding-bottom: 3.5em;
    overflow: visible; /* allow Swiper peek slides to extend outside section padding */
}
.s4-ritual::before{
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 29px;
    background-repeat: repeat-x;
    background-size: auto 100%;
    pointer-events: none;
    z-index: auto;
}
.s4-ritual .title      { color: var(--c-teal); }
.s4-ritual .pretitle   { color: var(--c-gold); }
.s4-ritual .pretitle::before,
.s4-ritual .pretitle::after { background: var(--c-gold); }
.s4-ritual .paragraph  { color: var(--c-text); }

.s4-ritual__swiper-wrap { margin-top: 0; }
.s4-ritual__swiper      { padding-bottom: 3.5em !important; overflow: hidden; }

/* Slide auto width — full card with peek on sides */
.s4-ritual__swiper .swiper-slide {
    width: min(92%, 1080px);
    height: auto;
}

/* Slide card  */
.s4-ritual__slide {
    position: relative;
    display: grid;
    gap: 1.5em;
    align-items: stretch;
    background: linear-gradient(to bottom, var(--c-green-box), var(--c-green-mint));
	background-repeat: no-repeat;
	background-size: cover;
    border-radius: 3em;
    border: 0.0675em solid var(--c-green-mint);
    padding: 2.5em 2em;
    overflow: visible; /* leaves extend outside card */
    min-height: 22em;
    box-sizing: border-box;
	
	
    grid-template-columns: 1fr 1fr;
  	grid-template-areas: 
    "header header"
    "prodA prodB";
}
.s4-ritual__slide.full-ritual-slide {
	aspect-ratio: 306 / 519;
	display: flex;
	align-items: flex-end;
    justify-content: center;
}


.s4-ritual__leaf {
    position: absolute;
    pointer-events: none;
    opacity: 0.5;
    z-index: 0;
    width: auto;
    height: auto;
	display: none;
}
.s4-ritual__leaf--l { bottom: 0; left: -5%; height: 115%; transform-origin: 50% 100%; animation: campaignLP_swingLeaf 2s linear 0s infinite; }
.s4-ritual__leaf--r { top: 10%;   right: 0; width: 35%;}
body[dir="rtl"] .s4-ritual__leaf--l { left: auto; right: -5%;}
body[dir="rtl"] .s4-ritual__leaf--r { right: auto; left: 0;}

/* Product columns (left + right) */
.s4-ritual__prod {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    text-align: center;
    gap: 0.6em;
}
.s4-ritual__center {grid-area: header;}
.s4-ritual__prod--a {grid-area: prodA;}
.s4-ritual__prod--b {grid-area: prodB;}


.s4-ritual__prod-img-link { display: block; }
.s4-ritual__prod-img-link img {
    width: 100%;
    max-width: 10em;
    height: auto;
    display: block;
    filter: drop-shadow(0 4px 12px rgba(0,0,0,0.3));
}
.s4-ritual__prod-name {
    font-size: 0.78em;
    font-weight: 700;
    color: var(--c-white);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0;
}
.s4-ritual__cart-btn {
    display: inline-block;
    background: linear-gradient(to bottom, var(--c-orange), var(--c-yellow-dark));
    color: var(--c-white);
    font-size: 0.72em;
	line-height: 1;
    font-weight: 700;
    padding: 0.5em 1em;
    border-radius: 1em;
    text-decoration: none;
    transition: opacity var(--transition);
    border: none;
    cursor: pointer;
}
.s4-ritual__cart-btn:hover { background: var(--c-white); color: var(--c-orange); text-decoration: none; }

/* Center content */
.s4-ritual__center,
.s4-ritual__center__top,
.s4-ritual__center__middle,
.s4-ritual__center__bottom{
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.5em;
}
.s4-ritual__label {
    font-size: 1em;
    font-weight: 300;
    color: var(--c-accent);
    letter-spacing: 0.2em;
    text-transform: uppercase;
    margin: 0;
}
.s4-ritual__title {
    font-family: 'Petrona', serif;
	letter-spacing: -0.01em;
    font-size: 2em;
    font-weight: 700;
    color: var(--c-accent-2);
    margin: 0;
    line-height: 1.2;
	text-align: center;
}
body[dir="rtl"] .s4-ritual__title { font-family: inherit; font-style: normal; }
.s4-ritual__text {
    font-family: 'Petrona', serif;
    font-size: 1.125em;
    font-weight: 300;
    color: var(--c-white);
    line-height: 1.25;
    font-style: italic;
    margin: 0;
	text-align: center;
}
body[dir="rtl"] .s4-ritual__text { font-family: inherit; font-style: normal; }
.s4-ritual__claim {
    font-size: 1em;
    font-weight: 300;
    color: var(--c-white);
    line-height: 1.25;
    margin: 0;
	text-align: center;
}
.s4-ritual__disclaimer {
    font-size: 0.75em;
	font-weight: 300;
    color: var(--c-white);
    margin: 0;
    line-height: 1.125;
	text-align: center;
}
a.campaign-button.s4-ritual__inner-cta {
    background: linear-gradient(to bottom, var(--c-accent), var(--c-teal-dark));
    border-color: transparent;
    border-radius: 1em;
    color: var(--c-white);
    margin-top: 0.5em;
    font-size: 0.925em;
	line-height: 1;
}
a.campaign-button.s4-ritual__inner-cta:hover,
a.campaign-button.s4-ritual__inner-cta:focus-visible {
    background: linear-gradient(to bottom, var(--c-teal-dark), var(--c-accent));
    border-color: transparent;
    color: var(--c-white);
}


/* --------------------------------------------------------------------------
   9. SECTION 5 – GIFTS
   -------------------------------------------------------------------------- */
.s5-gifts {
    background-color: transparent;
    padding: 2em 0;
    position: relative;
}
/* Separator bottom of S5 */
.s5-gifts::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 29px;
    background-repeat: repeat-x;
    background-size: auto 100%;
    pointer-events: none;
    z-index: 2;
}
.s5-gifts .title    { color: var(--c-headline); margin-bottom: 1.5em; }
.s5-gifts .paragraph { color: var(--c-body); }

/* Simple centered layout — two items stacked or side-by-side */
.s5-gifts__layout {
    max-width: 60em;
    margin: 0 auto;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
	flex-direction: column;
    gap: 1em;
    justify-content: center;
    align-items: center;
}
.s5-gifts__item {
    flex: 1 1 20em;
    max-width: 28em;
    text-align: center;
}
.s5-gifts__img-wrap { margin-bottom: 1.25em; }
.s5-gifts__img-wrap img { max-width: 20em; width: auto; max-width: 100%; height: auto; margin: 0 auto; border-radius: 0.75em; display: block; }
.s5-gifts__item-content { padding: 0 1em; }
.s5-gifts__item-title {
    font-family: 'Petrona', serif;
    font-size: 1.5em;
	font-weight: 700;
    color: var(--c-accent);
    margin: 0 0 0.5em;
	text-align: center;
}
body[dir="rtl"] .s5-gifts__item-title { font-family: inherit;  }
.s5-gifts__item-text {
    font-size: 0.925em;
    color: var(--c-body);
    line-height: 1.7;
    margin: 0 0 1em;
}
.s5-gifts__tote-conditions {
    font-size: 0.75em;
    color: var(--c-body);
    font-style: italic;
    margin: 0.75em 0 0;
    line-height: 1.5;
    opacity: 0.7;
}
.s5-gifts a.campaign-button--fill {
    background: var(--c-white);
    border: 1px dashed var(--c-accent);	
    color: var(--c-accent);
}
.s5-gifts a.campaign-button--fill:hover,
.s5-gifts a.campaign-button--fill:focus-visible {
    background: var(--c-accent);	
    color: var(--c-white);
    border-style: solid;
}


.s6-urgency {
    padding: 2em 0;
    text-align: center;
}
.s6-urgency .pretitle { color: var(--c-text); }
.s6-urgency .pretitle::before,
.s6-urgency .pretitle::after { background: var(--c-text); }
.s6-urgency__label {
    color: rgba(255,255,255,0.9);
    margin-bottom: 0.75em;
}
.s6-urgency__timer {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0.5em 0 1.5em;
}
.s6-urgency__timer-digits {
    font-family: monospace;
    font-size: 1.5em;
    font-weight: bold;
    color: var(--c-text);
    letter-spacing: 0.06em;
    line-height: 1;
    background: #e3e3e3;
    border: 1px solid var(--c-text);
    display: inline-block;
    padding: 0.25em;
	
}
.s6-urgency a.campaign-button {
    background: var(--c-white);
    border-color: var(--c-white);
    color: var(--c-text);
}
.s6-urgency a.campaign-button:hover,
.s6-urgency a.campaign-button:focus-visible {
    background: var(--c-yellow-dark);
    border-color: var(--c-yellow-dark);
    color: var(--c-text);
}

/* --------------------------------------------------------------------------
   11. SECTION 7 – LIMITED MOMENT (dark)
   -------------------------------------------------------------------------- */
.s7-limited {
    background-color: var(--c-dark);
    padding: 3em 0;
}
.s7-limited .pretitle { color: var(--c-gold); }
.s7-limited .pretitle::before,
.s7-limited .pretitle::after { background: var(--c-gold); }
.s7-limited .title { color: var(--c-accent-2); font-size: 2em; }
.s7-limited .paragraph { color: rgba(255,255,255,0.82); }
.s7-limited__inner {
    padding: 0;
    margin: 0 auto;
}
.s7-limited a.campaign-button--fill {
    background: var(--c-white);
    border: 1px dashed var(--c-accent);	
    color: var(--c-accent);
}
.s7-limited a.campaign-button--fill:hover,
.s7-limited a.campaign-button--fill:focus-visible {
    background: var(--c-accent);	
    color: var(--c-white);
    border-style: solid;
}

/* --------------------------------------------------------------------------
   12. SECTION 8 – FINALE
   -------------------------------------------------------------------------- */
.s8-finale {
    background-color: var(--c-cream);
    padding: 0;
    min-height: 40em;
}
.s8-finale__content { position: relative;}
.s8-finale__inner {
    position: relative;
    width: 100%;
    display: flex;
	flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 4em 1.5em;
    box-sizing: border-box;
}
.s8-finale__media-img {width:100%; height: auto;}
.s8-finale .title    { color: var(--c-headline); }
.s8-finale .paragraph { color: var(--c-body); }

.s8-video {
    background-size: cover;
    background-position: center;
    min-height: 22em;
    display: block;
    padding: 2em 1em;
	box-sizing: border-box; 
}
.s8-video__inner { position: relative; z-index: 2; display: block; width: auto; max-width: 100%; box-sizing: border-box; }
.s8-video__container { margin: 1.5em 0 0 0; aspect-ratio: 16 / 9; width: 100%;
    display: flex; justify-content: center; align-items: center; flex-wrap: nowrap;
}
.s8-video__play {
    display: inline-flex; align-items: center; justify-content: center;
    width: 5em; height: 5em;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.8);
    background: rgba(255,255,255,0.15);
    transition: background var(--transition);
    text-decoration: none;
}
.s8-video__play:hover,
.s8-video__play:focus-visible { background: rgba(255,255,255,0.3); outline: none; }
.s8-video__play img { width: 2em; height: 2em; object-fit: contain; }

.s8-video__play-placeholder {
    display: inline-flex;
    width: 5em; height: 5em;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.7);
    background: rgba(255,255,255,0.15);
    position: relative;
}
.s8-video__play-placeholder::after {
    content: '';
    position: absolute;
    top: 50%; left: 52%;
    transform: translate(-50%,-50%);
    width: 0; height: 0;
    border-style: solid;
    border-width: 0.7em 0 0.7em 1.2em;
    border-color: transparent transparent transparent rgba(255,255,255,0.85);
}

.video-frame { display: block; width: 100%; aspect-ratio: 16 / 9; border: 0; }

@media only screen and (min-width: 48em) {
    .s8-video { padding: 3em 1em; }
}


.campaign-separator {
    position: relative;
    height: 29px;
    background-repeat: repeat-x;
    background-size: auto 100%;
    overflow: visible;
}

.s2-story__split {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    margin-top: 2em;
}
.s2-story__photo {
    position: relative;
    flex: 0 0 auto;
    overflow: visible;
}
.s2-story__photo img {
    width: 100%;
    height: auto;
    display: block;
}
.s2-story__products-wrap { flex: 1 1 auto; }
.s2-story__collection-title { font-size: 1.5em; margin: 0.5em 0 0.25em; }

/* Product list horizontal scroll */
.campaignLP-horiz-list-wrapper { position: relative; }
.campaignLP-products { padding: 1.5em 0 3em; }
.campaignLP-products .wrap { position: relative; overflow: visible; margin: 0 1em; direction: ltr; }
.campaignLP-products .frame { overflow: auto; padding: 0; position: relative; }
.campaignLP-products .productsList.horizontal-scroll { font-size: 0.9em; }
.campaignLP-products .productsList.horizontal-scroll .article_cell {
    width: 14em; padding: 0 0.75em; white-space: normal;
}
.campaignLP-products .scrollbar {
    margin: 1em 0 0.5em; height: 3px;
    background: rgba(175,152,102,0.2);
    border-radius: 3px; line-height: 0;
}
.campaignLP-products .scrollbar .handle {
    height: 100%; border-radius: 3px;
    background: var(--c-gold); cursor: pointer; min-width: 3em;
}
.campaignLP-products .scrollbar .handle .mousearea {
    position: absolute; top: -0.75em; left: 0; width: 100%; height: 1.5em;
}
.campaignLP-products .productsList .article_name_container a { color: var(--c-text); }
.campaignLP-products .productsList .article_name_container a:hover { color: var(--c-teal); }
.campaignLP-products .productsListWrapperTopInfo { display: none; }

/* --------------------------------------------------------------------------
   16. Game parrots
   -------------------------------------------------------------------------- */
.game-parrot {
    position: absolute;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    z-index: 10;
    transition: transform 0.15s ease;
    /* positions overridden per parrot modifier */
}
.game-parrot:hover { transform: scale(1.12) rotate(-5deg); }
.game-parrot:focus-visible { outline: 2px dashed var(--c-gold); outline-offset: 4px; }
.game-parrot img { display: block; pointer-events: none; }

/* Parrot positions */
.game-parrot--s2                    { top: -10px; right: -10px; } /* inside .s2-story__deco--kit */
.game-parrot--s34                   { top: -28px; right: 12%; }
.game-parrot--s5                    { top: -20px; right: -30px; }
.game-parrot--s6                    { top: 1.5em; right: 2em; }
body[dir="rtl"] .game-parrot--s2   { right: auto; left: -10px; }
body[dir="rtl"] .game-parrot--s34  { right: auto; left: 12%; }
body[dir="rtl"] .game-parrot--s5   { right: auto; left: -30px; }
body[dir="rtl"] .game-parrot--s6   { right: auto; left: 2em; }

/* Fly-away animation */
@keyframes parrotFlyAway {
    0%   { opacity: 1; transform: scale(1) translate(0, 0); }
    40%  { opacity: 0.7; transform: scale(1.1) translate(20px, -30px) rotate(15deg); }
    100% { opacity: 0; transform: scale(0.3) translate(80px, -120px) rotate(30deg); }
}
.game-parrot--flying {
    animation: parrotFlyAway 0.7s ease-in forwards;
    pointer-events: none;
}
.game-parrot--found { display: none !important; }

/* Position contexts for parrot parents */
.s2-story__photo        { overflow: visible; }
.s5-kit__cta-wrap       { position: relative; display: inline-block; }
.s6-urgency             { overflow: visible; }
.campaign-separator     { overflow: visible; }

/* --------------------------------------------------------------------------
   17. Game bubble — fixed, always visible when game is active
   -------------------------------------------------------------------------- */
.game-bubble {
    position: fixed;
    bottom: 1.5em;
    right: 1.5em;
    z-index: 9000;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    pointer-events: none;
    font-size: 1rem;
}
body[dir="rtl"] .game-bubble { right: auto; left: 1.5em; align-items: flex-start; }

/* White glow behind bubble */
.game-bubble__glow {
    position: absolute;
    bottom: 0.5em; right: 0.75em;
    width: 10em; height: 10em;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,0.95) 20%, rgba(255,255,255,0) 70%);
    pointer-events: none;
    z-index: 0;
}
body[dir="rtl"] .game-bubble__glow { right: auto; left: 0.75em; }

/* Hexagonal body */
.game-bubble__body {
    position: relative;
    z-index: 1;
    pointer-events: all;
    background: linear-gradient(135deg, #f5a623 0%, #e07820 60%, #c86010 100%);
    clip-path: polygon(15% 0%, 85% 0%, 100% 15%, 100% 85%, 85% 100%, 15% 100%, 0% 85%, 0% 15%);
    padding: 1.25em 1.4em;
    max-width: 13em;
    text-align: center;
    box-shadow: 0 4px 20px rgba(224, 120, 32, 0.4);
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.game-bubble__body:hover { transform: scale(1.04); box-shadow: 0 6px 28px rgba(224,120,32,0.5); }

.game-bubble__text {
    font-size: 0.8em;
    color: rgba(255,255,255,0.92);
    line-height: 1.45;
    margin: 0 0 0.75em;
}
.game-bubble__cta {
    display: inline-block;
    background: rgba(255,255,255,0.2);
    border: 1.5px solid rgba(255,255,255,0.7);
    border-radius: 4em;
    color: var(--c-white);
    font-size: 0.78em;
    font-weight: 700;
    padding: 0.45em 1.1em;
    letter-spacing: 0.04em;
    text-decoration: none;
    transition: background var(--transition);
}
.game-bubble__cta:hover { background: rgba(255,255,255,0.35); text-decoration: none; color: var(--c-white); }

/* Counter circle */
.game-bubble__counter {
    position: absolute;
    bottom: -0.6em;
    right: 3.5em;
    z-index: 2;
    pointer-events: none;
    width: 2.6em; height: 2.6em;
    border-radius: 50%;
    background: var(--c-teal);
    color: var(--c-white);
    font-size: 0.82em;
    font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
    letter-spacing: -0.02em;
}
body[dir="rtl"] .game-bubble__counter { right: auto; left: 3.5em; }

/* Win state */
.game-bubble--won .game-bubble__body {
    background: linear-gradient(135deg, #f5c842 0%, #e8a800 60%, #c88000 100%);
    box-shadow: 0 4px 24px rgba(245, 200, 66, 0.5);
}
.game-bubble--won .game-bubble__counter { background: #c88000; }

/* Language overrides */
body.lang_ro .game-bubble__body { font-size: 0.9em; }

/* --------------------------------------------------------------------------
   15. Animations
   -------------------------------------------------------------------------- */
@keyframes campaignLP_blurIn {
    0%   { opacity: 0; filter: blur(30px); }
    100% { opacity: 1; filter: blur(0); }
}
@keyframes campaignLP_scaleIn {
    0%   { opacity: 0; transform: scale(0); }
    100% { opacity: 1; transform: scale(1); }
}
@keyframes campaignLP_fadeIn {
    0%   { opacity: 0; }
    100% { opacity: 1; }
}
@keyframes campaignLP_fadeInDown {
    0%   { transform: translateY(-40px); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
}
@keyframes campaignLP_fadeInDownBlurred {
    0%   { transform: translateY(-40px); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
}
@keyframes campaignLP_fadeInUp {
    0%   { transform: translateY(40px); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
}
@keyframes campaignLP_fadeInLeft {
    0%   { transform: translateX(40px); opacity: 0; }
    100% { transform: translateX(0); opacity: 1; }
}
@keyframes campaignLP_fadeInRight {
    0%   { transform: translateX(-40px); opacity: 0; }
    100% { transform: translateX(0); opacity: 1; }
}

.campaignLP-container .animate .blurIn              { animation: campaignLP_blurIn 1s linear 0s 1 forwards; }
.campaignLP-container .animate .scaleIn             { animation: campaignLP_scaleIn 1s linear 0s 1 forwards; }
.campaignLP-container .animate .fadeIn              { animation: campaignLP_fadeIn 1s linear 0s 1 forwards; }
.campaignLP-container .animate .fadeInDown          { animation: campaignLP_fadeInDown 1s linear 0s 1 forwards; }
.campaignLP-container .animate .fadeInDownBlurred   { animation: campaignLP_fadeInDownBlurred 1s linear 0s 1 forwards; }
.campaignLP-container .animate .fadeInUp            { animation: campaignLP_fadeInUp 1s linear 0s 1 forwards; }
.campaignLP-container .animate .fadeInLeft          { animation: campaignLP_fadeInLeft 1s linear 0s 1 forwards; }
.campaignLP-container .animate .fadeInRight         { animation: campaignLP_fadeInRight 1s linear 0s 1 forwards; }

.campaignLP-container .anim { animation-play-state: paused; }
.campaignLP-container .animate .anim { animation-play-state: running; }

.campaignLP-container .animate .delay-0s    { animation-delay: 0s; }
.campaignLP-container .animate .delay-0s25  { animation-delay: 0.25s; }
.campaignLP-container .animate .delay-0s5   { animation-delay: 0.5s; }
.campaignLP-container .animate .delay-0s75  { animation-delay: 0.75s; }
.campaignLP-container .animate .delay-1s    { animation-delay: 1s; }
.campaignLP-container .animate .delay-1s5   { animation-delay: 1.5s; }
.campaignLP-container .animate .delay-2s    { animation-delay: 2s; }

.campaignLP-container .animate .duration-0s5  { animation-duration: 0.5s; }
.campaignLP-container .animate .duration-0s75 { animation-duration: 0.75s; }
.campaignLP-container .animate .duration-1s   { animation-duration: 1s; }
.campaignLP-container .animate .duration-1s5  { animation-duration: 1.5s; }
.campaignLP-container .animate .duration-2s   { animation-duration: 2s; }
