/* General */

.no-shadow {
    box-shadow: none !important;
}

.text-primary {
    color: var(--site-primary-color) !important;
}

.active {
    color: var(--site-primary-color) !important;
}

.text-justify {
    text-align: justify !important;
}

.pointer {
    cursor: pointer !important;
}

.no-select {
    user-select: none;
    /* Safari */
    -webkit-user-select: none;
    /* Firefox */
    -moz-user-select: none;
    /* IE10+/Edge */
    -ms-user-select: none;
}

blockquote {
    font-style: italic;
    color: #555;
    border-left: 4px solid #ddd;
    border-radius: 0 5px 5px 0;
    margin: 20px 0;
    padding: 10px 20px;
    background-color: #dddddd3d;
    text-align: left;
}

pre {
    background-color: #2d2d2d;
    color: #f8f8f2;
    padding: 15px;
    border-radius: 5px;
    overflow-x: auto;
    font-family: 'Courier New', Courier, monospace;
    font-size: 14px;
    line-height: 1.5;
    white-space: pre-wrap;
    margin: 20px 0;
    text-align: left;
}

hr {
    margin: 1rem 0;
    color: var(--site-friendly-black) !important;
    border: 0;
    border-top: 1px solid;
    opacity: 0.25;
}

input[readonly] {
    color: var(--site-invalid) !important;
    border: 1px solid #ccc;
    cursor: not-allowed;
}

/* Disclaimer */

.footer-disclaimer {
    color: var(--site-invalid) !important;
}


/* Tooltip Element */

.tooltip-element {
    position: relative;
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
}

.tooltip-element .tooltip-element-target {
    position: absolute;
    right: -20px;
    top: -5px;
    font-size: 13px;
}

.opacity-hover {
    opacity: 1 !important;
    transition: 0.3s;
}

.opacity-hover:hover {
    opacity: 0.8 !important;
    transition: 0.3s;

}

/* SEO */
.preview-text {
    display: none;
    font-size: 1px;
    color: #ffffff;
    line-height: 1px;
    max-height: 0px;
    max-width: 0px;
    opacity: 0;
    overflow: hidden;
}

/* Breaking News Section */
.bn-element {
    padding: 5px !important;
    border-radius: 5px;
    background-color: var(--site-primary-color);
    color: var(--site-uncolored-text);
    transition: 0.3s;
    text-align: center;
    border: none !important;
}

.bn-instance {
    padding: 5px !important;
    border-radius: 5px !important;
    background-color: var(--site-primary-color);
    color: var(--site-uncolored-text);
    transition: 0.3s;
    text-align: center;
    border: none !important;
}

.toast-header {
    background-color: var(--site-primary-color);
}

.no-radius {
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.yes-radius {
    border-radius: 5px !important;
}

.bn-element:hover,
.bn-instance:hover {
    transition: 0.3s;
    background-color: var(--site-primary-hover);
}

@keyframes blink {

    0%,
    100% {
        color: #ecf0f1;
        /* Initial and final color */
    }

    50% {
        color: #ecf0f165;
        /* Color during the blink */
    }
}

.blinking-icon {
    animation: blink 1s linear infinite;
}

#breaking_news-social-media>li>a {
    color: var(--site-friendly-black) !important;
}

#breaking_news-social-media>li>a:hover {
    color: var(--site-invalid) !important;
}

#toastTime {
    color: var(--site-uncolored-text) !important;
}

/* Mailchimp - Newsletter*/

#mc_embed_signup {
    background: var(--site-bg-white);
    clear: left;
    font: 14px Helvetica, Arial, sans-serif;
    width: 600px;
}

#mc-embedded-subscribe {
    margin: 0 !important;
}

.newsletter-hidden-input {
    position: absolute;
    left: -5000px;
}

.mc-layout__modalContent {
    box-shadow: none !important;
}

/* GDPR and Cookie */

.gdpr-banner {
    border-top: 1px solid var(--site-primary-hover);
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: var(--site-secondary-color);
    padding: 15px;
    text-align: center;
    z-index: 999;
    display: none;
}

.gdpr-banner p {
    margin-bottom: 10px;
    color: var(--default-color);
}

.gdpr-banner p>a {
    color: var(--site-primary-color) !important;
}

#gdpr-accept,
#gdpr-settings {
    padding: 10px 20px;
    border-radius: 15px;
    cursor: pointer;
}

