/*
==========================================================
- Theme Style
==========================================================
*/

/* -------------------------------------------------------
   CSS Variables — Notout Color Palette
------------------------------------------------------- */
:root {
    --notout-dark:        #011d10;
    --notout-footer-bg:   #091a14;
    --notout-header-bg:   rgba(2, 28, 16, 0.92);
    --notout-accent:      #f0f812;
    --notout-heading:     #9ae600;
    --notout-text:        #ffffff;
    --notout-text-muted:  rgba(255, 255, 255, 0.65);
    --notout-border:      rgba(255, 255, 255, 0.08);
}

/* -------------------------------------------------------
   HEADER
------------------------------------------------------- */
.notout-header {
    position: sticky;
    top: 0;
    z-index: 10000;
    width: 100%;
}

/* Main Menu Style */
.navbar-toggler {
    border: 1px solid rgba(0,0,0,0.09);
}
.notout-navbar {
    position: relative;
    width: 100%;
    z-index: 10000;
    display: flex;
    align-items: center;
    min-height: 68px;
    background: var(--notout-header-bg);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--notout-border);
}
.notout-menu-wrap {
    width: 100%;
    height: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.notout-navbar-brand {
    flex-shrink: 0;
    line-height: 0;
}
.notout-navbar-brand img,
.notout-navbar-brand .custom-logo {
    display: block;
    height: 38px;
    width: auto;
    max-width: none;
}
.notout-main-menu {
    padding: 0;
    margin: 0;
    list-style: none;
}
.notout-main-menu li {
    position: relative;
    display: inline-block;
    padding: 0;
    margin: 0;
    z-index: 100;
}
.notout-main-menu li a {
    display: block;
    padding: 20px 15px;
}
.notout-main-menu li > .sub-menu {
    display: none;
    position: absolute;
    top: 64px;
    left: 0px;
    z-index: 10;
    padding: 0px;
    margin: 0px;
    width: 225px;
    background: #f1f1f1;
}
.notout-main-menu li > .sub-menu li {
    display: block;
    position: relative;
    z-index: 0;
}
.notout-main-menu li > .sub-menu li a {
    display: block;
    text-decoration: none;
    padding: 10px 15px;
    line-height: 1.5;
    border-bottom: 1px solid rgba(255,255,255, 0.7);
}
.notout-main-menu li > .sub-menu li ul.sub-menu {
    display: block;
    position: absolute;
    width: 225px;
    left: 100%;
    top: 0%;
    z-index: 1;
    list-style: none;
    padding: 0px;
    margin: 0px;
    background-color: #f1f1f1;
}
.open {
    display: block !important;
}
.hide {
    display: none !important;
}
.fixed-to-top {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100000;
    /* transition: all 0.3s ease-in-out; */
}
.notout-main-menu .menu-item-has-children {
    padding-right: 10px;
}
.notout-main-menu > .menu-item-has-children:after {
    content: "\f078";
    position: absolute;
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 12px;
    line-height: 1;
    right: 0;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
    width: 10px;
}
.notout-main-menu > .menu-item-has-children:hover::after {
    content: "\f077";
}
.notout-main-menu > li ul.sub-menu .menu-item-has-children:after {
    content: "\f054";
    position: absolute;
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 12px;
    line-height: 1;
    right: 0;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
    width: 10px;
}
.notout-main-menu > li ul.sub-menu .menu-item-has-children:hover::after {
    content: "\f053";
}
.notout-main-menu > li ul.sub-menu li.menu-item-has-children:after {
    right: 10px;
}
.notout-navbar-toggler,
.notout-main-menu li .mb-toggle {
    display: none;
}
.mb-toggle .dashicons {
    margin: 50%;
    transform: translate(-50%, -50%);
}
.current-menu-item > a {
    color: #222;
    font-weight: 500;
}
/* Portrait and Landscape */
@media only screen
and (max-width: 1080px) {
    .notout-navbar {
        background-color: #303030;
    }
    .notout-navbar .container {
        padding: 0;
    }
    .notout-brand-wrap {
        padding: 0 15px;
    }
    a.notout-navbar-brand {
        font-weight: 600;
    }
    a.notout-navbar-brand,
    a.notout-navbar-brand:visited,
    .notout-navbar-toggler {
        color: #fff
    }
    .notout-brand-wrap {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        height: 60px;
        border-bottom: 1px solid rgba(255,255,255, 0.7);
    }
    .notout-navbar-toggler {
        display: block;
        width: 40px;
        height: 40px;
        text-align: center;
        line-height: 40px;
        border: none;
    }
    .notout-main-menu {
        display: none;
        width: 100%;
        padding: 0 15px;
        background: #f1f1f1;
    }
    .notout-main-menu > li {
        display: block;
        border-bottom: 1px solid rgba(255,255,255, 0.7);
    }
    .notout-main-menu li a {
        padding: 10px 0px;
    }
    .notout-main-menu .menu-item-has-children:after {
        display: none;
    }
    .notout-main-menu li .mb-toggle {
        display: block;
        position: absolute;
        width: 40px;
        height: 40px;
        color: #333;
        text-align: center;
        line-height: 2.5;
        top: 2px;
        right: 0px;
    }
    .notout-main-menu li ul {
        position: relative;
        width: 100%;
        padding: 0;
        margin: 0;
    }
    .notout-main-menu li ul li {
        display: block;
        position: relative;
    }
    .notout-main-menu > li ul.sub-menu {
        display: none;
        width: 100%;
        position: relative;
        top: 0;
        background-color: #fff;
        padding: 0px 0px 0px 10px;
    }
    .notout-main-menu > li ul.sub-menu > li {
        border-bottom: 1px solid rgba(0,0,0,0.05);
    }
    .notout-main-menu > li ul.sub-menu li:first-child {
        border-top: 1px solid rgba(0,0,0,0.05);
    }
    .notout-main-menu > li ul.sub-menu > li:last-child {
        border: 0;
    }
    .notout-main-menu > li ul.sub-menu > li:only-child {
        border-top: 1px solid rgba(0,0,0,0.05);
    }
    .notout-main-menu li > .sub-menu li ul.sub-menu {
        position: relative;
        top: 0;
        left: 0;
        width: 100%;
        background-color: #fff;
        padding: 0px 0px 0px 10px;
    }
    .notout-main-menu .menu-item-has-children {
        padding-right: 0;
    }
    .notout-main-menu li > .sub-menu li a {
        padding: 10px 0px;
    }

    .notout-navbar-toggler::after {
        content: '';
        width: 24px;
        height: 2px;
        background-color:#dadada;
        position: absolute;
        left: 0;
        top: 15px;
    }
    .notout-navbar-toggler::after {
        content: '';
        width: 24px;
        height: 2px;
        background-color:#dadada;
        position: absolute;
        left: 0;
        top: 15px;
    }
    .notout-navbar-toggler i::after {
        content: '';
        width: 24px;
        height: 2px;
        background-color:#dadada;
        position: absolute;
        left: 0;
        top: 7px;
    }
    .notout-navbar-toggler::before {
        content: '';
        width: 24px;
        height: 2px;
        background-color:#dadada;
        position: absolute;
        left: 0;
        top: 0;
    }
    .notout-navbar-toggler i::before {
        visibility: hidden;
    }
    .notout-navbar-toggler {
        display: block;
        right: 10px;
        top: 20px;
        width: 24px;
        position: absolute;
        cursor: pointer;
        border: 0;
        color: #dadada;
        z-index: 9;
        width: 36px;
        padding: 2px;
    }
    .notout-navbar-toggler,
    .notout-navbar-toggler:before,
    .notout-navbar-toggler:after,
    .notout-navbar-toggler.js-hide-nav:before,
    .notout-navbar-toggler.js-hide-nav:after {
        -webkit-transition: all 200ms ease;
        -moz-transition: all 200ms ease;
        -ms-transition: all 200ms ease;
        -o-transition: all 200ms ease;
        transition: all 200ms ease;
    }
    .notout-navbar-toggler.js-hide-nav:before {
        moz-transform: rotate(45deg) translateX(6px) translateY(6px);
        -webkit-transform: rotate(45deg) translateX(6px) translateY(6px);
        -o-transform: rotate(45deg) translateX(6px) translateY(6px);
        -ms-transform: rotate(45deg) translateX(6px) translateY(6px);
        transform: rotate(45deg) translateX(6px) translateY(6px);
    }
    .notout-navbar-toggler.js-hide-nav:after {
        -moz-transform: rotate(-45deg) translateX(5px) translateY(-5px);
        -webkit-transform: rotate(-45deg) translateX(5px) translateY(-5px);
        -o-transform: rotate(-45deg) translateX(5px) translateY(-5px);
        -ms-transform: rotate(-45deg) translateX(5px) translateY(-5px);
        transform: rotate(-45deg) translateX(5px) translateY(-5px);
    }
    .notout-navbar-toggler.js-hide-nav i:after {
        visibility: hidden;
    }
}

/* -------------------------------------------------------
   HEADER — Notout Color Overrides
------------------------------------------------------- */

/* Nav links */
.notout-main-menu li a {
    color: var(--notout-text);
    font-size: 15px;
    font-weight: 500;
    text-decoration: none;
    transition: color 0.2s ease;
}
.notout-main-menu li a:hover,
.notout-main-menu li.current-menu-item > a,
.notout-main-menu li.current_page_item > a {
    color: var(--notout-accent);
}

/* Dropdown */
.notout-main-menu li > .sub-menu {
    background: var(--notout-dark);
    border: 1px solid var(--notout-border);
    border-top: 2px solid var(--notout-accent);
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.notout-main-menu li > .sub-menu li a {
    color: var(--notout-text-muted);
    border-bottom: 1px solid var(--notout-border);
    transition: color 0.2s, background 0.2s;
}
.notout-main-menu li > .sub-menu li a:hover {
    color: var(--notout-accent);
    background: rgba(240, 248, 18, 0.06);
}
.notout-main-menu li > .sub-menu li ul.sub-menu {
    background: var(--notout-dark);
}

/* Mobile toggler */
.notout-navbar-toggler {
    background: transparent;
    color: var(--notout-text);
    border: none;
    border-radius: 4px;
    padding: 6px 10px;
    font-size: 18px;
    line-height: 1;
}

/* CTA Button */
.notout-header-cta {
    flex-shrink: 0;
}
.notout-btn-cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 20px;
    background: var(--notout-accent);
    color: var(--notout-dark);
    font-size: 14px;
    font-weight: 700;
    border-radius: 6px;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.2s ease, transform 0.1s ease;
    border: 2px solid var(--notout-accent);
}
.notout-btn-cta:hover {
    background: transparent;
    color: var(--notout-accent);
    text-decoration: none;
}

/* -------------------------------------------------------
   FOOTER — Notout Style
------------------------------------------------------- */
.notout-footer {
    background: var(--notout-footer-bg);
    color: var(--notout-text-muted);
    font-size: 15px;
}

/* Footer Main Section */
.notout-footer-main {
    padding: 64px 0 40px;
    border-bottom: 1px solid var(--notout-border);
}

.notout-footer-col {
    margin-bottom: 32px;
}

/* Footer Brand */
.notout-footer-brand {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.notout-footer-logo img {
    max-height: 50px;
    width: auto;
}
.notout-footer-desc {
    color: var(--notout-text-muted);
    line-height: 1.7;
    margin: 0;
}

/* Footer Social Icons */
.notout-social-links {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 4px;
}
.notout-social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
    color: var(--notout-text-muted);
    font-size: 15px;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}
.notout-social-link:hover {
    background: var(--notout-accent);
    color: var(--notout-dark);
    text-decoration: none;
}

/* Footer Headings */
.notout-footer-heading {
    color: var(--notout-heading);
    font-size: 17px;
    font-weight: 700;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--notout-border);
}

