html, body {
    overflow-x: hidden;
    max-width: 100%
}

 
img, video, iframe {
    max-width: 100%
}

:root {
    --bg: #fbf5ee;
    --surface: #fffdfa;
    --surface-2: #f7ede0;
    --ink: #1b140f;
    --ink-soft: #68584c;
    --line: rgba(27,20,15,.10);
    --gold: #e12826;
    --gold-2: #e03e43;
    --deep: #1d140f;
    --deep-2: #312117;
    --success: #2f7d56;
    --shadow: 0 20px 60px rgba(27,20,14,.08);
    --radius: 26px
}

* {
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body {
    font-family: "Inter","Segoe UI",Arial,sans-serif;
    color: var(--ink);
    background: var(--bg);
    line-height: 1.65
}

img {
    max-width: 100%;
    display: block
}

a {
    text-decoration: none
}

.container-premium {
    width: min(1320px, calc(100% - 44px));
    margin: auto
}

.section-space {
    padding: 84px 0
}

.section-space-sm {
    padding: 54px 0
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    border: 1px solid rgb(255 255 255 / .14);
    background: rgb(255 255 255 / .08);
    backdrop-filter: blur(10px);
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase
}

.section-tag {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    border: 1px solid var(--line);
    background: #fff;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--ink)
}

.section-title {
    font-size: 50px;
    line-height: 1.08;
    font-weight: 800;
    letter-spacing: -.03em;
    margin: 16px 0 14px
}

.section-subtitle {
    font-size: 18px;
    color: var(--ink-soft);
    max-width: 720px;
    line-height: 1.68
}

.text-muted-premium {
    color: var(--ink-soft)
}

.btn-premium, .btn-premium-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 15px 24px;
    border-radius: 999px;
    font-weight: 700;
    transition: .25s ease;
    letter-spacing: .01em;
    border: 1px solid #fff0
}

.btn-premium {
    background: linear-gradient(135deg,var(--gold),var(--gold-2));
    color: #fff;
    box-shadow: 0 18px 35px rgb(184 135 70 / .22)
}

    .btn-premium:hover {
        transform: translateY(-2px);
        color: #fff
    }

.btn-premium-outline {
    border-color: rgb(255 255 255 / .22);
    background: rgb(255 255 255 / .08);
    color: #fff
}

    .btn-premium-outline:hover {
        color: #fff;
        background: rgb(255 255 255 / .14)
    }

.site-topbar {
    background: #3d3d3c;
    color: #f1e7db;
    font-size: 13px;
    border-bottom: 1px solid rgb(255 255 255 / .08)
}

    .site-topbar .wrap {
        display: flex;
        justify-content: space-between;
        gap: 18px;
        align-items: center;
        padding: 10px 0
    }

    .site-topbar a {
        color: #f1e7db;
        opacity: .85
    }

.site-topbar {
    background: radial-gradient(circle at 12% 50%,rgb(225 40 38 / .22),transparent 28%),linear-gradient(90deg,#151313 0%,#3d3d3c 48%,#171515 100%) !important;
    color: #fff !important;
    font-size: 13px;
    border-bottom: 1px solid rgb(255 255 255 / .10)
}

    .site-topbar .wrap {
        min-height: 42px;
        padding: 8px 0 !important
    }

        .site-topbar .wrap > div:first-child {
            display: flex;
            align-items: center;
            gap: 10px;
            font-weight: 700;
            letter-spacing: .02em
        }

            .site-topbar .wrap > div:first-child:before {
                content: "★";
                width: 24px;
                height: 24px;
                border-radius: 50%;
                background: rgb(225 40 38 / .18);
                color: #fff;
                display: grid;
                place-items: center;
                font-size: 11px;
                border: 1px solid rgb(255 255 255 / .14)
            }

        .site-topbar .wrap > div:last-child {
            display: flex;
            align-items: center;
            gap: 16px
        }

    .site-topbar a {
        color: #fff !important;
        opacity: 1 !important;
        font-weight: 600
    }

        .site-topbar a[href^="tel:"]:before {
            content: "\f095";
            font-family: "Font Awesome 6 Free";
            font-weight: 900;
            margin-right: 7px;
            color: #e12826
        }

        .site-topbar a[href^="mailto:"]:before {
            content: "\f0e0";
            font-family: "Font Awesome 6 Free";
            font-weight: 900;
            margin-right: 7px;
            color: #e12826
        }

.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgb(255 250 245 / .82);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgb(24 18 13 / .08)
}

.nav-shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 15px 0
}

.brand {
    display: flex;
    align-items: center;
    gap: 14px;
    color: var(--ink)
}

