.bdvb-wrapper {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: 12px;
}

/* Hjørne-stil */
.bdvb-wrapper.bdvb-corners-square {
    border-radius: 0;
}

.bdvb-orientation-landscape {
    max-width: 100%;
}

.bdvb-orientation-vertical {
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

.bdvb-bg {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    transform: translate(-50%, -50%);
    object-fit: cover;
}

.bdvb-bg-image {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}


.bdvb-overlay {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    box-sizing: border-box;
    transition: background 0.25s ease, color 0.25s ease;
}

.bdvb-overlay-style-dark {
    color: #ffffff;
    background: linear-gradient(
        135deg,
        rgba(0, 0, 0, 0.65),
        rgba(0, 0, 0, 0.4)
    );
}

.bdvb-overlay-style-light {
    color: #111827;
    background: linear-gradient(
        135deg,
        rgba(255, 255, 255, 0.85),
        rgba(243, 244, 246, 0.9)
    );
}

.bdvb-overlay-style-light .bdvb-price {
    background: rgba(17, 24, 39, 0.85);
    color: #f9fafb;
    letter-spacing: 0 !important;
    word-spacing: 0 !important;
    font-variant-numeric: normal;
    font-feature-settings: "zero" 0;
}


.bdvb-price.bdvb-percent-mode {
    font-size: clamp(3rem, 10vw, 12rem);
    font-weight: 900;
    letter-spacing: 0.04em;
}


.bdvb-label {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    background: rgba(37, 99, 235, 0.9);
    color: #f9fafb;
}

.bdvb-label-color-blue {
    background: rgba(37, 99, 235, 0.9);
}

.bdvb-label-color-red {
    background: rgba(220, 38, 38, 0.9);
}

.bdvb-label-color-green {
    background: rgba(16, 185, 129, 0.9);
}

.bdvb-label-color-orange {
    background: rgba(249, 115, 22, 0.95);
}

.bdvb-label-color-gray {
    background: rgba(107, 114, 128, 0.9);
}

.bdvb-headline {
    font-size: 1.8rem;
    font-weight: 700;
    margin: 0 0 0.25em;
    letter-spacing: normal !important;
    word-spacing: normal !important;
    white-space: normal;
}

.bdvb-headline-line2 {
    display: inline-block;
    margin-top: 0.1em;
}

.bdvb-subheadline {
    font-size: 1rem;
    margin: 0 0 1em;
    opacity: 0.85;
    letter-spacing: normal !important;
    word-spacing: normal !important;
    white-space: normal;
}

.bdvb-price {
    font-size: 3.2rem;
    font-weight: 800;
    padding: 0.4em 0.8em;
    background: rgba(0, 0, 0, 0.6);
    border-radius: 999px;
    display: inline-block;
    white-space: nowrap;
    will-change: transform;
    font-variant-numeric: normal;
    font-feature-settings: "zero" 0;
}


.bdvb-emoji {
    margin-left: 0;
    display: inline-block;
}

.bdvb-price-emoji {
    margin-left: 0.35em;
}

@media (max-width: 768px) {
    .bdvb-headline {
        font-size: 1.25rem;
    }
    .bdvb-price {
        font-size: clamp(1.0rem, 4.2vw, 1.4rem);
        padding: 0.25em 0.6em;
    }
}

@media (max-width: 480px) {
    .bdvb-price {
        font-size: clamp(0.9rem, 4.5vw, 1.2rem);
        padding: 0.2em 0.5em;
    }
}

.bdvb-headline-size-sm {
    font-size: 1.2rem;
}

.bdvb-headline-size-md {
    font-size: 1.6rem;
}

.bdvb-headline-size-lg {
    font-size: 2.1rem;
}

.bdvb-headline-size-xl {
    font-size: 2.6rem;
}

.bdvb-headline-size-xxl {
    font-size: 3.2rem;
}

.bdvb-subheadline-size-sm {
    font-size: 0.85rem;
}

.bdvb-subheadline-size-md {
    font-size: 1rem;
}

.bdvb-subheadline-size-lg {
    font-size: 1.2rem;
}

.bdvb-subheadline-size-xl {
    font-size: 1.4rem;
}

.bdvb-subheadline-size-xxl {
    font-size: 1.6rem;
}

.bdvb-price-size-sm {
    font-size: 2.4rem;
}

.bdvb-price-size-md {
    font-size: 2.8rem;
}

.bdvb-price-size-lg {
    font-size: 3.4rem;
}

.bdvb-price-size-xl {
    font-size: 4.0rem;
}

.bdvb-price-size-xxl {
    font-size: 4.8rem;
}

.bdvb-align-left {
    align-items: flex-start;
    text-align: left;
}

.bdvb-align-center {
    align-items: center;
    text-align: center;
}

.bdvb-align-right {
    align-items: flex-end;
    text-align: right;
}

@media (max-width: 768px) {
    .bdvb-align-mobile-left {
        align-items: flex-start !important;
        text-align: left !important;
    }
    .bdvb-align-mobile-center {
        align-items: center !important;
        text-align: center !important;
    }
    .bdvb-align-mobile-right {
        align-items: flex-end !important;
        text-align: right !important;
    }
}

.bdvb-disclaimer {
    margin-top: 0.45em;
    font-size: 0.75rem;
    opacity: 0.9;
    max-width: 90%;
}

@media (max-width: 768px) {
    .bdvb-disclaimer {
        font-size: 0.8rem;
    }
}


.bdvb-price-bump {
    animation: bdvb-price-bump-keyframes 1.2s ease-out;
}

@keyframes bdvb-price-bump-keyframes {
    0% {
        transform: scale(1) translateX(0);
    }
    25% {
        transform: scale(1.4) translateX(0); /* kraftig zoom opp */
    }
    40% {
        transform: scale(1.4) translateX(0); /* hold på full zoom */
    }
    55% {
        transform: scale(1.4) translateX(-12px); /* start hard shake */
    }
    62% {
        transform: scale(1.4) translateX(12px);
    }
    69% {
        transform: scale(1.4) translateX(-10px);
    }
    76% {
        transform: scale(1.4) translateX(10px);
    }
    83% {
        transform: scale(1.35) translateX(-8px);
    }
    90% {
        transform: scale(1.3) translateX(8px);
    }
    96% {
        transform: scale(1.1) translateX(0); /* roer ned før landing */
    }
    100% {
        transform: scale(1) translateX(0); /* setter seg bestemt */
    }
}
    30% {
        transform: scale(1.35) translateX(0); /* zoom opp */
    }
    45% {
        transform: scale(1.35) translateX(0); /* hold på full zoom */
    }
    60% {
        transform: scale(1.35) translateX(-6px); /* kraftig risting */
    }
    70% {
        transform: scale(1.35) translateX(6px);
    }
    78% {
        transform: scale(1.35) translateX(-4px);
    }
    86% {
        transform: scale(1.35) translateX(4px);
    }
    93% {
        transform: scale(1.32) translateX(0); /* roer litt ned */
    }
    100% {
        transform: scale(1) translateX(0); /* setter seg bestemt */
    }
}
    30% {
        transform: scale(1.35);
    }
    55% {
        transform: scale(0.9);
    }
    100% {
        transform: scale(1);
    }
}
    40% {
        transform: scale(1.16);
    }
    100% {
        transform: scale(1);
    }
}