/* Footer Nav Menus */
.notout-footer-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}
.notout-footer-menu li {
    border-bottom: 1px solid var(--notout-border);
}
.notout-footer-menu li:last-child {
    border-bottom: none;
}
.notout-footer-menu li a {
    display: block;
    padding: 9px 0;
    color: var(--notout-text-muted);
    text-decoration: none;
    transition: color 0.2s, padding-left 0.2s;
}
.notout-footer-menu li a:hover {
    color: var(--notout-accent);
    padding-left: 6px;
}

/* Footer Bottom / Copyright */
.notout-footer-bottom {
    padding: 18px 0;
}
.notout-copyright {
    color: var(--notout-text-muted);
    font-size: 14px;
    margin: 0;
}
.notout-copyright a {
    color: var(--notout-text);
    text-decoration: none;
    font-weight: 600;
}
.notout-copyright a:hover {
    color: var(--notout-accent);
}

/* -------------------------------------------------------
   PROMOTIONS ARCHIVE PAGE
------------------------------------------------------- */
.notout-promotions-page {
    background:
        radial-gradient(ellipse 80% 50% at 50% -10%, rgba(154,230,0,0.07) 0%, transparent 65%),
        radial-gradient(ellipse 60% 40% at 90% 80%, rgba(240,248,18,0.04) 0%, transparent 55%),
        var(--notout-dark);
    min-height: 60vh;
    padding: 56px 0 80px;
}

/* Page Header */
.notout-promo-page-header {
    text-align: center;
    margin-bottom: 44px;
}
.notout-promo-page-title {
    color: var(--notout-text);
    font-size: 38px;
    font-weight: 800;
    letter-spacing: -0.5px;
    margin: 0 0 14px;
    line-height: 1.15;
    position: relative;
    display: inline-block;
    padding-bottom: 18px;
}
.notout-promo-page-title::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 72px;
    height: 3px;
    border-radius: 2px;
    background: linear-gradient(90deg, var(--notout-heading) 0%, var(--notout-accent) 100%);
}
.notout-promo-page-subtitle {
    color: var(--notout-text-muted);
    font-size: 15px;
    margin: 0;
    letter-spacing: 0.2px;
}

/* Category Filter Tabs */
.notout-promo-tabs-wrap {
    margin-bottom: 36px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.notout-promo-tabs-wrap::-webkit-scrollbar {
    display: none;
}
.notout-promo-tabs {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
    padding-bottom: 4px;
}
.notout-promo-tab {
    display: inline-block;
    padding: 9px 22px;
    border-radius: 50px;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
    text-decoration: none;
    color: var(--notout-text-muted);
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
    cursor: pointer;
    letter-spacing: 0.3px;
}
.notout-promo-tab:hover {
    color: var(--notout-text);
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.18);
    text-decoration: none;
}
.notout-promo-tab.active {
    background: linear-gradient(135deg, var(--notout-heading) 0%, var(--notout-accent) 100%);
    color: var(--notout-dark);
    border-color: transparent;
    font-weight: 700;
    box-shadow: 0 0 20px rgba(154,230,0,0.35);
}

/* Cards Grid */
.notout-promo-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 40px;
}

/* Loading Spinner */
.notout-promo-spinner {
    grid-column: 1 / -1;
    text-align: center;
    padding: 60px 0;
    color: var(--notout-accent);
    font-size: 36px;
}
.notout-promo-loading {
    min-height: 200px;
}

/* Empty State */
.notout-promo-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 80px 0;
    color: var(--notout-text-muted);
}
.notout-promo-empty i {
    font-size: 52px;
    display: block;
    margin-bottom: 18px;
    color: rgba(255,255,255,0.12);
}

/* Promotion Card */
.notout-promo-card {
    position: relative;
    background: rgba(255,255,255,0.025);
    border-radius: 14px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    box-shadow: 0 2px 16px rgba(0,0,0,0.25);
}
/* Gradient border via mask technique */
.notout-promo-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 14px;
    padding: 1px;
    background: linear-gradient(135deg, rgba(154,230,0,0.35) 0%, rgba(255,255,255,0.04) 50%, rgba(240,248,18,0.25) 100%);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    transition: background 0.3s ease;
    z-index: 1;
}
.notout-promo-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.45), 0 0 0 1px rgba(154,230,0,0.08);
}
.notout-promo-card:hover::before {
    background: linear-gradient(135deg, rgba(154,230,0,0.65) 0%, rgba(255,255,255,0.08) 50%, rgba(240,248,18,0.5) 100%);
}