.brand-mark {
    width: 46px;
    height: 46px;
    border-radius: 14px;
    background: linear-gradient(135deg,var(--gold),#f0d7a5);
    display: grid;
    place-items: center;
    font-weight: 900;
    color: #18120d;
    box-shadow: 0 10px 30px rgb(184 135 70 / .25)
}

.brand-title {
    font-weight: 900;
    letter-spacing: .2em;
    font-size: 14px
}

.brand-sub {
    display: block;
    font-size: 11px;
    color: var(--ink-soft);
    letter-spacing: .14em;
    text-transform: uppercase
}

.nav-menu {
    display: flex;
    gap: 24px;
    align-items: center;
    flex-wrap: wrap
}

    .nav-menu a {
        color: var(--ink);
        font-weight: 600;
        font-size: 15px;
        position: relative
    }

        .nav-menu a:after {
            content: "";
            position: absolute;
            left: 0;
            bottom: -8px;
            width: 0;
            height: 2px;
            background: var(--gold);
            transition: .25s
        }

        .nav-menu a:hover:after, .nav-menu a.active:after {
            width: 100%
        }

.hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg,rgb(20 15 11 / .86),rgb(20 15 11 / .55)),url(/images/m4.jpg) center/cover no-repeat;
    color: #fff
}

    .hero:before {
        content: "";
        position: absolute;
        inset: 0;
        background: radial-gradient(circle at top right,rgb(216 178 122 / .26),transparent 30%),radial-gradient(circle at 20% 30%,rgb(255 255 255 / .08),transparent 24%)
    }

.hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.08fr .92fr;
    gap: 42px;
    align-items: center;
    min-height: 82vh;
    padding: 64px 0
}

.hero-stats {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 14px;
    margin-top: 30px
}

.glass-card {
    background: rgb(255 255 255 / .10);
    border: 1px solid rgb(255 255 255 / .16);
    border-radius: 24px;
    padding: 18px 20px;
    backdrop-filter: blur(12px)
}

.hero-stat h3 {
    font-size: 34px;
    margin: 0 0 6px;
    font-weight: 800
}

.hero-stat p {
    margin: 0;
    color: rgb(255 255 255 / .8)
}

.hero-side {
    padding: 26px;
    border-radius: 34px;
    background: linear-gradient(180deg,rgb(225 55 58 / 39%),rgb(255 255 255 / .05));
    border: 1px solid rgb(255 255 255 / .14);
    backdrop-filter: blur(12px);
    box-shadow: 0 20px 60px rgb(0 0 0 / .18)
}

    .hero-side img {
        border-radius: 26px;
        min-height: 460px;
        object-fit: cover
    }

.cards-2 {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: 28px
}

.content-card {
    background: var(--surface);
    border: 1px solid rgb(24 18 13 / .08);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow)
}

    .content-card .content {
        padding: 30px
    }

.split-media {
    display: grid;
    grid-template-columns: 1fr 1.02fr;
    gap: 28px;
    align-items: center
}

    .split-media.reverse {
        grid-template-columns: 1.05fr 1fr
    }

.media-frame {
    position: relative;
    background: #e8ddd0;
    padding: 14px;
    border-radius: 32px;
    box-shadow: var(--shadow)
}

    .media-frame img, .media-frame video, .media-frame iframe {
        width: 100%;
        height: 100%;
        min-height: 420px;
        object-fit: cover;
        border-radius: 24px
    }

.premium-list {
    padding-left: 0;
    list-style: none;
    margin: 0
}

    .premium-list li {
        position: relative;
        padding-left: 32px;
        margin-bottom: 14px;
        color: var(--ink-soft)
    }

        .premium-list li:before {
            content: "";
            position: absolute;
            left: 0;
            top: .6em;
            width: 14px;
            height: 14px;
            border-radius: 50%;
            background: radial-gradient(circle at 35% 35%,#fff,var(--gold));
            box-shadow: 0 0 0 5px rgb(184 135 70 / .14)
        }

.grid-4, .grid-3, .grid-5 {
    display: grid;
    gap: 22px
}

.grid-4 {
    grid-template-columns: repeat(4,1fr)
}

.grid-3 {
    grid-template-columns: repeat(3,1fr)
}

.grid-5 {
    grid-template-columns: repeat(5,1fr)
}

.info-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 24px;
    padding: 24px;
    box-shadow: var(--shadow);
    height: 100%
}

    .info-card h3, .info-card h4 {
        margin: 14px 0 10px
    }

.icon-badge {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg,rgb(184 135 70 / .16),rgb(216 178 122 / .35));
    font-size: 26px
}