.bdvb-valign-top {
    justify-content: flex-start;
}

.bdvb-valign-center {
    justify-content: center;
}

.bdvb-valign-bottom {
    justify-content: flex-end;
}


/* Responsive adjustments */
@media (max-width: 768px) {
    .bdvb-overlay {
        padding: 1.5rem 1rem;
    }
    .bdvb-headline {
        font-size: 2rem;
    }
    .bdvb-subheadline {
        font-size: 1rem;
    }
    .bdvb-price {
        font-size: 1.4rem;
    }
    .bdvb-price.bdvb-percent-mode {
        font-size: clamp(3rem, 26vw, 7rem);
    }
    .bdvb-disclaimer {
        font-size: 0.75rem;
    }
}

/* Responsive adjustments for percent-mode */
@media (max-width: 1200px) {
    .bdvb-price.bdvb-percent-mode {
        font-size: clamp(3rem, 14vw, 9rem);
    }
}

@media (max-width: 900px) {
    .bdvb-price.bdvb-percent-mode {
        font-size: clamp(3rem, 20vw, 7rem);
    }
}

@media (max-width: 768px) {
    .bdvb-price.bdvb-percent-mode {
        font-size: clamp(2.4rem, 24vw, 6rem);
    }
}



.bdvb-price.bdvb-price-no-bg {
    background: transparent;
    box-shadow: none;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    padding: 0;
}