#gdpr-accept {
    background-color: var(--site-primary-color);
    color: var(--site-uncolored-text);
}

#gdpr-accept:hover {
    background-color: var(--site-primary-hover);
}

#gdpr-settings {
    margin-left: 10px;
    background-color: #c0392b;
    color: var(--site-uncolored-text);
}

#gdpr-settings:hover {
    background-color: #c0392bd0;
}

#popupModal6 {
    z-index: 9999;
}

.cookies-border {
    border-color: var(--site-primary-hover) !important;
}

/* Truncation */

.truncation {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 6;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.5em;
    max-height: calc(1.5em * 6);
}

.b-truncation {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.5em;
    max-height: calc(1.5em * 6);
}

.truncation.fallback-single-line {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}


/* Truncation */
.d-truncation>p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.5em;
}

.d-truncation>h3 {
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    line-height: 1.2em !important;
}

@media (max-width: 457px) {
    .d-truncation>p {
        -webkit-line-clamp: 6;
        line-clamp: 6;
        max-height: 10.5em;
        height: 144px;
    }
}

@media (max-width: 401.98px) {
    .d-truncation>h3 {
        -webkit-line-clamp: 2;
        line-clamp: 2;
        max-height: 10.5em;
        height: 54px;
    }
}

@media (min-width: 992px) {
    .d-truncation>h3 {
        -webkit-line-clamp: 2;
        line-clamp: 2;
        max-height: 10.5em;
        height: 67px;
    }
}

/* Card */

.is_special {
    border: 1px solid var(--site-primary-color);
}


/* Youtube Facade */

.youtube-container {
    position: relative;
    width: 100%;
    /* Fallback for browsers without aspect-ratio support */
    height: 0;
    padding-bottom: 75%;
    /* Normal */
    aspect-ratio: 4 / 3;
    overflow: hidden;
}

.image-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Important: Show full image, never crop */
.youtube-thumbnail-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    display: block;
}

/* Center play button within image area */
.play-button {
    position: absolute;
    width: 60px;
    height: 60px;
    background: url(../assets/youtube-brands-solid.svg) center center no-repeat;
    background-size: contain;
    z-index: 2;
    cursor: pointer;
}

.bg-green {
    background-color: #27ae60 !important;
    color: var(--contrast-color);
}

.bg-danger {
    background-color: #c0392b !important;
    color: var(--contrast-color);
}

.thumbnail-item {
    position: relative;
    cursor: pointer;
}

.youtube-play-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    /* so the icon doesn't block clicks */
}

.youtube-play-icon svg {
    width: 40px;
    height: 40px;
}

/* Cart */

.btn-side-bag {
    position: fixed;
    height: 60px;
    width: auto;
    padding: 0 5px 0 5px;
    bottom: 50vh;
    right: 10px;
    background-color: var(--site-primary-color);
    display: inline-block;
    color: var(--site-uncolored-text) !important;
    transition: 0.3s;
    z-index: 99999;
}


.btn-side-bag-txt-white {
    color: var(--site-uncolored-text) !important;
}

/* Social Media Sharing */

.social-icons {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;

    a {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 36px;
        height: 36px;
        border-radius: 50%;
        background-color: color-mix(in srgb, var(--default-color), transparent 90%);
        color: var(--default-color);
        font-size: 16px;
        transition: all 0.3s ease;

        &:hover {
            background-color: var(--accent-color);
            transform: rotate(360deg);
            color: var(--contrast-color);
        }
    }
}

/* Messages */

/* Basic styling for the messages container */
.messages {
    margin-top: 20px;
    transition: 0.3s;
}

/* Styles for specific message types */
.alert-info {
    background-color: var(--site-info-bg);
    border: 1px solid var(--site-border-white);
    color: var(--site-friendly-black) !important;
    padding: 10px;
    margin-bottom: 10px;
    border-radius: 5px;
    transition: 0.3s;
    width: auto;
}

.alert-error {
    background-color: var(--site-error-bg);
    border: 1px solid var(--site-border-white);
    color: var(--site-friendly-black) !important;
    padding: 10px;
    margin-bottom: 10px;
    border-radius: 5px;
    transition: 0.3s;
}