/* Card Image */
.notout-promo-card-img {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    background: rgba(255,255,255,0.03);
    flex-shrink: 0;
}
.notout-promo-card-img a {
    display: block;
    width: 100%;
    height: 100%;
}
.notout-promo-thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.45s ease;
}
.notout-promo-card:hover .notout-promo-thumb {
    transform: scale(1.06);
}
.notout-promo-no-thumb {
    width: 100%;
    height: 100%;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    overflow: hidden;
    /* default fallback gradient */
    background: linear-gradient(135deg, #1a4a25 0%, #0a1e0f 100%);
}
/* Per-category gradient backgrounds */
.notout-promo-no-thumb--welcome-offer { background: linear-gradient(140deg, #2a3a00 0%, #1c2800 40%, #0d1a00 100%); }
.notout-promo-no-thumb--slots         { background: linear-gradient(140deg, #2a0050 0%, #18003a 40%, #0a0020 100%); }
.notout-promo-no-thumb--live-casino   { background: linear-gradient(140deg, #3a0a00 0%, #280600 40%, #140200 100%); }
.notout-promo-no-thumb--sports        { background: linear-gradient(140deg, #00203a 0%, #001428 40%, #000b18 100%); }
.notout-promo-no-thumb--fishing       { background: linear-gradient(140deg, #003028 0%, #001e18 40%, #000e0c 100%); }
.notout-promo-no-thumb--lottery       { background: linear-gradient(140deg, #2e1800 0%, #1e0e00 40%, #100600 100%); }
.notout-promo-no-thumb--table         { background: linear-gradient(140deg, #200040 0%, #140028 40%, #0a0018 100%); }
.notout-promo-no-thumb--arcade        { background: linear-gradient(140deg, #3a0020 0%, #280015 40%, #14000a 100%); }
.notout-promo-no-thumb--crash         { background: linear-gradient(140deg, #3a0000 0%, #260000 40%, #120000 100%); }
.notout-promo-no-thumb--kyc           { background: linear-gradient(140deg, #1a2028 0%, #101418 40%, #080c10 100%); }
.notout-promo-no-thumb--normal        { background: linear-gradient(140deg, #002040 0%, #001428 40%, #000a18 100%); }
.notout-promo-no-thumb--other         { background: linear-gradient(140deg, #0a2800 0%, #061800 40%, #020c00 100%); }

/* Decorative circles */
.notout-promo-no-thumb-dec {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}
.notout-promo-no-thumb-dec--tl {
    width: 120px;
    height: 120px;
    top: -30px;
    left: -30px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
}
.notout-promo-no-thumb-dec--br {
    width: 90px;
    height: 90px;
    bottom: -20px;
    right: -20px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.05);
}

/* Category icon */
.notout-promo-no-thumb-icon {
    position: relative;
    z-index: 2;
    font-size: 52px;
    line-height: 1;
    filter: drop-shadow(0 4px 16px rgba(0,0,0,0.6));
    transition: transform 0.35s ease;
}
/* Per-category icon accent colors */
.notout-promo-no-thumb--welcome-offer .notout-promo-no-thumb-icon { color: #f0f812; }
.notout-promo-no-thumb--slots         .notout-promo-no-thumb-icon { color: #cc66ff; }
.notout-promo-no-thumb--live-casino   .notout-promo-no-thumb-icon { color: #ff6644; }
.notout-promo-no-thumb--sports        .notout-promo-no-thumb-icon { color: #44aaff; }
.notout-promo-no-thumb--fishing       .notout-promo-no-thumb-icon { color: #33ddaa; }
.notout-promo-no-thumb--lottery       .notout-promo-no-thumb-icon { color: #ffaa33; }
.notout-promo-no-thumb--table         .notout-promo-no-thumb-icon { color: #aa77ff; }
.notout-promo-no-thumb--arcade        .notout-promo-no-thumb-icon { color: #ff5588; }
.notout-promo-no-thumb--crash         .notout-promo-no-thumb-icon { color: #ff4444; }
.notout-promo-no-thumb--kyc           .notout-promo-no-thumb-icon { color: #99aacc; }
.notout-promo-no-thumb--normal        .notout-promo-no-thumb-icon { color: #55aaff; }
.notout-promo-no-thumb--other         .notout-promo-no-thumb-icon { color: #9ae600; }

.notout-promo-card:hover .notout-promo-no-thumb-icon {
    transform: scale(1.12);
}

/* Category label text */
.notout-promo-no-thumb-label {
    position: relative;
    z-index: 2;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.45);
}
/* Bottom gradient overlay on image */
.notout-promo-card-img::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(1,29,16,0.85) 0%, transparent 55%);
    pointer-events: none;
    z-index: 1;
}

/* Hover overlay CTA — hidden */
.notout-promo-card-overlay {
    display: none;
}
.notout-promo-claim-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 11px 26px;
    background: linear-gradient(135deg, #f0f812 0%, #c8e000 100%);
    color: var(--notout-dark);
    font-size: 13px;
    font-weight: 800;
    border-radius: 50px;
    text-decoration: none;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    box-shadow: 0 4px 16px rgba(240,248,18,0.4);
}
.notout-promo-claim-btn:hover {
    transform: scale(1.04);
    box-shadow: 0 6px 24px rgba(240,248,18,0.55);
    text-decoration: none;
    color: var(--notout-dark);
}

/* Badge */
.notout-promo-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background: linear-gradient(135deg, var(--notout-heading) 0%, var(--notout-accent) 100%);
    color: var(--notout-dark);
    font-size: 10px;
    font-weight: 800;
    padding: 4px 12px;
    border-radius: 50px;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    z-index: 4;
    transform: rotate(-2deg);
    box-shadow: 0 3px 12px rgba(0,0,0,0.4), 0 0 8px rgba(154,230,0,0.3);
}

/* Card Body */
.notout-promo-card-body {
    padding: 18px 20px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
    position: relative;
    z-index: 2;
}

/* Category Chips */
.notout-promo-cats {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.notout-promo-cat {
    display: inline-block;
    background: rgba(154,230,0,0.1);
    color: rgba(154,230,0,0.75);
    font-size: 10px;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 50px;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    border: 1px solid rgba(154,230,0,0.15);
}

/* Dates */
.notout-promo-dates {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--notout-text-muted);
}
.notout-promo-dates i {
    font-size: 10px;
    flex-shrink: 0;
    color: rgba(154,230,0,0.5);
}

/* Card Title */
.notout-promo-card-title {
    margin: 0;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.4;
    flex: 1;
}
.notout-promo-card-title a {
    color: var(--notout-text);
    text-decoration: none;
    transition: color 0.2s;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.notout-promo-card-title a:hover {
    color: var(--notout-accent);
}

/* Divider */
.notout-promo-divider {
    border: none;
    border-top: 1px solid rgba(255,255,255,0.08);
    margin: 4px 0 2px;
}

/* Read More */
.notout-promo-readmore {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 700;
    color: var(--notout-heading);
    text-decoration: none;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    transition: color 0.2s, gap 0.2s;
}
.notout-promo-readmore:hover {
    color: var(--notout-accent);
    text-decoration: underline;
    gap: 9px;
}
.notout-promo-readmore i {
    font-size: 9px;
    transition: transform 0.2s;
}
.notout-promo-readmore:hover i {
    transform: translateX(2px);
}

/* Pagination Footer */
.notout-promo-footer-separator {
    border: none;
    border-top: 1px solid rgba(255,255,255,0.07);
    margin: 0 0 24px;
}
.notout-promo-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.notout-promo-records {
    color: var(--notout-text-muted);
    font-size: 13px;
    letter-spacing: 0.2px;
}

/* Load More Button */
.notout-btn-loadmore {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 44px;
    background: linear-gradient(135deg, var(--notout-heading) 0%, var(--notout-accent) 100%);
    color: var(--notout-dark);
    font-size: 14px;
    font-weight: 800;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    letter-spacing: 0.4px;
    transition: box-shadow 0.25s ease, transform 0.2s ease, opacity 0.2s;
    text-decoration: none;
    box-shadow: 0 4px 20px rgba(154,230,0,0.25);
}
.notout-btn-loadmore:hover {
    box-shadow: 0 6px 28px rgba(154,230,0,0.45);
    transform: translateY(-1px);
}
.notout-btn-loadmore:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* Page Nav */
.notout-promo-pagnav {
    display: flex;
    align-items: center;
    gap: 8px;
}
.notout-promo-pagnav-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.12);
    color: var(--notout-text);
    font-size: 18px;
    line-height: 1;
    text-decoration: none;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.notout-promo-pagnav-btn:hover {
    background: linear-gradient(135deg, var(--notout-heading) 0%, var(--notout-accent) 100%);
    border-color: transparent;
    color: var(--notout-dark);
    text-decoration: none;
}
.notout-promo-pagnav-btn.disabled {
    opacity: 0.25;
    cursor: not-allowed;
    pointer-events: none;
}
.notout-promo-pagnav-info {
    color: var(--notout-text-muted);
    font-size: 13px;
    white-space: nowrap;
    padding: 0 4px;
}

/* ═══════════════════════════════════════════════════════
   SINGLE PROMOTION — PREMIUM LAYOUT  (nsp-*)
═══════════════════════════════════════════════════════ */

/* Page wrapper */
.nsp-page { background: var(--notout-dark); }

/* ── TOP BAR (breadcrumb) ─────────────────────────── */
.nsp-topbar {
    background: rgba(0,0,0,.35);
    border-bottom: 1px solid rgba(255,255,255,.06);
    padding: 11px 0;
}

/* Breadcrumb */
.nsp-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(255,255,255,.45);
}
.nsp-breadcrumb a {
    color: rgba(255,255,255,.45);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: color .2s;
}
.nsp-breadcrumb a:hover { color: var(--notout-heading); }
.nsp-breadcrumb__sep { font-size: 9px; color: rgba(255,255,255,.2); }
.nsp-breadcrumb > span { color: rgba(255,255,255,.65); }

/* ── FULL IMAGE SHOWCASE ──────────────────────────── */
.nsp-imgbox {
    background: #061510;
    line-height: 0; /* collapse whitespace around img */
}
/* Category-specific fallback bg colour (no image) */
.nsp-imgbox--cat-welcome-offer { background-color: #151f00; }
.nsp-imgbox--cat-slots         { background-color: #0e0020; }
.nsp-imgbox--cat-live-casino   { background-color: #1a0300; }
.nsp-imgbox--cat-sports        { background-color: #001428; }
.nsp-imgbox--cat-fishing       { background-color: #001e18; }
.nsp-imgbox--cat-lottery       { background-color: #1a0c00; }
.nsp-imgbox--cat-table         { background-color: #110028; }
.nsp-imgbox--cat-arcade        { background-color: #200010; }
.nsp-imgbox--cat-crash         { background-color: #200000; }
.nsp-imgbox--cat-kyc           { background-color: #0c1018; }
.nsp-imgbox--cat-normal        { background-color: #00101e; }
.nsp-imgbox--cat-other         { background-color: #061400; }

.nsp-imgbox__wrap {
    position: relative;
    overflow: hidden;
    max-height: 560px;
}

/* Actual image — full width, natural ratio, clamped height */
.nsp-imgbox__photo {
    display: block;
    width: 100%;
    height: auto;
    max-height: 560px;
    object-fit: cover;
    object-position: center top;
    line-height: 0;
}

/* No-image fallback */
.nsp-imgbox__no-img {
    min-height: 340px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.nsp-imgbox__no-img-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    color: rgba(255,255,255,.18);
}
.nsp-imgbox__no-img-inner i  { font-size: 64px; }
.nsp-imgbox__no-img-inner span {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

/* Badge pill — top left */
.nsp-imgbox__badge {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 14px;
    background: var(--notout-accent);
    color: #011d10;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    border-radius: 5px;
    box-shadow: 0 4px 16px rgba(240,248,18,.4);
    line-height: 1.4;
}

/* Status pill — top right */
.nsp-imgbox__status {
    position: absolute;
    top: 16px;
    right: 16px;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 5px 14px;
    border-radius: 50px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    border: 1px solid;
    backdrop-filter: blur(8px);
    line-height: 1.4;
}
.nsp-imgbox__status--active  { color: #9ae600; border-color: rgba(154,230,0,.35); background: rgba(1,29,16,.72); }
.nsp-imgbox__status--expired { color: rgba(255,255,255,.4); border-color: rgba(255,255,255,.12); background: rgba(0,0,0,.55); }

/* Bottom overlay — categories + date */
.nsp-imgbox__bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 4;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 20px 20px 18px;
    background: linear-gradient(to top, rgba(1,29,16,.92) 0%, rgba(1,29,16,.6) 60%, transparent 100%);
    line-height: 1.4;
}
.nsp-imgbox__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.nsp-imgbox__date {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 12px;
    color: rgba(255,255,255,.65);
}
.nsp-imgbox__date i { color: var(--notout-heading); font-size: 11px; }

/* Status dot (shared) */
.nsp-status-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: currentColor;
    flex-shrink: 0;
}
.nsp-imgbox__status--active .nsp-status-dot {
    box-shadow: 0 0 8px currentColor;
    animation: nsp-dot-blink 2s ease-in-out infinite;
}
@keyframes nsp-dot-blink { 0%,100%{opacity:1} 50%{opacity:.35} }

/* ── TITLE CARD ───────────────────────────────────── */
.nsp-title-card {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 14px;
    overflow: hidden;
    margin-bottom: 24px;
}
.nsp-title-card__accent-bar {
    height: 3px;
    background: linear-gradient(90deg, var(--notout-accent) 0%, var(--notout-heading) 100%);
}
.nsp-title-card__inner {
    padding: 28px 28px 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.nsp-title-card__title {
    font-size: clamp(22px, 3vw, 36px);
    font-weight: 900;
    color: #fff;
    line-height: 1.12;
    letter-spacing: -.02em;
    margin: 0;
}
.nsp-title-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px;
}
.nsp-title-card__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    padding-top: 4px;
}

/* Shared action buttons (used in title card) */
.nsp-hero__date {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(255,255,255,.55);
}
.nsp-hero__date i { color: var(--notout-heading); font-size: 12px; }
.nsp-hero__status {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 4px 14px;
    border-radius: 50px;
    border: 1px solid;
}
.nsp-hero__status--active  { color: #9ae600; border-color: rgba(154,230,0,.3); background: rgba(154,230,0,.07); }
.nsp-hero__status--expired { color: rgba(255,255,255,.35); border-color: rgba(255,255,255,.1); background: rgba(255,255,255,.03); }
.nsp-hero__status--active .nsp-status-dot {
    box-shadow: 0 0 8px currentColor;
    animation: nsp-dot-blink 2s ease-in-out infinite;
}
.nsp-hero__cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 13px 28px;
    background: linear-gradient(135deg, var(--notout-accent) 0%, var(--notout-heading) 100%);
    color: #011d10;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .07em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 9px;
    box-shadow: 0 6px 24px rgba(240,248,18,.35);
    transition: transform .25s, box-shadow .25s;
    animation: nsp-cta-glow 3s ease-in-out infinite;
}
@keyframes nsp-cta-glow {
    0%,100% { box-shadow: 0 6px 24px rgba(240,248,18,.35); }
    50%     { box-shadow: 0 8px 38px rgba(240,248,18,.6); }
}
.nsp-hero__cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 36px rgba(240,248,18,.55);
    color: #011d10;
    text-decoration: none;
}
.nsp-hero__back-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 9px;
    color: rgba(255,255,255,.6);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    background: rgba(255,255,255,.04);
    backdrop-filter: blur(8px);
    transition: all .25s;
}
.nsp-hero__back-btn:hover {
    border-color: rgba(154,230,0,.3);
    color: var(--notout-heading);
    background: rgba(154,230,0,.06);
    text-decoration: none;
}

/* ── INFO STRIP ───────────────────────────────────── */
.nsp-info-strip {
    background: rgba(255,255,255,.022);
    border-top: 1px solid rgba(154,230,0,.12);
    border-bottom: 1px solid rgba(255,255,255,.05);
}
.nsp-info-strip__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
}
.nsp-info-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 18px 26px;
    flex: 1 1 auto;
}
.nsp-info-item__icon {
    font-size: 16px;
    color: var(--notout-heading);
    flex-shrink: 0;
    width: 18px;
    text-align: center;
}
.nsp-icon--active  { color: var(--notout-heading); }
.nsp-icon--expired { color: rgba(255,255,255,.2); }
.nsp-info-item > div { display: flex; flex-direction: column; gap: 2px; }
.nsp-info-item__label {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255,255,255,.3);
}
.nsp-info-item__value {
    font-size: 12px;
    font-weight: 600;
    color: rgba(255,255,255,.75);
}
.nsp-info-item__value--accent  { color: var(--notout-accent); }
.nsp-info-item__value--active  { color: var(--notout-heading); }
.nsp-info-item__value--expired { color: rgba(255,255,255,.3); }
.nsp-info-divider {
    width: 1px;
    background: rgba(255,255,255,.06);
    align-self: stretch;
    flex-shrink: 0;
}

/* ── BODY ─────────────────────────────────────────── */
.nsp-body { padding: 56px 0 80px; }
.nsp-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 30px;
    align-items: start;
}

/* ── CONTENT CARD ─────────────────────────────────── */
.nsp-content-card {
    background: rgba(255,255,255,.025);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 16px;
    overflow: hidden;
}
.nsp-content-card__header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 18px 28px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.02);
}
.nsp-content-card__header i  { color: var(--notout-heading); font-size: 14px; }
.nsp-content-card__header h2 { margin:0; font-size:13px; font-weight:700; letter-spacing:.05em; color:rgba(255,255,255,.55); }
.nsp-content-card__body { padding: 32px 36px; }

/* Content typography */
.nsp-content {
    color: rgba(255,255,255,.68);
    font-size: 15px;
    line-height: 1.9;
}
.nsp-content p               { margin-bottom: 1.2em; color: inherit; }
.nsp-content p:last-child    { margin-bottom: 0; }
.nsp-content h2,.nsp-content h3,.nsp-content h4 { color:#fff; margin: 1.8em 0 .5em; font-weight:700; }
.nsp-content h2              { font-size:21px; }
.nsp-content h3              { font-size:17px; }
.nsp-content ul,.nsp-content ol { padding-left:22px; margin-bottom:1.2em; }
.nsp-content li              { margin-bottom:.35em; }
.nsp-content a               { color:var(--notout-heading); text-decoration:none; }
.nsp-content a:hover         { color:var(--notout-accent); }
.nsp-content img             { max-width:100%; border-radius:10px; margin:1em 0; }
.nsp-content strong          { color:#fff; font-weight:700; }
.nsp-content blockquote {
    border-left: 3px solid var(--notout-heading);
    padding: 12px 20px;
    margin: 1.5em 0;
    background: rgba(154,230,0,.04);
    border-radius: 0 8px 8px 0;
    font-style: italic;
    color: rgba(255,255,255,.6);
}

/* ── SIDEBAR WIDGETS ──────────────────────────────── */
.nsp-sidebar {
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: sticky;
    top: 24px;
}
.nsp-widget {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 16px;
    padding: 22px 24px;
    position: relative;
    overflow: hidden;
}
.nsp-widget__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
}
.nsp-widget__header i  { color:var(--notout-heading); font-size:14px; }
.nsp-widget__header h3 { margin:0; font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.5); }

/* Countdown */
.nsp-widget--countdown {
    background: rgba(154,230,0,.04);
    border-color: rgba(154,230,0,.14);
}
.nsp-widget--countdown::before {
    content:'';
    position:absolute;
    top:0; left:0; right:0;
    height:2px;
    background:linear-gradient(90deg, transparent, var(--notout-heading), var(--notout-accent), transparent);
}
.nsp-countdown {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.nsp-cd-box {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    background: rgba(0,0,0,.28);
    border: 1px solid rgba(154,230,0,.14);
    border-radius: 10px;
    padding: 14px 4px 10px;
}
.nsp-cd-val {
    font-size: 26px;
    font-weight: 900;
    color: var(--notout-accent);
    line-height: 1;
    font-variant-numeric: tabular-nums;
    letter-spacing: -.02em;
    text-shadow: 0 0 20px rgba(240,248,18,.4);
}
.nsp-cd-label {
    font-size: 8px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255,255,255,.28);
}
.nsp-cd-sep {
    font-size: 20px;
    font-weight: 700;
    color: rgba(154,230,0,.35);
    padding-bottom: 16px;
    flex-shrink: 0;
}
.nsp-cd-expired {
    display: block;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    padding: 8px;
}

/* CTA widget */
.nsp-widget--cta {
    border-color: rgba(240,248,18,.15);
    background: rgba(240,248,18,.025);
}
.nsp-widget--cta::before {
    content:'';
    position:absolute;
    top:0; left:0; right:0;
    height:2px;
    background:linear-gradient(90deg, transparent, var(--notout-accent), transparent);
}
.nsp-cta-glow {
    position: absolute;
    width: 200px; height: 200px;
    top: -70px; right: -50px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(240,248,18,.07) 0%, transparent 70%);
    pointer-events: none;
}
.nsp-cta-desc {
    font-size: 13px;
    color: rgba(255,255,255,.48);
    line-height: 1.7;
    margin-bottom: 18px;
}
.nsp-cta-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 16px 20px;
    background: linear-gradient(135deg, var(--notout-accent) 0%, var(--notout-heading) 100%);
    color: #011d10;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .07em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 10px;
    box-shadow: 0 6px 24px rgba(240,248,18,.28);
    transition: transform .25s, box-shadow .25s;
    animation: nsp-cta-pulse 3s ease-in-out infinite;
    margin-bottom: 10px;
}
@keyframes nsp-cta-pulse {
    0%,100% { box-shadow: 0 6px 24px rgba(240,248,18,.28); }
    50%     { box-shadow: 0 8px 36px rgba(240,248,18,.50); }
}
.nsp-cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 40px rgba(240,248,18,.5);
    color: #011d10;
    text-decoration: none;
}
.nsp-cta-terms {
    font-size: 10px;
    color: rgba(255,255,255,.22);
    text-align: center;
    letter-spacing: .05em;
    margin: 0;
}

/* Info widget */
.nsp-info-list {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    flex-direction: column;
}
.nsp-info-list__item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 13px 0;
    border-bottom: 1px solid rgba(255,255,255,.05);
}
.nsp-info-list__item:last-child { border-bottom: none; }
.nsp-info-list__icon {
    width: 30px; height: 30px;
    border-radius: 8px;
    background: rgba(154,230,0,.08);
    border: 1px solid rgba(154,230,0,.12);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    color: var(--notout-heading);
    flex-shrink: 0;
}
.nsp-info-list__item > div { display:flex; flex-direction:column; gap:3px; padding-top:2px; }
.nsp-info-list__label {
    font-size: 9px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.28);
}
.nsp-info-list__value {
    font-size: 12px;
    font-weight: 600;
    color: rgba(255,255,255,.72);
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.nsp-info-list__value a {
    color: var(--notout-heading);
    text-decoration: none;
    padding: 2px 8px;
    border-radius: 4px;
    background: rgba(154,230,0,.08);
    font-size: 11px;
    transition: background .2s;
}
.nsp-info-list__value a:hover          { background:rgba(154,230,0,.16); }
.nsp-info-list__value--accent          { color:var(--notout-accent); }
.nsp-info-list__value--active          { color:var(--notout-heading); }
.nsp-info-list__value--expired         { color:rgba(255,255,255,.28); }
.nsp-icon--active  { color:var(--notout-heading) !important; }
.nsp-icon--expired { color:rgba(255,255,255,.2)  !important; }

/* ── RELATED PROMOTIONS ───────────────────────────── */
.nsp-related {
    padding: 64px 0 84px;
    background: rgba(0,0,0,.18);
    border-top: 1px solid rgba(255,255,255,.04);
}
.nsp-related__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 36px;
}
.nsp-related__title-row {
    display: flex;
    align-items: center;
    gap: 12px;
}
.nsp-related__gem   { color:var(--notout-accent); font-size:11px; opacity:.7; }
.nsp-related__title { margin:0; font-size:22px; font-weight:800; color:#fff; letter-spacing:-.015em; }
.nsp-related__view-all {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 700;
    color: var(--notout-heading);
    text-decoration: none;
    letter-spacing: .05em;
    padding: 8px 16px;
    border: 1px solid rgba(154,230,0,.2);
    border-radius: 8px;
    background: rgba(154,230,0,.04);
    transition: all .25s;
}
.nsp-related__view-all:hover {
    background: rgba(154,230,0,.1);
    border-color: rgba(154,230,0,.4);
    color: var(--notout-accent);
}

/* ── RESPONSIVE ───────────────────────────────────── */
@media (max-width: 960px) {
    .nsp-layout              { grid-template-columns: 1fr; }
    .nsp-sidebar             { position: static; }
    .nsp-hero__overlay       { min-height: 480px; padding-bottom: 44px; }
    .nsp-hero__title         { font-size: clamp(24px, 6vw, 42px); }
}
@media (max-width: 600px) {
    .nsp-hero__overlay       { min-height: 420px; padding-bottom: 36px; }
    .nsp-body                { padding: 32px 0 48px; }
    .nsp-content-card__body  { padding: 22px 20px; }
    .nsp-info-strip__inner   { flex-direction: column; }
    .nsp-info-divider        { width: auto; height: 1px; margin: 0 26px; }
    .nsp-info-item           { flex: 0 0 auto; }
    .nsp-related             { padding: 40px 0 56px; }
    .nsp-related__header     { flex-direction: column; align-items: flex-start; }
    .nsp-hero__actions       { flex-direction: column; align-items: flex-start; }
}

/* -------------------------------------------------------
   PROMOTIONS RESPONSIVE
------------------------------------------------------- */
@media ( max-width: 991px ) {
    .notout-promo-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
    .notout-promo-page-title {
        font-size: 30px;
    }
}

@media ( max-width: 576px ) {
    .notout-promotions-page {
        padding: 36px 0 60px;
    }
    .notout-promo-page-title {
        font-size: 26px;
    }
    .notout-promo-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }
    .notout-promo-tabs {
        flex-wrap: nowrap;
        justify-content: flex-start;
    }
    .notout-promo-footer {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }
    .notout-btn-loadmore {
        width: 100%;
        justify-content: center;
    }
    .notout-promo-pagnav {
        align-self: flex-end;
    }
    .notout-single-promo-title {
        font-size: 24px;
    }
}

/* ==========================================================
   PREMIUM GRAPHICS ENHANCEMENTS
========================================================== */

/* --- Rich background: gradient glows + diamond grid pattern --- */
.notout-promotions-page {
    background:
        radial-gradient(ellipse 110% 55% at 50% -8%, rgba(154,230,0,0.11) 0%, transparent 58%),
        radial-gradient(ellipse 60% 50% at 95% 90%, rgba(240,248,18,0.06) 0%, transparent 52%),
        radial-gradient(ellipse 45% 55% at 5% 55%,  rgba(154,230,0,0.05) 0%, transparent 52%),
        repeating-conic-gradient(rgba(255,255,255,0.013) 0% 25%, transparent 0% 50%) 0 0 / 28px 28px,
        var(--notout-dark);
}

/* --- Page header gem icon --- */
.notout-promo-header-gem {
    display: block;
    text-align: center;
    font-size: 16px;
    color: var(--notout-heading);
    margin-bottom: 18px;
    filter: drop-shadow(0 0 10px rgba(154,230,0,0.7));
    animation: notout-gem-pulse 3s ease-in-out infinite;
}
@keyframes notout-gem-pulse {
    0%, 100% { opacity: 0.7;  filter: drop-shadow(0 0 8px  rgba(154,230,0,0.6)); }
    50%       { opacity: 1;    filter: drop-shadow(0 0 18px rgba(154,230,0,0.95)); }
}

/* --- Title row: decorative flanking lines --- */
.notout-promo-title-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-bottom: 14px;
}
.notout-promo-title-dec {
    flex: 1;
    max-width: 110px;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(154,230,0,0.55) 100%);
    position: relative;
}
.notout-promo-title-dec::after {
    content: '';
    position: absolute;
    right: -1px;
    top: 50%;
    transform: translateY(-50%);
    width: 7px;
    height: 7px;
    background: var(--notout-heading);
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(154,230,0,0.9), 0 0 20px rgba(154,230,0,0.4);
}
.notout-promo-title-dec--right {
    background: linear-gradient(90deg, rgba(154,230,0,0.55) 0%, transparent 100%);
}
.notout-promo-title-dec--right::after {
    right: auto;
    left: -1px;
}
/* Title inside the flex row — override inline-block */
.notout-promo-title-row .notout-promo-page-title {
    flex-shrink: 0;
    margin-bottom: 0;
    padding-bottom: 0;
    text-shadow: 0 0 48px rgba(154,230,0,0.18), 0 2px 4px rgba(0,0,0,0.4);
}
.notout-promo-title-row .notout-promo-page-title::after {
    display: none; /* replaced by the title row gem + lines */
}
/* Subtitle glow */
.notout-promo-page-subtitle {
    text-shadow: 0 0 20px rgba(154,230,0,0.1);
}

/* --- Decorative gradient rule above the tabs --- */
.notout-promo-tabs-wrap {
    position: relative;
}
.notout-promo-tabs-wrap::before {
    content: '';
    display: block;
    height: 1px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(154,230,0,0.25) 25%,
        rgba(240,248,18,0.25) 75%,
        transparent 100%);
    margin-bottom: 28px;
}

/* --- Animated gradient on the active tab --- */
@keyframes notout-tab-shimmer {
    0%   { background-position: 0%   50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0%   50%; }
}
.notout-promo-tab.active {
    background: linear-gradient(135deg,
        var(--notout-heading),
        var(--notout-accent),
        #d4ff00,
        var(--notout-heading));
    background-size: 300% 300%;
    animation: notout-tab-shimmer 3.5s ease infinite;
    box-shadow: 0 0 22px rgba(154,230,0,0.4), 0 2px 8px rgba(0,0,0,0.3);
}

/* --- Card top accent line (::after) --- */
.notout-promo-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,
        rgba(154,230,0,0.0)  0%,
        rgba(154,230,0,0.7) 30%,
        rgba(240,248,18,0.9) 65%,
        rgba(154,230,0,0.0) 100%);
    z-index: 3;
    opacity: 0.45;
    transition: opacity 0.35s ease;
    border-radius: 14px 14px 0 0;
}
.notout-promo-card:hover::after {
    opacity: 1;
}

/* --- Shimmer border animation on card hover --- */
@keyframes notout-border-shimmer {
    0%   { background-position: 0%   50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0%   50%; }
}
.notout-promo-card:hover::before {
    background: linear-gradient(135deg,
        rgba(154,230,0,0.75) 0%,
        rgba(255,255,255,0.12) 25%,
        rgba(240,248,18,0.65) 50%,
        rgba(255,255,255,0.12) 75%,
        rgba(154,230,0,0.75) 100%);
    background-size: 300% 300%;
    animation: notout-border-shimmer 2s ease infinite;
}

/* --- Enhanced hover glow on cards --- */
.notout-promo-card:hover {
    box-shadow:
        0 18px 52px rgba(0,0,0,0.6),
        0 0 40px rgba(154,230,0,0.09),
        0 0  0 1px rgba(154,230,0,0.12);
}

/* --- Pulsing "Claim Offer" button --- */
@keyframes notout-claim-pulse {
    0%, 100% { box-shadow: 0 4px 16px rgba(240,248,18,0.40); }
    50%       { box-shadow: 0 4px 28px rgba(240,248,18,0.75),
                            0 0   0  8px rgba(240,248,18,0.10); }
}
.notout-promo-card-overlay .notout-promo-claim-btn {
    animation: notout-claim-pulse 2.2s ease-in-out infinite;
}

/* --- Card category chip hover glow --- */
.notout-promo-cat {
    transition: background 0.2s, color 0.2s, box-shadow 0.2s;
    cursor: default;
}
.notout-promo-cat:hover {
    background: rgba(154,230,0,0.22);
    color: var(--notout-heading);
    box-shadow: 0 0 10px rgba(154,230,0,0.22);
}

/* --- Footer separator glow --- */
.notout-promo-footer-separator {
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(154,230,0,0.25) 30%,
        rgba(240,248,18,0.20) 70%,
        transparent 100%) !important;
    border-top: none !important;
    height: 1px;
}

/* --- Load More button glow pulse --- */
@keyframes notout-loadmore-glow {
    0%, 100% { box-shadow: 0 4px 20px rgba(154,230,0,0.28); }
    50%       { box-shadow: 0 6px 32px rgba(154,230,0,0.55), 0 0 0 4px rgba(154,230,0,0.08); }
}
.notout-btn-loadmore {
    animation: notout-loadmore-glow 2.8s ease-in-out infinite;
}
.notout-btn-loadmore:hover {
    animation: none;
    box-shadow: 0 8px 36px rgba(154,230,0,0.60);
}

/* --- Single promo title glow --- */
.notout-single-promo-title {
    text-shadow: 0 0 40px rgba(154,230,0,0.12), 0 2px 6px rgba(0,0,0,0.5);
}

/* --- Responsive tweaks for enhancements --- */
@media (max-width: 576px) {
    .notout-promo-title-dec { max-width: 48px; }
    .notout-promo-header-gem { font-size: 14px; }
}

/* ==========================================================
   PREMIUM HEADER & FOOTER REDESIGN
========================================================== */

/* -------------------------------------------------------
   TOP ANNOUNCEMENT BAR
------------------------------------------------------- */
.notout-topbar {
    background: linear-gradient(90deg, #010d06 0%, #031510 50%, #010d06 100%);
    border-bottom: 1px solid rgba(154,230,0,0.12);
    padding: 7px 0;
    font-size: 12px;
    position: relative;
    overflow: hidden;
}
/* subtle shimmer line */
.notout-topbar::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(154,230,0,0.3) 30%,
        rgba(240,248,18,0.3) 50%,
        rgba(154,230,0,0.3) 70%,
        transparent 100%);
}
.notout-topbar .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.notout-topbar-left {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.notout-topbar-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: rgba(255,255,255,0.48);
    font-size: 11.5px;
    font-weight: 500;
    letter-spacing: 0.2px;
    white-space: nowrap;
}
.notout-topbar-item i {
    color: var(--notout-heading);
    font-size: 11px;
    flex-shrink: 0;
}
.notout-topbar-dot {
    color: rgba(154,230,0,0.22);
    font-size: 7px;
    line-height: 1;
    flex-shrink: 0;
}
.notout-topbar-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 14px;
    border: 1px solid rgba(154,230,0,0.25);
    border-radius: 50px;
    color: var(--notout-heading);
    font-size: 11px;
    font-weight: 600;
    background: rgba(154,230,0,0.07);
    letter-spacing: 0.4px;
    white-space: nowrap;
    box-shadow: 0 0 10px rgba(154,230,0,0.12);
}
.notout-topbar-badge i {
    font-size: 10px;
}

/* -------------------------------------------------------
   ENHANCED NAVBAR
------------------------------------------------------- */
.notout-navbar {
    background: rgba(2, 14, 9, 0.98) !important;
    border-bottom: 1px solid rgba(154,230,0,0.2) !important;
    box-shadow: 0 4px 28px rgba(0,0,0,0.55), 0 1px 0 rgba(154,230,0,0.08) !important;
}

/* Nav link animated underline */
.notout-main-menu > li > a {
    position: relative;
    overflow: hidden;
}
.notout-main-menu > li > a::after {
    content: '';
    position: absolute;
    left: 15px;
    right: 15px;
    bottom: 12px;
    height: 2px;
    background: linear-gradient(90deg, var(--notout-heading), var(--notout-accent));
    border-radius: 1px;
    transform: scaleX(0);
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    transform-origin: center;
}
.notout-main-menu > li > a:hover::after,
.notout-main-menu > li.current-menu-item > a::after,
.notout-main-menu > li.current_page_item > a::after {
    transform: scaleX(1);
}

/* CTA button — animated gradient shimmer */
@keyframes notout-cta-shimmer {
    0%   { background-position: 0%   50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0%   50%; }
}
.notout-btn-cta {
    background: linear-gradient(135deg, #9ae600 0%, #f0f812 40%, #b8f000 70%, #9ae600 100%) !important;
    background-size: 300% 300% !important;
    box-shadow: 0 0 22px rgba(154,230,0,0.3) !important;
    border: none !important;
    animation: notout-cta-shimmer 4s ease infinite;
    border-radius: 8px !important;
    letter-spacing: 0.3px;
}
.notout-btn-cta:hover {
    box-shadow: 0 0 36px rgba(154,230,0,0.55) !important;
    color: var(--notout-dark) !important;
    transform: translateY(-2px);
    text-decoration: none;
    animation: none;
    background: linear-gradient(135deg, #b4f500 0%, #f5fa20 100%) !important;
}

/* -------------------------------------------------------
   HEADER ACTIONS — Flag + Login + Sign Up + CTA
------------------------------------------------------- */

/* Actions wrapper */
.notout-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

/* Vertical divider */
.notout-header-divider {
    display: inline-block;
    width: 1px;
    height: 22px;
    background: rgba(255,255,255,0.1);
    flex-shrink: 0;
}

/* ── Bangladesh Flag Pill ── */
.notout-lang-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px 5px 5px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: 50px;
    cursor: default;
    transition: background 0.2s, border-color 0.2s;
}
.notout-lang-pill:hover {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.16);
}

/* Pure-CSS Bangladesh flag circle */
.notout-flag-bd {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #006a4e;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    box-shadow: 0 0 0 1.5px rgba(255,255,255,0.15);
}
.notout-flag-bd-disc {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #f42a41;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-46%, -50%);
}
.notout-lang-code {
    font-size: 11px;
    font-weight: 700;
    color: rgba(255,255,255,0.6);
    letter-spacing: 0.5px;
}

/* ── Log In button ── */
.notout-btn-login {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 15px;
    background: transparent;
    border: 1px solid rgba(255,255,255,0.16);
    border-radius: 7px;
    color: rgba(255,255,255,0.72);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.notout-btn-login i { font-size: 12px; }
.notout-btn-login:hover {
    border-color: rgba(154,230,0,0.5);
    color: var(--notout-heading);
    background: rgba(154,230,0,0.06);
    text-decoration: none;
}

/* ── Sign Up button ── */
.notout-btn-signup {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: linear-gradient(135deg, rgba(154,230,0,0.18) 0%, rgba(240,248,18,0.14) 100%);
    border: 1px solid rgba(154,230,0,0.38);
    border-radius: 7px;
    color: var(--notout-heading);
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
    letter-spacing: 0.2px;
    transition: background 0.2s, box-shadow 0.2s, transform 0.15s;
}
.notout-btn-signup i { font-size: 12px; }
.notout-btn-signup:hover {
    background: linear-gradient(135deg, rgba(154,230,0,0.28) 0%, rgba(240,248,18,0.22) 100%);
    box-shadow: 0 0 16px rgba(154,230,0,0.3);
    transform: translateY(-1px);
    text-decoration: none;
    color: var(--notout-heading);
}

/* ── Responsive: hide text labels on small screens ── */
@media (max-width: 991px) {
    .notout-btn-login span,
    .notout-btn-signup span { display: none; }
    .notout-btn-login,
    .notout-btn-signup { padding: 8px 10px; }
    .notout-lang-code { display: none; }
    .notout-lang-pill { padding: 5px; }
}
@media (max-width: 767px) {
    .notout-btn-login,
    .notout-header-divider { display: none; }
    .notout-btn-signup span { display: none; }
    .notout-btn-signup { padding: 8px 10px; }
}

/* -------------------------------------------------------
   FOOTER — PREMIUM REDESIGN
------------------------------------------------------- */

/* Top accent bar */
.notout-footer-top-accent {
    height: 3px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(154,230,0,0.4) 15%,
        var(--notout-heading) 35%,
        var(--notout-accent) 50%,
        var(--notout-heading) 65%,
        rgba(154,230,0,0.4) 85%,
        transparent 100%);
    box-shadow: 0 0 24px rgba(154,230,0,0.45);
}

/* ── Brand Ambassadors Ticker ── */
@keyframes notout-amb-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

.notout-amb-bar {
    display: flex;
    align-items: stretch;
    background: rgba(0,0,0,0.28);
    border-bottom: 1px solid rgba(154,230,0,0.1);
    overflow: hidden;
    min-height: 52px;
}

/* Left label */
.notout-amb-label {
    display: flex;
    align-items: center;
    gap: 7px;
    flex-shrink: 0;
    padding: 0 20px;
    background: linear-gradient(135deg, rgba(154,230,0,0.14) 0%, rgba(154,230,0,0.06) 100%);
    border-right: 1px solid rgba(154,230,0,0.18);
    color: var(--notout-heading);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    white-space: nowrap;
}
.notout-amb-label i {
    font-size: 10px;
    color: var(--notout-accent);
    filter: drop-shadow(0 0 6px rgba(240,248,18,0.7));
}

/* Scrolling overflow container */
.notout-amb-overflow {
    flex: 1;
    overflow: hidden;
    position: relative;
    /* Fade edges */
    mask-image: linear-gradient(to right, transparent 0%, black 4%, black 96%, transparent 100%);
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 4%, black 96%, transparent 100%);
}

/* Scrolling track — doubled items for seamless loop */
.notout-amb-track {
    display: flex;
    align-items: center;
    gap: 0;
    width: max-content;
    animation: notout-amb-scroll 32s linear infinite;
}
.notout-amb-track:hover {
    animation-play-state: paused;
}

/* Single ambassador card */
.notout-amb-card {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 0 24px;
    border-right: 1px solid rgba(255,255,255,0.05);
    cursor: default;
    transition: background 0.2s;
    height: 52px;
}
.notout-amb-card:hover {
    background: rgba(154,230,0,0.05);
}

/* Avatar circle — first letter */
.notout-amb-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(154,230,0,0.22), rgba(240,248,18,0.15));
    border: 1px solid rgba(154,230,0,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 800;
    color: var(--notout-heading);
    flex-shrink: 0;
    line-height: 1;
}

/* Name + year */
.notout-amb-info {
    display: flex;
    flex-direction: column;
    gap: 1px;
}
.notout-amb-name {
    font-size: 12.5px;
    font-weight: 700;
    color: rgba(255,255,255,0.85);
    white-space: nowrap;
}
.notout-amb-years {
    font-size: 10.5px;
    color: rgba(154,230,0,0.65);
    font-weight: 500;
    letter-spacing: 0.2px;
}

/* Star badge */
.notout-amb-badge {
    font-size: 9px;
    color: rgba(240,248,18,0.5);
    flex-shrink: 0;
}

/* Tagline row */
.notout-footer-tagline-row {
    background: rgba(0,0,0,0.22);
    border-bottom: 1px solid var(--notout-border);
    padding: 14px 0;
}
.notout-footer-tagline-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    color: rgba(255,255,255,0.28);
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 3px;
    text-transform: uppercase;
}
.notout-footer-tagline-gem {
    color: var(--notout-heading);
    font-size: 8px;
    filter: drop-shadow(0 0 7px rgba(154,230,0,0.85));
}

/* Footer main section */
.notout-footer-main {
    padding: 60px 0 36px;
    border-bottom: 1px solid var(--notout-border);
    position: relative;
}
/* Subtle radial glow at footer top */
.notout-footer-main::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 70%;
    height: 1px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(154,230,0,0.12) 30%,
        rgba(154,230,0,0.12) 70%,
        transparent 100%);
}

/* Footer heading — left accent bar */
.notout-footer-heading {
    position: relative !important;
    padding-left: 14px !important;
    border-bottom: 1px solid rgba(154,230,0,0.1) !important;
    padding-bottom: 12px !important;
    margin-top: 0 !important;
    margin-bottom: 20px !important;
}
.notout-footer-heading::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-75%);
    width: 3px;
    height: 18px;
    border-radius: 2px;
    background: linear-gradient(180deg, var(--notout-heading), var(--notout-accent));
    box-shadow: 0 0 8px rgba(154,230,0,0.6);
}

/* Social links — premium */
.notout-social-link {
    border: 1px solid rgba(154,230,0,0.2) !important;
    background: rgba(154,230,0,0.05) !important;
    transition: all 0.25s ease !important;
}
.notout-social-link:hover {
    background: linear-gradient(135deg, var(--notout-heading), var(--notout-accent)) !important;
    border-color: transparent !important;
    color: var(--notout-dark) !important;
    box-shadow: 0 0 20px rgba(154,230,0,0.42) !important;
    transform: translateY(-2px);
    text-decoration: none !important;
}

/* Secure Payments section */
.notout-footer-payments-desc {
    font-size: 13px;
    color: var(--notout-text-muted);
    line-height: 1.7;
    margin: 8px 0 0;
}

/* Payment grid — unified cards */
.notout-payment-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    margin-top: 18px;
}
.notout-pay-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 12px 6px 10px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: 10px;
    cursor: default;
    transition: background 0.22s, border-color 0.22s, transform 0.22s;
    min-width: 0;
}
.notout-pay-card:hover {
    background: rgba(255,255,255,0.10);
    border-color: rgba(255,255,255,0.22);
    transform: translateY(-3px);
}
/* Image logos (bKash, Nagad, Rocket, Upay) */
.notout-pay-card img {
    display: block;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    object-fit: cover;
    flex-shrink: 0;
}
/* FA icon logos (Visa, Mastercard, Bank) */
.notout-pay-card--icon i {
    font-size: 32px;
    line-height: 1;
    display: block;
}
.notout-pay-card--icon .fa-cc-visa        { color: #1a1f71; }
.notout-pay-card--icon .fa-cc-mastercard  { color: #eb001b; }
.notout-pay-card--icon .fa-building-columns { color: rgba(255,255,255,0.7); }
/* Label */
.notout-pay-card span {
    font-size: 10px;
    font-weight: 600;
    color: rgba(255,255,255,0.55);
    letter-spacing: 0.3px;
    text-align: center;
    line-height: 1.2;
    white-space: nowrap;
}
.notout-pay-card:hover span {
    color: rgba(255,255,255,0.85);
}

/* SSL / PCI trust row */
.notout-footer-secure-row {
    display: flex;
    gap: 10px;
    margin-top: 14px;
    flex-wrap: wrap;
}
.notout-footer-secure-item {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    background: rgba(154,230,0,0.04);
    border: 1px solid rgba(154,230,0,0.15);
    border-radius: 50px;
    color: rgba(154,230,0,0.55);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.3px;
}
.notout-footer-secure-item i {
    font-size: 10px;
}

/* Footer bottom */
.notout-footer-bottom {
    background: rgba(0,0,0,0.28) !important;
    border-top: 1px solid rgba(255,255,255,0.04) !important;
    padding: 0 !important;
}
.notout-footer-bottom-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    padding: 20px 0 12px;
}
.notout-footer-badges {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.notout-footer-age-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: 2px solid rgba(255,80,80,0.35);
    border-radius: 50%;
    color: rgba(255,80,80,0.55);
    font-size: 10px;
    font-weight: 800;
    flex-shrink: 0;
    letter-spacing: -0.5px;
}
.notout-footer-trust-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border: 1px solid rgba(154,230,0,0.18);
    border-radius: 50px;
    color: rgba(154,230,0,0.5);
    font-size: 11px;
    font-weight: 600;
    background: rgba(154,230,0,0.04);
    white-space: nowrap;
}
.notout-footer-trust-badge i {
    font-size: 10px;
}
.notout-footer-disclaimer {
    font-size: 11px;
    color: rgba(255,255,255,0.2);
    text-align: center;
    padding: 10px 0 18px;
    line-height: 1.7;
    border-top: 1px solid rgba(255,255,255,0.04);
    margin: 0;
}

/* -------------------------------------------------------
   PROMOTIONS PAGE — FURTHER IMPROVEMENTS
------------------------------------------------------- */

/* Richer page background */
.notout-promotions-page {
    background:
        radial-gradient(ellipse 120% 60% at 50% -5%,  rgba(154,230,0,0.13) 0%, transparent 55%),
        radial-gradient(ellipse 55%  55% at 92% 85%,  rgba(240,248,18,0.06) 0%, transparent 50%),
        radial-gradient(ellipse 40%  60% at 4%  60%,  rgba(154,230,0,0.06) 0%, transparent 50%),
        radial-gradient(ellipse 30%  40% at 80% 15%,  rgba(240,248,18,0.04) 0%, transparent 45%),
        repeating-conic-gradient(rgba(255,255,255,0.013) 0% 25%, transparent 0% 50%) 0 0 / 28px 28px,
        var(--notout-dark) !important;
}

/* Page header — more dramatic spacing */
.notout-promo-page-header {
    margin-bottom: 52px !important;
    padding-top: 8px;
}

/* Gem icon — bigger */
.notout-promo-header-gem {
    font-size: 18px !important;
    margin-bottom: 22px !important;
}

/* Page title — more impactful */
.notout-promo-page-title {
    font-size: 42px !important;
    letter-spacing: -1px !important;
    text-shadow: 0 0 60px rgba(154,230,0,0.22), 0 2px 8px rgba(0,0,0,0.5) !important;
}

/* Category tabs wrap — subtle glow below rule */
.notout-promo-tabs-wrap::before {
    box-shadow: 0 1px 12px rgba(154,230,0,0.06);
}

/* Cards — slightly larger gap & rounded */
.notout-promo-grid {
    gap: 28px !important;
}

/* Card body — a touch more padding */
.notout-promo-card-body {
    padding: 20px 22px 22px !important;
}

/* Read More — micro underline on hover */
.notout-promo-readmore:hover {
    text-decoration: none !important;
    color: var(--notout-accent) !important;
}

/* Empty state icon */
.notout-promo-empty i {
    color: rgba(154,230,0,0.08) !important;
}

/* Load More — pill shape improvement */
.notout-btn-loadmore {
    border-radius: 50px !important;
    padding: 12px 48px !important;
    letter-spacing: 0.6px;
}

/* Pagination nav buttons */
.notout-promo-pagnav-btn:not(.disabled):hover {
    transform: scale(1.08);
}

/* -------------------------------------------------------
   RESPONSIVE — HEADER / FOOTER ADDITIONS
------------------------------------------------------- */
@media (max-width: 992px) {
    .notout-topbar-dot--hide-sm,
    .notout-topbar-item--hide-sm { display: none; }
}
@media (max-width: 768px) {
    .notout-topbar { display: none; }
    .notout-footer-tagline-row { padding: 12px 0; }
    .notout-footer-bottom-inner { flex-direction: column; align-items: flex-start; gap: 10px; }
    .notout-footer-badges { flex-wrap: wrap; }
}
@media (max-width: 576px) {
    .notout-footer-tagline-row { display: none; }
    .notout-payment-grid { grid-template-columns: repeat(4, 1fr); }
    .notout-promo-page-title { font-size: 28px !important; }
}

/* =======================================================
   MOBILE-FIRST PROMOTIONS PAGE
   Primary audience: 90% mobile — designed for 360–430px
======================================================= */

/* ── Page shell ── */
@media (max-width: 767px) {
    .notout-promotions-page {
        padding: 22px 0 48px;
    }
    .notout-promo-page-header {
        margin-bottom: 20px;
    }
    .notout-promo-page-title {
        font-size: 26px !important;
        padding-bottom: 12px;
        margin-bottom: 8px;
    }
    .notout-promo-page-subtitle {
        font-size: 13px;
    }
}

/* ── Category tabs — full-bleed horizontal scroll strip ── */
@media (max-width: 767px) {
    .notout-promo-tabs-wrap {
        /* break out of container padding for edge-to-edge scroll */
        margin-left:  -15px;
        margin-right: -15px;
        padding:      0 15px 2px;
        margin-bottom: 20px;
    }
    .notout-promo-tabs {
        flex-wrap:        nowrap;
        justify-content:  flex-start;
        gap:              7px;
        padding-bottom:   6px;
    }
    .notout-promo-tab {
        flex-shrink: 0;
        padding:     8px 14px;
        font-size:   12px;
        min-height:  36px;
        display:     inline-flex;
        align-items: center;
    }
}

/* ── Cards grid — 2 columns on all phones ── */
@media (max-width: 767px) {
    .notout-promo-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
        margin-bottom: 28px;
    }
}

/* ── Card: tighter, touch-friendly ── */
@media (max-width: 767px) {
    .notout-promo-card {
        border-radius: 10px;
    }
    .notout-promo-card:hover {
        transform: none; /* disable hover lift on touch */
    }
    .notout-promo-card-img {
        aspect-ratio: 3 / 2;
    }
    .notout-promo-badge {
        font-size: 8px;
        padding:   3px 8px;
        top: 7px;
        left: 7px;
    }
    .notout-promo-card-body {
        padding: 10px 11px 12px;
        gap:     6px;
    }
    .notout-promo-cats {
        gap: 4px;
    }
    .notout-promo-cat {
        font-size: 9px;
        padding:   2px 7px;
    }
    .notout-promo-dates {
        font-size:   9.5px;
        line-height: 1.3;
    }
    .notout-promo-card-title {
        font-size:   12.5px;
        line-height: 1.35;
    }
    .notout-promo-divider {
        margin: 2px 0 0;
    }
    .notout-promo-readmore {
        font-size: 10.5px;
        gap:       4px;
    }
}

/* ── Pagination / load-more ── */
@media (max-width: 767px) {
    .notout-promo-footer {
        flex-direction: column;
        align-items:    center;
        text-align:     center;
        gap:            14px;
    }
    .notout-btn-loadmore {
        width:           100%;
        justify-content: center;
        padding:         13px 20px;
        font-size:       13px;
        border-radius:   10px;
    }
    .notout-promo-pagnav-btn {
        width:     44px;
        height:    44px;
        font-size: 20px;
    }
    .notout-promo-records {
        font-size: 12px;
    }
}

/* ── Ambassador ticker on mobile ── */
@media (max-width: 576px) {
    .notout-amb-bar {
        min-height: 44px;
    }
    .notout-amb-label {
        padding:        0 12px;
        font-size:      9.5px;
        letter-spacing: 0.3px;
        gap:            5px;
    }
    .notout-amb-card {
        padding:  0 16px;
        height:   44px;
        gap:      8px;
    }
    .notout-amb-avatar {
        width:     26px;
        height:    26px;
        font-size: 11px;
    }
    .notout-amb-name  { font-size: 11.5px; }
    .notout-amb-years { font-size: 10px; }
}

/* ── Header actions on small phones ── */
@media (max-width: 480px) {
    .notout-header-actions { gap: 5px; }
    /* Official Agent — icon only on very small screens */
    .notout-btn-cta span   { display: none; }
    .notout-btn-cta        { padding: 8px 11px; border-radius: 7px !important; }
    /* Sign Up — icon only */
    .notout-btn-signup span { display: none; }
    .notout-btn-signup      { padding: 8px 10px; }
}

/* ── Footer column layout on mobile ── */
@media (max-width: 767px) {
    .notout-footer-main    { padding: 36px 0 24px; }
    .notout-footer-col     { margin-bottom: 24px; }
    .notout-footer-desc    { font-size: 13px; }
    .notout-social-links   { gap: 8px; }
    .notout-social-link    { width: 36px; height: 36px; font-size: 13px; }
    .notout-footer-bottom-inner { padding: 14px 0 10px; }
    .notout-footer-age-badge    { width: 30px; height: 30px; font-size: 9px; }
    .notout-footer-trust-badge  { font-size: 10px; padding: 4px 10px; }
}

/* =======================================================
   MOBILE HEADER — Single-row layout + dark nav overrides
   Fixes brand-wrap width: 100% pushing header-actions off-row
   Fixes legacy gray nav background (#f1f1f1)
======================================================= */
@media (max-width: 1080px) {

    /* 1. Navbar: use theme dark green, not legacy #303030 */
    .notout-navbar {
        background-color: var(--notout-header-bg) !important;
    }

    /* 2. Brand-wrap: auto width so it doesn't consume the full row */
    .notout-brand-wrap {
        width:         auto !important;
        flex:          0 0 auto;
        order:         1;
        border-bottom: none !important;
        min-height:    60px;
    }

    /* 3. Header actions: fill remaining width, flush right, leave room for hamburger */
    .notout-header-actions {
        order:           2;
        flex:            1 1 auto;
        justify-content: flex-end;
        flex-wrap:       nowrap;
        padding-right:   52px; /* clears the absolute-positioned toggler (right: 10px, w: 36px) */
        gap:             5px;
    }

    /* 4. Mobile nav: appears on its own row when toggled */
    .notout-main-menu {
        order: 3;
    }

    /* 5. Mobile nav dropdown: dark theme */
    .notout-main-menu {
        background: var(--notout-dark) !important;
        border-top: 1px solid var(--notout-border);
    }
    .notout-main-menu > li {
        border-bottom: 1px solid var(--notout-border) !important;
    }
    .notout-main-menu li a {
        color: var(--notout-text) !important;
    }
    .notout-main-menu > li ul.sub-menu {
        background: rgba(0, 0, 0, 0.30) !important;
    }
    .notout-main-menu > li ul.sub-menu > li,
    .notout-main-menu > li ul.sub-menu > li:first-child {
        border-color: var(--notout-border) !important;
    }

    /* 6. Vertical divider: too decorative at mobile widths */
    .notout-header-divider { display: none; }
}

/* ── Compact header buttons on phones ── */
@media (max-width: 767px) {
    /* Login: icon only, no text label */
    .notout-btn-login span { display: none; }
    .notout-btn-login      { padding: 7px 10px; }
}

/* ── Very small phones (≤380px) — header must fit in one row ── */
/* brand-wrap(191px) + 4 icon buttons(~163px) + padding = 406px > 360px → wraps.
   Fix: shrink logo + hide login so total ≈ 157 + 122 = 279px < 360px           */
@media (max-width: 380px) {
    .notout-navbar-brand img,
    .notout-navbar-brand .custom-logo {
        height: 30px !important; /* logo shrinks from 161px wide → ~127px */
    }
    .notout-btn-login {
        display: none !important; /* removed; signup is sufficient */
    }
    .notout-header-actions {
        gap:           4px !important;
        padding-right: 48px !important;
    }
}

/* ── Category tabs: 4-col grid, all visible, no scroll ── */
@media (max-width: 767px) {
    .notout-promo-tabs-wrap {
        overflow-x:    visible !important;
        overflow:      visible !important;
        margin-left:   0 !important;
        margin-right:  0 !important;
        padding:       0 0 2px !important;
        margin-bottom: 16px !important;
    }
    .notout-promo-tabs {
        display:               grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        gap:                   6px !important;
    }
    .notout-promo-tab {
        flex-shrink:     unset;
        padding:         7px 2px !important;
        font-size:       9.5px !important;
        text-align:      center !important;
        justify-content: center !important;
        overflow:        hidden !important;
        text-overflow:   ellipsis !important;
        white-space:     nowrap !important;
        letter-spacing:  0 !important;
    }
}

/* =======================================================
   MOBILE CRITICAL OVERRIDES
   Desktop "premium" rules use !important — these must too
======================================================= */
@media (max-width: 767px) {
    /* Page header — tighter vertical rhythm on phone */
    .notout-promo-page-header { margin-bottom: 16px !important; padding-top: 0 !important; }
    .notout-promo-header-gem  { margin-bottom: 10px !important; font-size: 14px !important; }
    .notout-promo-page-title  { letter-spacing: 0 !important; }

    /* Cards grid — compact gap saves screen real-estate */
    .notout-promo-grid { gap: 10px !important; }

    /* Card body — compact padding for small 2-col cards */
    .notout-promo-card-body { padding: 10px 11px 12px !important; }

    /* Load More — full-width pill, tighter padding */
    .notout-btn-loadmore { padding: 13px 20px !important; }
}

/* ── Mobile nav: hide desktop underline on active/hover menu items ── */
@media (max-width: 1080px) {
    .notout-main-menu > li > a::after {
        display: none !important;
    }
}

/* ── Header actions: uniform icon buttons — same size, same gap ── */
@media (max-width: 1080px) {
    .notout-header-actions {
        gap: 6px !important;
        align-items: center !important;
    }

    /* All three visible items: equal 36×36px square icon buttons */
    .notout-lang-pill,
    .notout-btn-signup,
    .notout-btn-cta {
        width:           36px !important;
        height:          36px !important;
        min-width:       36px !important;
        padding:         0 !important;
        display:         inline-flex !important;
        align-items:     center !important;
        justify-content: center !important;
        border-radius:   8px !important;
        gap:             0 !important;
    }

    /* Flag pill: hide "BD" label, just the flag circle */
    .notout-lang-pill .notout-lang-code { display: none !important; }

    /* Keep flag disc size */
    .notout-lang-pill .notout-flag-bd { flex-shrink: 0; }

    /* Icon sizes consistent across all buttons */
    .notout-btn-signup i,
    .notout-btn-cta i { font-size: 15px !important; }
}

/* ══════════════════════════════════════════════════════════════
   NSP SINGLE PROMOTION — SUPER RESPONSIVE  (≤ 767 px)
   Optimised for 390 px (iPhone 14) / 360 px (small Android)
══════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {

    /* ── Breadcrumb top bar ─────────────────────── */
    .nsp-topbar                     { padding: 9px 0; }
    .nsp-breadcrumb                 { font-size: 10px; gap: 6px; }
    .nsp-breadcrumb a               { gap: 5px; }
    .nsp-breadcrumb__sep            { font-size: 8px; }

    /* ── Hero image showcase ────────────────────── */
    .nsp-imgbox__wrap               { max-height: 220px; }
    .nsp-imgbox__photo              { max-height: 220px; }
    .nsp-imgbox__no-img             { min-height: 190px; }
    .nsp-imgbox__no-img-inner i     { font-size: 44px; }

    /* Smaller badge pill — top-left */
    .nsp-imgbox__badge {
        top: 10px; left: 10px;
        padding: 4px 10px;
        font-size: 9px;
        gap: 5px;
    }
    /* Smaller status pill — top-right */
    .nsp-imgbox__status {
        top: 10px; right: 10px;
        padding: 4px 10px;
        font-size: 10px;
        gap: 5px;
    }
    /* Bottom overlay — compact */
    .nsp-imgbox__bottom             { padding: 14px 12px 12px; gap: 7px; }
    .nsp-imgbox__date               { font-size: 11px; }

    /* ── Info strip: 2-column grid ─────────────── */
    .nsp-info-strip__inner {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
    }
    /* Remove the vertical <div> dividers from grid flow */
    .nsp-info-divider               { display: none !important; }
    /* All items: 50% width, horizontal dividing lines */
    .nsp-info-item {
        flex: unset !important;
        padding: 14px 14px !important;
        border-bottom: 1px solid rgba(255,255,255,.05) !important;
        border-right: none !important;
    }
    /*
     * Left-column items = nth-child 1, 5, 9 (4n+1):
     * DOM order is: item(1) divider(2) item(3) divider(4) item(5)…
     * Grid ignores display:none dividers, placing items left→right.
     * nth-child counts ALL children incl. hidden dividers.
     */
    .nsp-info-strip__inner .nsp-info-item:nth-child(4n+1) {
        border-right: 1px solid rgba(255,255,255,.05) !important;
    }

    /* ── Body ──────────────────────────────────── */
    .nsp-body                       { padding: 20px 0 36px !important; }
    .nsp-layout                     { gap: 16px !important; }

    /* ── Title card ─────────────────────────────── */
    .nsp-title-card                 { border-radius: 12px; margin-bottom: 16px; }
    .nsp-title-card__inner          { padding: 18px 16px 16px !important; gap: 12px !important; }
    .nsp-title-card__title {
        font-size: clamp(17px, 5vw, 22px) !important;
        line-height: 1.2 !important;
        letter-spacing: -.01em !important;
    }
    .nsp-title-card__meta           { gap: 10px !important; }
    .nsp-hero__date                 { font-size: 12px; }

    /* Action buttons — full-width, stacked vertically */
    .nsp-title-card__actions {
        flex-direction: column !important;
        gap: 8px !important;
        padding-top: 2px !important;
    }
    .nsp-hero__cta-btn,
    .nsp-hero__back-btn {
        width: 100% !important;
        justify-content: center !important;
        padding: 13px 16px !important;
        font-size: 12px !important;
        border-radius: 9px !important;
    }

    /* ── Content card ───────────────────────────── */
    .nsp-content-card               { border-radius: 12px; }
    .nsp-content-card__header       { padding: 14px 16px; }
    .nsp-content-card__body         { padding: 18px 16px !important; }
    .nsp-content                    { font-size: 14px !important; line-height: 1.8 !important; }
    .nsp-content h2                 { font-size: 18px !important; }
    .nsp-content h3                 { font-size: 15px !important; }

    /* ── Sidebar widgets ────────────────────────── */
    .nsp-sidebar                    { gap: 12px !important; }
    .nsp-widget                     { padding: 16px !important; border-radius: 12px !important; }
    .nsp-widget__header             { margin-bottom: 14px !important; }

    /* Countdown — compact number boxes */
    .nsp-countdown                  { gap: 4px !important; }
    .nsp-cd-box                     { padding: 10px 4px 8px !important; border-radius: 8px !important; }
    .nsp-cd-val                     { font-size: 22px !important; }
    .nsp-cd-sep                     { font-size: 15px !important; padding-bottom: 12px !important; }

    /* CTA widget */
    .nsp-cta-desc                   { font-size: 12px !important; margin-bottom: 14px !important; }
    .nsp-cta-btn                    { padding: 14px 16px !important; font-size: 12px !important; }

    /* Quick info list — tighter rows */
    .nsp-info-list__item            { padding: 11px 0 !important; gap: 10px !important; }
    .nsp-info-list__icon {
        width: 26px !important;
        height: 26px !important;
        font-size: 11px !important;
        border-radius: 7px !important;
    }

    /* ── Related promotions ─────────────────────── */
    .nsp-related                    { padding: 28px 0 40px !important; }
    .nsp-related__header {
        margin-bottom: 20px !important;
        flex-direction: row !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
        gap: 10px !important;
    }
    .nsp-related__title-row         { gap: 8px !important; }
    .nsp-related__title             { font-size: 17px !important; }
    .nsp-related__gem               { font-size: 9px !important; }
    .nsp-related__view-all {
        font-size: 11px !important;
        padding: 6px 10px !important;
        flex-shrink: 0 !important;
    }
}