.bdvb-price {
    letter-spacing: 0 !important;
    word-spacing: 0 !important;
}

.bdvb-price-label,
.bdvb-price-value,
.bdvb-price-suffix {
    display: inline-block;
    vertical-align: baseline;
}

.bdvb-price-label-part + .bdvb-price-label-part {
    margin-left: 0.18em;
}

.bdvb-price-label + .bdvb-price-value {
    margin-left: 0.28em;
    /* Ekstra stramt tusenskille-mellomrom i tallverdien */
    word-spacing: -0.40em;
}

.bdvb-price-value + .bdvb-price-suffix {
    margin-left: 0.02em;
}


/* Make label/suffix text smaller than numeric value */
.bdvb-price-label,
.bdvb-price-suffix {
    font-size: 0.5em;
}

/* Komprimer mellomrom i prisverdi (tusenskille) */
.bdvb-price-value {
    word-spacing: -0.18em;
}

/* --- Override: større tall inne i boblen, uten å blåse opp boblen --- */

/* Moderat base-størrelse på boblen i prosent-modus */
.bdvb-price.bdvb-percent-mode {
    font-size: clamp(1.1rem, 3.4vw, 1.6rem);
    font-weight: 900;
    letter-spacing: 0.04em;
}

/* Felles: gjør selve tallet mye større enn boblen sin grunntekst */
.bdvb-price .bdvb-price-value {
    font-size: 2.8em;
    line-height: 1;
}

/* I prosent-modus kan tallet være enda større */
.bdvb-price.bdvb-percent-mode .bdvb-price-value {
    font-size: 3.2em;
}

/* Hold label/suffix små slik at tallet dominerer inni boblen */
.bdvb-price-label,
.bdvb-price-suffix {
    font-size: 0.4em;
}

/* Justering for små mobiler */
@media (max-width: 480px) {
    .bdvb-price.bdvb-percent-mode {
        font-size: clamp(0.9rem, 4vw, 1.2rem);
    }
    .bdvb-price .bdvb-price-value {
        font-size: 2.6em;
    }
}

/* --- Mer luft ved venstre/høyre-justering --- */
/* Desktop / større flater: litt ekstra innrykk slik at tekst/price ikke ligger helt inntil kanten */
.bdvb-overlay.bdvb-align-left {
    padding-left: 34px;
}

.bdvb-overlay.bdvb-align-right {
    padding-right: 34px;
}

/* Mobil: behold kompakt layout, men gi fortsatt litt ekstra luft */
@media (max-width: 768px) {
    .bdvb-overlay.bdvb-align-left,
    .bdvb-overlay.bdvb-align-mobile-left {
        padding-left: 22px !important;
        padding-right: 16px !important;
    }

    .bdvb-overlay.bdvb-align-right,
    .bdvb-overlay.bdvb-align-mobile-right {
        padding-right: 22px !important;
        padding-left: 16px !important;
    }
}