.alert-success {
    background-color: var(--site-success-bg);
    border: 1px solid var(--site-border-white);
    color: var(--site-friendly-black) !important;
    padding: 10px;
    margin-bottom: 10px;
    border-radius: 5px;
    transition: 0.3s;
}

.alert-warning {
    background-color: var(--site-warning-bg);
    border: 1px solid var(--site-border-white);
    color: var(--site-friendly-black) !important;
    padding: 10px;
    margin-bottom: 10px;
    border-radius: 5px;
    transition: 0.3s;
}

/* Spinner */
.spinner {
    color: var(--accent-color) !important;
}

/* Sitename */
.sitename {
    color: var(--accent-color) !important;
}

/* Scroll Image Solution */

/* Make main image container allow vertical scroll */
.main-image-container,
.image-zoom-container {
    touch-action: pan-y !important;
    /* Allow vertical scrolling */
    -ms-touch-action: pan-y !important;
    /* For old IE/Edge */
}

/* Prevent Swiper from blocking vertical scroll */
.swiper,
.swiper-wrapper {
    touch-action: pan-y !important;
    -ms-touch-action: pan-y !important;
}

@media (max-width: 768px) {
    .main-image-container {
        pointer-events: none !important;
    }
}

/* Login */
.google-icon {
    background: url('/static/homepage/assets/btn_google_light_normal_ios.svg') transparent 5px 50% no-repeat;
    display: inline-block;
    width: 46px;
    height: 46px;
    display: inline-block;
    vertical-align: middle;
}

.g-icon-text {
    vertical-align: middle;
}

/* Buttons */

.btn-primary {
    width: auto;
    background-color: var(--site-primary-color);
    --bs-btn-bg: var(--site-primary-color);
    --bs-btn-border-color: var(--site-primary-color);
    --bs-btn-hover-color: var(--site-uncolored-text);
    --bs-btn-hover-bg: var(--site-primary-hover);
    --bs-btn-hover-border-color: var(--site-primary-color);
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    --bs-btn-active-color: var(--site-uncolored-text);
    --bs-btn-active-bg: var(--site-primary-color);
    --bs-btn-active-border-color: var(--site-primary-color);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: var(--site-uncolored-text);
    --bs-btn-disabled-bg: var(--site-primary-color);
    --bs-btn-disabled-border-color: var(--site-primary-color);
    transition: 0.3s;
}


/* Spinner */
#spinner {
    animation: rotateSpinner 1s infinite linear;
}

@keyframes rotateSpinner {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* Like Attenton */
@keyframes glowZoom {

    0% {
        filter: drop-shadow(0 0 0px var(--accent-color));
        transform: scale(1);
    }

    50% {
        filter: drop-shadow(0 0 8px var(--accent-color));
        transform: scale(1.2);
        /* slight zoom */
    }

    100% {
        filter: drop-shadow(0 0 0px var(--accent-color));
        transform: scale(1);
    }
}

.attention {
    animation: glowZoom 0.9s ease-in-out;
    animation-iteration-count: 10;
    display: inline-block;
}

.copy-link.copied i {
    animation: spin 0.6s ease-out;
}

/* Tooltip generated with ::after so no extra markup needed */
.copy-link.copied::after {
    content: "Ok!";
    position: absolute;
    top: -0.7rem;
    left: 50%;
    transform: translateX(-50%) translateY(0);
    padding: 0.15rem 0.5rem;
    font-size: 0.75rem;
    background: var(--site-primary-color);
    color: #fff;
    border-radius: 4px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    animation: rise-fade 1.5s forwards;
    z-index: 10;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes rise-fade {
    0% {
        opacity: 0;
        transform: translate(-50%, 4px);
    }

    15% {
        opacity: 1;
        transform: translate(-50%, -2px);
    }

    85% {
        opacity: 1;
        transform: translate(-50%, -14px);
    }

    100% {
        opacity: 0;
        transform: translate(-50%, -18px);
    }
}

/* Blog post images */
img.note-float-right {
    float: right !important;
    margin-left: 10px !important;
    margin-bottom: 10px !important;
    margin-top: 5%;
}

img.note-float-left {
    float: left !important;
    margin-right: 10px !important;
    margin-bottom: 10px !important;
    margin-top: 5%;
}

.content img {
    border-radius: 30px !important;
}

.note-video-clip {
    width: 100% !important;
    border-radius: 15px !important;
}