.network-card {
    background: linear-gradient(180deg,#fff,#fbf7f1);
    border: 1px solid var(--line);
    border-radius: 28px;
    padding: 30px
}

.studio-search {
    background: linear-gradient(135deg,#17100c,#3b2415);
    color: #fff;
    border-radius: 34px;
    padding: 34px;
    box-shadow: 0 30px 60px rgb(19 12 8 / .24)
}

.search-panel {
    display: grid;
    grid-template-columns: 1.1fr .75fr .75fr auto;
    gap: 14px;
    margin-top: 24px
}

.form-control-premium, .form-select-premium, textarea.form-control-premium {
    width: 100%;
    padding: 15px 18px;
    border: 1px solid rgb(24 18 13 / .12);
    border-radius: 18px;
    background: #fff;
    color: var(--ink);
    outline: none;
    transition: .2s ease;
    min-height: 56px
}

    .form-control-premium:focus, .form-select-premium:focus, textarea.form-control-premium:focus {
        border-color: var(--gold);
        box-shadow: 0 0 0 4px rgb(184 135 70 / .12)
    }

.event-card, .blog-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 26px;
    overflow: hidden;
    box-shadow: var(--shadow);
    height: 100%
}

    .event-card img, .blog-card img {
        height: 220px;
        width: 100%;
        object-fit: cover
    }

    .event-card .content, .blog-card .content {
        padding: 20px 22px 22px
    }

.meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    color: var(--ink-soft);
    font-size: 14px;
    margin-bottom: 10px
}

.cta-band {
    background: linear-gradient(135deg,#170f0b,#332116);
    color: #fff;
    border-radius: 34px;
    padding: 38px;
    display: grid;
    grid-template-columns: 1.08fr .92fr;
    gap: 24px;
    align-items: center
}

.stats-strip {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 18px
}

    .stats-strip .item {
        background: #fff;
        border: 1px solid var(--line);
        border-radius: 24px;
        padding: 22px 20px;
        text-align: center;
        box-shadow: var(--shadow)
    }

    .stats-strip h3 {
        font-size: 34px;
        margin: 0 0 6px
    }

.video-shell {
    position: relative;
    overflow: hidden;
    background: #120d0a;
    border-radius: 30px;
    min-height: 420px
}

    .video-shell:before {
        content: "Studio Preview";
        position: absolute;
        inset: 0;
        display: grid;
        place-items: center;
        color: #fff;
        font-size: 30px;
        font-weight: 800;
        letter-spacing: .04em;
        background: linear-gradient(135deg,rgb(18 13 10 / .62),rgb(18 13 10 / .42)),url(/images/m3.jpg) center/cover no-repeat
    }

.contact-wrap {
    display: grid;
    grid-template-columns: .95fr 1.05fr;
    gap: 24px
}

.form-shell {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 30px;
    padding: 28px;
    box-shadow: var(--shadow)
}

.faq-item {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 22px;
    padding: 20px 22px;
    box-shadow: var(--shadow)
}

    .faq-item h4 {
        margin: 0 0 10px;
        font-size: 18px
    }

.site-footer {
    background: #130f0c;
    color: #f3e7d8;
    margin-top: 0
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.2fr .8fr .8fr 1fr;
    gap: 26px;
    padding: 68px 0 26px
}

.site-footer a {
    color: #f3e7d8;
    opacity: .85
}

.footer-bottom {
    border-top: 1px solid rgb(255 255 255 / .09);
    padding: 18px 0;
    color: rgb(243 231 216 / .72)
}

.page-hero {
    background: linear-gradient(135deg,rgb(20 15 11 / .88),rgb(36 23 15 / .58)),url(/assets/image/page-title/page-title-1.jpg) center/cover no-repeat;
    color: #fff;
    padding: 108px 0 64px
}

.breadcrumb-premium {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    color: rgb(255 255 255 / .75)
}

.notice-success {
    background: #edf8f1;
    border: 1px solid #cfe9d8;
    color: #1f6c47;
    padding: 16px 18px;
    border-radius: 16px;
    margin-bottom: 18px
}

.notice-info {
    background: #f7f3ec;
    border: 1px solid #e7ddcf;
    color: #695948;
    padding: 16px 18px;
    border-radius: 16px;
    margin-bottom: 18px
}

.table-premium {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 14px
}

    .table-premium td, .table-premium th {
        padding: 18px;
        background: #fff
    }

    .table-premium tr td:first-child, .table-premium tr th:first-child {
        border-radius: 18px 0 0 18px
    }

    .table-premium tr td:last-child, .table-premium tr th:last-child {
        border-radius: 0 18px 18px 0
    }

    .table-premium th {
        color: var(--ink-soft);
        font-size: 14px;
        text-transform: uppercase;
        letter-spacing: .08em
    }

.brand-logo {
    height: 65px;
    width: auto;
    display: block
}

    .brand-logo.footer-logo {
        height: 38px;
        filter: brightness(0) invert(1)
    }

.brand-stack {
    display: flex;
    flex-direction: column;
    gap: 2px
}

.leadership-hero {
    position: relative;
    overflow: hidden;
    border-radius: 34px;
    padding: 40px;
    background: linear-gradient(135deg,#3d3d3c 0%,#372315 52%,#3d3d3c 100%);
    color: #fff;
    box-shadow: 0 30px 70px rgb(36 20 11 / .18)
}

    .leadership-hero:before {
        content: "";
        position: absolute;
        inset: 0;
        background: radial-gradient(circle at top right,rgb(244 176 99 / .22),transparent 28%),radial-gradient(circle at left bottom,rgb(255 255 255 / .08),transparent 24%);
        pointer-events: none
    }

.leadership-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.02fr .98fr;
    gap: 30px;
    align-items: center
}

.leadership-copy p {
    color: rgb(255 255 255 / .78);
    max-width: 620px
}

.people-grid {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: 16px
}

.person-card {
    background: rgb(255 255 255 / .10);
    border: 1px solid rgb(255 255 255 / .16);
    backdrop-filter: blur(12px);
    border-radius: 24px;
    padding: 14px;
    min-height: 100%;
    box-shadow: 0 18px 40px rgb(0 0 0 / .14)
}

    .person-card img {
        width: 100%;
        height: 230px;
        object-fit: cover;
        border-radius: 18px
    }

    .person-card h4 {
        margin: 14px 0 4px;
        font-size: 20px;
        line-height: 1.25;
        color: #fff
    }

    .person-card p {
        margin: 0;
        color: rgb(255 255 255 / .74);
        font-size: 14px;
        line-height: 1.55
    }

    .person-card.featured {
        transform: translateY(-10px)
    }

.compact-copy p, .compact-copy li {
    line-height: 1.62
}

.compact-copy p {
    margin-bottom: 12px
}

.section-tight {
    padding-top: 72px;
    padding-bottom: 72px
}

.card-tight h3, .card-tight h4 {
    line-height: 1.24
}

.card-tight p {
    margin-bottom: 0
}

.studio-search h2, .cta-band h2 {
    max-width: 760px
}

.meta span {
    position: relative;
    padding-right: 12px
}

    .meta span:not(:last-child):after {
        content: "•";
        position: absolute;
        right: 0;
        color: rgb(104 88 76 / .55)
    }

@media (max-width:1100px) {
    .leadership-grid {
        grid-template-columns: 1fr
    }
}

@media (max-width:768px) {
    .brand-logo {
        height: 28px
    }

        .brand-logo.footer-logo {
            height: 32px
        }

    .people-grid {
        grid-template-columns: 1fr
    }

    .leadership-hero {
        padding: 26px
    }

    .person-card.featured {
        transform: none
    }

    .section-space {
        padding: 64px 0
    }

    .section-space-sm {
        padding: 44px 0
    }
}

@media (max-width:1100px) {
    .hero-grid, .split-media, .split-media.reverse, .cta-band, .contact-wrap, .footer-grid {
        grid-template-columns: 1fr
    }

    .grid-4 {
        grid-template-columns: repeat(2,1fr)
    }

    .grid-5 {
        grid-template-columns: repeat(2,1fr)
    }

    .stats-strip {
        grid-template-columns: repeat(2,1fr)
    }

    .search-panel {
        grid-template-columns: 1fr 1fr
    }

    .hero-side img {
        min-height: 400px
    }
}

@media (max-width:768px) {
    .nav-shell {
        flex-wrap: wrap
    }

    .nav-menu {
        gap: 14px
    }

    .hero-grid {
        min-height: auto;
        padding: 70px 0
    }

    .hero-stats, .grid-3, .grid-4, .grid-5, .cards-2, .stats-strip, .search-panel {
        grid-template-columns: 1fr
    }

    .section-space {
        padding: 72px 0
    }

    .site-topbar .wrap {
        flex-direction: column;
        align-items: flex-start
    }
}

.nav-menu {
    display: flex;
    gap: 24px;
    align-items: center;
    flex-wrap: wrap
}

    .nav-menu a, .nav-item > a {
        color: var(--ink);
        font-weight: 600;
        font-size: 17px;
        text-transform: uppercase;
        position: relative;
        padding: 12px 5px;
        display: inline-flex;
        align-items: center
    }

.nav-item {
    position: relative
}

.has-submenu > a::before {
    content: "";
    width: 7px;
    height: 7px;
    border-right: 2px solid var(--ink);
    border-bottom: 2px solid var(--ink);
    transform: rotate(45deg);
    margin-left: 8px;
    order: 2;
    margin-top: -4px;
    transition: .25s ease
}

.has-submenu:hover > a::before {
    transform: rotate(225deg);
    margin-top: 4px
}

.submenu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(14px);
    min-width: 255px;
    background: #fffdfa;
    border: 1px solid rgb(27 20 15 / .10);
    border-radius: 20px;
    box-shadow: 0 24px 55px rgb(27 20 14 / .16);
    padding: 12px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: .25s ease;
    z-index: 999
}

    .submenu::before {
        content: "";
        position: absolute;
        top: -8px;
        left: 50%;
        transform: translateX(-50%) rotate(45deg);
        width: 16px;
        height: 16px;
        background: #fffdfa;
        border-left: 1px solid rgb(27 20 15 / .10);
        border-top: 1px solid rgb(27 20 15 / .10)
    }

.has-submenu:hover .submenu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0)
}

.submenu a {
    display: block;
    padding: 12px 14px;
    border-radius: 14px;
    color: var(--ink);
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
    transition: .2s ease
}

    .submenu a:hover {
        background: rgb(225 40 38 / .08);
        color: var(--gold)
    }

    .submenu a::after {
        display: none !important
    }

@media(max-width:768px) {
    .nav-item {
        width: 100%
    }

    .submenu {
        position: static;
        transform: none;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        box-shadow: none;
        border-radius: 16px;
        margin-top: 6px;
        width: 100%;
        min-width: 100%
    }

        .submenu::before {
            display: none
        }
}

.mobile-menu-btn, .mobile-close-btn, .mobile-menu-overlay, .mobile-nav-cta {
    display: none
}

.desktop-nav-cta {
    white-space: nowrap
}

@media(max-width:991px) {
    body.menu-open {
        overflow: hidden
    }

    .site-topbar {
        display: none
    }

    .site-header {
        position: sticky;
        top: 0;
        z-index: 9999;
        background: rgb(255 250 245 / .96)
    }

    .nav-shell {
        padding: 10px 0
    }

    .brand-logo {
        height: 46px
    }

    .desktop-nav-cta {
        display: none !important
    }

    .mobile-menu-btn {
        width: 44px;
        height: 44px;
        border: 0;
        border-radius: 14px;
        background: #15120f;
        display: grid;
        place-items: center;
        padding: 10px;
        margin-left: auto
    }

        .mobile-menu-btn span {
            display: block;
            width: 22px;
            height: 2px;
            background: #fff;
            margin: 3px 0;
            border-radius: 20px
        }

    .mobile-menu-overlay {
        display: block;
        position: fixed;
        inset: 0;
        background: rgb(0 0 0 / .55);
        opacity: 0;
        visibility: hidden;
        transition: .25s ease;
        z-index: 9998
    }

    body.menu-open .mobile-menu-overlay {
        opacity: 1;
        visibility: visible
    }

    .nav-menu {
        position: fixed;
        top: 0;
        right: -100%;
        width: min(88vw, 380px);
        height: 100vh;
        z-index: 9999;
        display: flex !important;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        flex-wrap: nowrap;
        padding: 72px 22px 24px;
        background: radial-gradient(circle at 90% 5%,rgb(225 40 38 / .12),transparent 28%),linear-gradient(180deg,#fffdfa 0%,#fbf1e6 100%);
        box-shadow: -24px 0 70px rgb(0 0 0 / .24);
        overflow-y: auto;
        transition: .32s ease
    }

    body.menu-open .nav-menu {
        right: 0
    }

    .mobile-close-btn {
        display: grid;
        place-items: center;
        position: absolute;
        top: 18px;
        right: 18px;
        width: 42px;
        height: 42px;
        border: 0;
        border-radius: 50%;
        background: #15120f;
        color: #fff;
        font-size: 30px;
        line-height: 1
    }

    .nav-menu a, .nav-item > a {
        width: 100%;
        padding: 15px 4px;
        color: var(--ink);
        font-size: 16px;
        font-weight: 800;
        border-bottom: 1px solid rgb(27 20 15 / .08)
    }

        .nav-menu a::after {
            display: none !important
        }

    .nav-item {
        width: 100%
    }

    .has-submenu > a::before {
        margin-left: auto
    }

    .submenu {
        position: static;
        transform: none !important;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        width: 100%;
        min-width: 100%;
        display: none;
        margin: 8px 0 14px;
        padding: 10px;
        border-radius: 18px;
        background: rgb(255 255 255 / .72);
        box-shadow: none;
        border: 1px solid rgb(27 20 15 / .08)
    }

    .nav-item.open .submenu {
        display: block
    }

    .submenu::before {
        display: none
    }

    .submenu a {
        border-bottom: 0;
        padding: 11px 12px;
        font-size: 14px;
        border-radius: 12px;
        white-space: normal
    }

    .mobile-nav-cta {
        display: flex;
        justify-content: center;
        margin-top: 18px;
        padding: 15px 22px !important;
        border-radius: 999px;
        background: linear-gradient(135deg,var(--gold),var(--gold-2));
        color: #fff !important;
        border-bottom: 0 !important;
        box-shadow: 0 16px 34px rgb(225 40 38 / .22)
    }
}

.btn-premium {
    background: white !important;
    border: 1px solid #e12826 !important;
    color: #e12826 !important;
    box-shadow: 0 18px 35px rgb(184 135 70 / .22)
}

.mobile-top-actions {
    display: none
}

    .mobile-top-actions a {
        width: 38px;
        height: 38px;
        border-radius: 50%;
        background: #fff4ef;
        color: #e12826;
        display: flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
        font-size: 14px
    }

.mobile-bottom-bar {
    display: none
}

@media(max-width:768px) {
    body {
        padding-bottom: 78px
    }

    .container-premium {
        width: min(100% - 24px,1180px) !important
    }

    .site-topbar {
        display: none
    }

    .desktop-nav-cta {
        display: none
    }

    .mobile-top-actions {
        display: flex;
        align-items: center;
        gap: 8px;
        margin-left: auto;
        margin-right: 12px
    }

    .brand-logo {
        max-height: 44px
    }

    .site-header {
        position: sticky;
        top: 0;
        z-index: 9999;
        background: #fff
    }

    .nav-shell {
        min-height: 74px
    }

    .nav-menu {
        position: fixed;
        top: 0;
        right: -100%;
        width: 82%;
        max-width: 340px;
        height: 100vh;
        background: #fff;
        z-index: 99999;
        padding: 90px 24px 30px;
        transition: .35s ease;
        overflow: auto;
        display: flex;
        flex-direction: column;
        gap: 8px;
        box-shadow: -10px 0 40px rgb(0 0 0 / .12)
    }

    body.menu-open .nav-menu {
        right: 0
    }

    .nav-menu a {
        min-height: 52px;
        border-radius: 14px;
        background: #fff8f4;
        padding: 0 16px;
        display: flex;
        align-items: center;
        font-size: 15px;
        font-weight: 700
    }

    .mobile-close-btn {
        position: absolute;
        top: 18px;
        right: 18px;
        width: 42px;
        height: 42px;
        border-radius: 50%;
        border: 0;
        background: #fff4ef;
        color: #e12826;
        font-size: 26px;
        line-height: 1
    }

    .mobile-menu-overlay {
        position: fixed;
        inset: 0;
        background: rgb(0 0 0 / .45);
        opacity: 0;
        visibility: hidden;
        transition: .25s ease;
        z-index: 9999
    }

    body.menu-open .mobile-menu-overlay {
        opacity: 1;
        visibility: visible
    }

    .mobile-bottom-bar {
        position: fixed;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 72px;
        background: rgb(255 255 255 / .96);
        backdrop-filter: blur(14px);
        border-top: 1px solid rgb(0 0 0 / .06);
        z-index: 99999;
        display: grid;
        grid-template-columns: repeat(5,1fr);
        padding-bottom: env(safe-area-inset-bottom);
        box-shadow: 0 -10px 30px rgb(0 0 0 / .06)
    }

        .mobile-bottom-bar a {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 5px;
            color: #444;
            text-decoration: none;
            font-size: 14px;
            font-weight: 700
        }

            .mobile-bottom-bar a i {
                font-size: 18px;
                color: #e12826
            }

            .mobile-bottom-bar a.active, .mobile-bottom-bar a:hover {
                color: #e12826
            }
}

@media(max-width:768px) {
    .nav-shell {
        min-height: 74px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 10px
    }

    .brand {
        flex: 0 0 auto
    }

    .brand-logo {
        max-height: 48px
    }

    .mobile-top-actions {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 9px;
        flex: 1;
        margin: 0
    }

        .mobile-top-actions a {
            width: 42px;
            height: 42px;
            border-radius: 50%;
            background: #fff4ef;
            color: #e12826;
            display: flex;
            align-items: center;
            justify-content: center;
            text-decoration: none;
            font-size: 15px
        }

    .mobile-menu-btn {
        flex: 0 0 48px;
        width: 48px;
        height: 48px;
        border-radius: 16px;
        border: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        gap: 5px;
        position: relative;
        z-index: 100001
    }

        .mobile-menu-btn span {
            width: 22px;
            height: 3px;
            border-radius: 10px;
            background: #fff;
            display: block
        }

    .mobile-menu-overlay {
        position: fixed;
        inset: 0;
        background: rgb(0 0 0 / .45);
        opacity: 0;
        visibility: hidden;
        transition: .25s ease;
        z-index: 99990;
        pointer-events: none
    }

    body.menu-open .mobile-menu-overlay {
        opacity: 1;
        visibility: visible;
        pointer-events: auto
    }

    .nav-menu {
        position: fixed;
        top: 0;
        right: -100%;
        width: 82%;
        max-width: 340px;
        height: 100vh;
        background: #fff;
        z-index: 100000;
        padding: 90px 22px 30px;
        transition: .35s ease;
        overflow-y: auto;
        display: flex;
        flex-direction: column;
        gap: 10px;
        box-shadow: -14px 0 45px rgb(0 0 0 / .18)
    }

    body.menu-open .nav-menu {
        right: 0
    }

    .nav-menu a {
        min-height: 52px;
        border-radius: 14px;
        background: #fff8f4;
        color: #111;
        padding: 0 16px;
        display: flex;
        align-items: center;
        text-decoration: none;
        font-size: 15px;
        font-weight: 700;
        position: relative;
        z-index: 100002
    }

    .mobile-close-btn {
        position: absolute;
        top: 20px;
        right: 20px;
        width: 42px;
        height: 42px;
        border-radius: 50%;
        border: 0;
        background: #fff4ef;
        color: #e12826;
        font-size: 28px;
        z-index: 100003
    }
}

html, body {
    overflow-x: hidden !important;
    max-width: 100% !important
}

    body.menu-open {
        overflow: hidden !important
    }

.mobile-top-actions {
    display: none
}

.mobile-bottom-bar {
    display: none
}

.mobile-menu-overlay {
    display: none
}

@media(max-width:991px) {
    body {
        padding-bottom: 78px
    }

    .container-premium {
        width: min(100% - 24px,1320px) !important;
        max-width: 100% !important
    }

    .site-topbar {
        display: none !important
    }

    .site-header {
        position: sticky !important;
        top: 0 !important;
        z-index: 99990 !important;
        background: #fff !important;
        border-bottom: 1px solid rgb(0 0 0 / .06)
    }

    .nav-shell {
        min-height: 74px !important;
        padding: 10px 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 10px !important;
        flex-wrap: nowrap !important
    }

    .brand {
        flex: 0 0 auto !important
    }

    .brand-logo {
        height: 52px !important;
        max-height: 52px !important;
        width: auto !important
    }

    .desktop-nav-cta {
        display: none !important
    }

    .mobile-top-actions {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        flex: 1 1 auto !important;
        margin: 0 !important
    }

        .mobile-top-actions a {
            width: 42px !important;
            height: 42px !important;
            border-radius: 50% !important;
            background: #fff4ef !important;
            color: #e12826 !important;
            display: flex !important;
            align-items: center !important;
            justify-content: center !important;
            text-decoration: none !important;
            font-size: 15px !important;
            border: 1px solid rgb(225 40 38 / .08)
        }

    .mobile-menu-btn {
        flex: 0 0 46px !important;
        width: 46px !important;
        height: 46px !important;
        border-radius: 16px !important;
        background: #fff4ef !important;
        border: 1px solid rgb(225 40 38 / .14) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex-direction: column !important;
        gap: 5px !important;
        padding: 0 !important;
        margin: 0 !important;
        position: relative !important;
        z-index: 100002 !important
    }

        .mobile-menu-btn span {
            width: 22px !important;
            height: 3px !important;
            border-radius: 20px !important;
            background: #111 !important;
            display: block !important;
            margin: 0 !important
        }

    body.menu-open .mobile-menu-btn {
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important
    }

    .mobile-menu-overlay {
        display: block !important;
        position: fixed !important;
        inset: 0 !important;
        background: rgb(0 0 0 / .48) !important;
        opacity: 0 !important;
        visibility: hidden !important;
        transition: .25s ease !important;
        z-index: 99980 !important
    }

    body.menu-open .mobile-menu-overlay {
        opacity: 1 !important;
        visibility: visible !important
    }

    .nav-menu {
        position: fixed !important;
        top: 0 !important;
        right: -100% !important;
        width: 82% !important;
        max-width: 340px !important;
        height: 100vh !important;
        background: #fff !important;
        z-index: 100001 !important;
        padding: 90px 22px 30px !important;
        transition: .35s ease !important;
        overflow-y: auto !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 10px !important;
        flex-wrap: nowrap !important;
        box-shadow: -14px 0 45px rgb(0 0 0 / .20) !important
    }

    body.menu-open .nav-menu {
        right: 0 !important
    }

    .nav-menu a, .nav-item > a {
        width: 100% !important;
        min-height: 54px !important;
        border-radius: 15px !important;
        background: #fff8f4 !important;
        color: #111 !important;
        padding: 0 16px !important;
        display: flex !important;
        align-items: center !important;
        text-decoration: none !important;
        font-size: 15px !important;
        font-weight: 800 !important;
        border-bottom: 0 !important;
        position: relative !important;
        z-index: 100003 !important
    }

        .nav-menu a:after {
            display: none !important
        }

    .mobile-close-btn {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        position: absolute !important;
        top: 20px !important;
        right: 20px !important;
        width: 46px !important;
        height: 46px !important;
        border-radius: 16px !important;
        border: 1px solid rgb(225 40 38 / .14) !important;
        background: #fff4ef !important;
        color: #e12826 !important;
        font-size: 30px !important;
        line-height: 1 !important;
        cursor: pointer !important;
        z-index: 100004 !important
    }

    .mobile-bottom-bar {
        position: fixed !important;
        left: 0 !important;
        bottom: 0 !important;
        width: 100% !important;
        height: 72px !important;
        background: rgb(255 255 255 / .96) !important;
        backdrop-filter: blur(14px) !important;
        border-top: 1px solid rgb(0 0 0 / .06) !important;
        z-index: 99999 !important;
        display: grid !important;
        grid-template-columns: repeat(5,1fr) !important;
        box-shadow: 0 -10px 30px rgb(0 0 0 / .06) !important;
        padding-bottom: env(safe-area-inset-bottom)
    }

        .mobile-bottom-bar a {
            display: flex !important;
            flex-direction: column !important;
            align-items: center !important;
            justify-content: center !important;
            gap: 5px !important;
            color: #444 !important;
            text-decoration: none !important;
            font-size: 13px !important;
            font-weight: 700 !important
        }

            .mobile-bottom-bar a i {
                font-size: 18px !important;
                color: #e12826 !important
            }

            .mobile-bottom-bar a:hover, .mobile-bottom-bar a.active {
                color: #e12826 !important
            }
}

@media(max-width:420px) {
    .brand-logo {
        height: 48px !important;
        max-height: 48px !important
    }

    .mobile-top-actions {
        gap: 6px !important
    }

        .mobile-top-actions a {
            width: 39px !important;
            height: 39px !important;
            font-size: 14px !important
        }

    .mobile-menu-btn {
        width: 44px !important;
        height: 44px !important;
        flex-basis: 44px !important
    }
}

.premium-footer {
    position: relative;
    background: radial-gradient(circle at 10% 0%,rgb(225 40 38 / .16),transparent 30%),linear-gradient(180deg,#15110f 0%,#090706 100%) !important;
    color: #f8eee3;
    overflow: hidden
}

    .premium-footer .footer-grid {
        display: grid;
        grid-template-columns: 1.35fr .7fr .8fr 1.1fr;
        gap: 54px;
        padding: 76px 0 36px
    }

.footer-logo-premium {
    width: 128px;
    height: auto;
    filter: brightness(0) invert(1);
    margin-bottom: 22px
}

.footer-brand-col p {
    max-width: 430px;
    color: rgb(248 238 227 / .78);
    font-size: 15px;
    line-height: 1.85
}

.premium-footer h4 {
    margin: 0 0 22px;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    position: relative
}

    .premium-footer h4:after {
        content: "";
        display: block;
        width: 32px;
        height: 2px;
        background: #e12826;
        margin-top: 12px
    }

.premium-footer p {
    margin: 0 0 14px;
    color: rgb(248 238 227 / .78);
    font-size: 15px;
    line-height: 1.6
}

.premium-footer a {
    color: rgb(248 238 227 / .78) !important;
    text-decoration: none;
    transition: .25s ease
}

    .premium-footer a:hover {
        color: #fff !important
    }

.premium-footer i {
    color: #e12826;
    margin-right: 8px
}

.footer-social {
    display: flex;
    gap: 10px;
    margin-top: 24px
}

    .footer-social a {
        width: 42px;
        height: 42px;
        border-radius: 50%;
        background: rgb(255 255 255 / .08);
        display: grid;
        place-items: center;
        border: 1px solid rgb(255 255 255 / .10)
    }

        .footer-social a i {
            margin: 0;
            color: #fff
        }

        .footer-social a:hover {
            background: #e12826
        }

.footer-bottom {
    border-top: 1px solid rgb(255 255 255 / .10) !important;
    padding: 20px 0 24px !important;
    color: rgb(248 238 227 / .68) !important;
    font-size: 14px
}

@media(max-width:700px) {
    .premium-footer .footer-grid {
        grid-template-columns: repeat(2,1fr) !important;
        gap: 26px 18px !important;
        padding: 50px 0 24px !important
    }

    .footer-brand-col {
        grid-column: 1 / -1
    }

    .footer-logo-premium {
        width: 100px;
        margin-bottom: 16px
    }

    .footer-brand-col p {
        font-size: 13px;
        line-height: 1.7
    }

    .premium-footer h4 {
        font-size: 14px;
        margin-bottom: 16px
    }

    .premium-footer p, .premium-footer a {
        font-size: 13px;
        line-height: 1.55
    }

    .footer-social a {
        width: 38px;
        height: 38px
    }

    .footer-bottom {
        padding-bottom: 90px !important;
        font-size: 12px
    }
}

/* DESKTOP HEADER STICKY FINAL FIX */
@media(min-width:992px) {

    .site-header {
        position: sticky !important;
        position: -webkit-sticky !important;
        top: 0 !important;
        z-index: 99999 !important;
        background: rgba(255,250,245,.96) !important;
        backdrop-filter: blur(16px) !important;
        -webkit-backdrop-filter: blur(16px) !important;
    }

    .site-topbar {
        position: relative !important;
        z-index: 100000 !important;
    }

    .nav-shell {
        flex-wrap: nowrap !important;
    }

    .nav-menu {
        display: flex !important;
        position: static !important;
        height: auto !important;
        width: auto !important;
        background: transparent !important;
        box-shadow: none !important;
        overflow: visible !important;
    }
}
@media(min-width:992px) {
    body,
    form,
    .main-wrapper,
    .page-wrapper {
        overflow: visible !important;
    }
}