/* ============================================================
   Momo2 – Complete Redesign
   Mu Destiny Zone · Dark theme · Gold #ffb320
   ============================================================ */

/* ── Design tokens ───────────────────────────────────────── */
:root {
    --m2-gold:          #ffb320;
    --m2-gold-dim:      #b37d14;
    --m2-gold-glow:     rgba(255, 179, 32, 0.15);
    --m2-gold-border:   rgba(255, 179, 32, 0.28);

    --m2-bg:            #0b0b0d;
    --m2-bg-card:       #141416;
    --m2-bg-elevated:   #1a1a1e;
    --m2-bg-overlay:    #1e1e24;
    --m2-bg-input:      #222228;

    --m2-border:        rgba(255, 255, 255, 0.07);
    --m2-border-strong: rgba(255, 179, 32, 0.28);

    --m2-text:          #e2e2e2;
    --m2-text-sub:      #bbb;
    --m2-text-muted:    #888;
    --m2-text-inv:      #131313;

    --m2-header-h:      60px;
    --m2-touch:         44px;
    --m2-r-sm:          8px;
    --m2-r-md:          12px;
    --m2-r-lg:          18px;

    --m2-shadow-hdr:    0 4px 32px rgba(0, 0, 0, 0.5);
    --m2-shadow-drop:   0 16px 48px rgba(0, 0, 0, 0.6);
    --m2-shadow-card:   0 4px 20px rgba(0, 0, 0, 0.4);
    --m2-shadow-gold:   0 8px 32px rgba(255, 179, 32, 0.18);
    --m2-trans:         0.2s ease;
}

/* ── Keyframes ───────────────────────────────────────────── */
@keyframes m2-fadeUp { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:translateY(0); } }
@keyframes m2-pulse { 0%,100%{box-shadow:0 0 5px rgba(76,175,80,.7);}50%{box-shadow:0 0 14px rgba(76,175,80,1);} }
@keyframes shimmer-gray { from{left:-100%;}to{left:100%;} }
@keyframes loader { 0%{transform:rotate(0deg);border:4px solid #f44336;border-left-color:transparent;} 50%{transform:rotate(180deg);border:4px solid #673ab7;border-left-color:transparent;} 100%{transform:rotate(360deg);border:4px solid #f44336;border-left-color:transparent;} }
@keyframes dropdown-slide { from{transform:translateY(-8px);opacity:0;}to{transform:translateY(0);opacity:1;} }
@keyframes fadeInUp { from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);} }

/* ── Base ────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;}
html,body{height:100%;margin:0;padding:0;font-family:"Roboto",system-ui,sans-serif;background:var(--m2-bg);color:var(--m2-text);-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;color:#e8e8e8;line-height:1.3;}
h1{font-size:clamp(2rem,5vw,4rem);}h2{font-size:clamp(1.5rem,3vw,2.25rem);}h3{font-size:clamp(1.2rem,2.5vw,1.875rem);}h4{font-size:1.5rem;}h5{font-size:1.25rem;}h6{font-size:1rem;}
a{color:var(--m2-gold);text-decoration:none;transition:color var(--m2-trans);}
a:hover,a:focus{color:#ffd265;text-decoration:none;outline:0;}
img{max-width:100%;}
ol,ul{padding:0;margin:0;list-style:none;}
button{cursor:pointer;}
button:focus,input:focus,select:focus,textarea:focus{outline:0;}
p{font-size:14px;color:#bbb;line-height:1.9;margin:0 0 1em;}
p:last-child{margin-bottom:0;}
.alert{max-width:800px;margin:0 auto;}

/* ── Layout ──────────────────────────────────────────────── */
.m2-body{background:var(--m2-bg);}
.m2-main{min-height:100vh;display:flex;flex-direction:column;}
.m2-content-wrap{flex:1;padding:28px 0 56px;}
.container{width:100%;max-width:1180px;margin:0 auto;padding:0 20px;}
@media(min-width:1200px){.container{max-width:1176px;}}
.spad{padding-top:80px;padding-bottom:80px;}
.dark-spad{padding:24px 0;background:var(--m2-bg);}
.section-title{text-align:center;margin-bottom:2rem;}
.section-title h2{font-size:2rem;color:#fff;padding-top:8px;}
.set-bg{background-repeat:no-repeat;background-size:cover;background-position:top center;}

/* ── Buttons ─────────────────────────────────────────────── */
.site-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border:0;border-radius:50px;background:var(--m2-gold);color:var(--m2-text-inv);font-size:14px;font-weight:600;cursor:pointer;transition:filter var(--m2-trans),transform var(--m2-trans);text-decoration:none;white-space:nowrap;}
.site-btn:hover{filter:brightness(1.12);transform:translateY(-2px);color:var(--m2-text-inv);}
.site-btn.btn-sm{padding:8px 22px;font-size:13px;}

/* ── Labels ──────────────────────────────────────────────── */
.label{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:4px 14px;border-radius:4px;color:#fff;}
.label.pink-red,.news-ticker-contant .nt-item span.new{background:#ff205f;}
.label.red-bright{background:#e53935;}.label.red-dark{background:#8b0000;}
.label.pink{background:#ff69b4;}.label.purple{background:#7c4dff;}
.label.orange{background:#ff8c42;}.label.yellow{background:#f9c523;color:#111;}
.label.green,.news-ticker-contant .nt-item span.strategy{background:#2e7d32;}
.label.teal{background:#00695c;}.label.blue{background:#1565c0;}
.label.darkblue{background:#0d47a1;}.label.brown{background:#6d4c41;}
.label.gray{background:#616161;}.label.black{background:#212121;}
.rating i{color:var(--m2-gold);}.rating .is-fade{color:#555;}

/* ── Preloder ────────────────────────────────────────────── */
#preloder{position:fixed;inset:0;z-index:999999;background:var(--m2-bg);display:flex;align-items:center;justify-content:center;}
.loader{width:40px;height:40px;border-radius:50%;animation:loader .8s linear infinite;}


/* ============================================================
   HEADER
   ============================================================ */

/* Strip padding/height that base .header adds */
.header.m2-header,.m2-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    min-height: var(--m2-header-h);
    height: auto !important;
    background: var(--m2-bg-card);
    border-bottom: 1px solid var(--m2-border);
    box-shadow: var(--m2-shadow-hdr);
    padding: 0 !important;
    display: block !important;
}
.m2-header__inner {
    display: flex;
    align-items: center;
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 20px;
    height: var(--m2-header-h);
    gap: 0;
}
@media (min-width: 1201px) {
    .m2-header__inner {
        max-width: 100%;
        padding: 0 40px;
        position: relative;
    }
    .m2-header__nav.m2-nav {
        position: absolute !important;
        left: 50% !important;
        transform: translateX(-50%);
        width: auto;
        flex: none !important;
        pointer-events: auto;
    }
}

/* Brand group */
.m2-header__brand-group {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1 1 0%;
    min-width: 0;
}
@media (min-width: 1201px) {
    .m2-header__brand-group {
        flex: 0 0 auto;
        margin-right: 32px;
    }
    .m2-header__utils {
        flex: 0 0 auto;
        margin-left: 32px;
    }
}
.m2-header__brand,
.m2-header .logo,
.header.m2-header .logo {
    position: static !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    text-decoration: none;
}
.m2-header__logo,
.m2-header .logo img,
.header.m2-header .logo img {
    display: block;
    width: 266px;
    height: auto;
    max-height: 38px;
    object-fit: contain;
}

/* Nav */
.m2-header__nav {
    flex: 1 1 0%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: static !important;
    min-width: 0;
}
.m2-nav-list {
    display: flex;
    align-items: center;
    gap: 2px;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: nowrap;
}
.m2-nav-item { position: relative; }
.m2-header__nav-link {
    display: flex;
    align-items: center;
    height: var(--m2-header-h);
    padding: 0 14px;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--m2-text);
    text-decoration: none;
    white-space: nowrap;
    transition: color var(--m2-trans);
    border-bottom: 2px solid transparent;
}
.m2-header__nav-link:hover,
.m2-header__nav-link:focus {
    color: var(--m2-gold);
    border-bottom-color: var(--m2-gold);
}

/* Utils */
.m2-header__utils {
    flex: 1 1 0%;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    min-width: 0;
}
.m2-header__divider {
    width: 1px;
    height: 24px;
    background: var(--m2-border);
}

/* Burger */
.m2-header__burger,
.header.m2-header .nav-toggle,
.m2-nav-toggle {
    position: static !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    display: none;
    align-items: center;
    justify-content: center;
    width: var(--m2-touch);
    height: var(--m2-touch);
    background: none;
    border: none;
    color: var(--m2-text);
    font-size: 20px;
    flex-shrink: 0;
    margin-right: 8px;
    cursor: pointer;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}
.m2-header__burger:hover { color: var(--m2-gold); }
/* prevent icon from being the click target on Chrome mobile */
.m2-header__burger i, .m2-nav-toggle i { pointer-events: none; }

/* Profile / usercp */
.m2-header__usercp,
.m2-header .usercp,
.header.m2-header .usercp {
    position: relative !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
}
.m2-usercp-toggle,
.m2-header__account {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--m2-touch);
    height: var(--m2-touch);
    background: none;
    border: 1px solid var(--m2-border);
    border-radius: 50%;
    color: var(--m2-text);
    font-size: 16px;
    flex-shrink: 0;
    transition: border-color var(--m2-trans), color var(--m2-trans);
    cursor: pointer;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}
.m2-usercp-toggle:hover { border-color: var(--m2-gold); color: var(--m2-gold); }
/* prevent icon from being the click target on Chrome mobile */
.m2-usercp-toggle i, .m2-header__account i { pointer-events: none; }

/* usercp dropdown */
.m2-usercp-dropdown,
.m2-header__dropdown {
    position: absolute !important;
    right: 0;
    top: calc(100% + 8px);
    min-width: 180px;
    background: var(--m2-bg-overlay);
    border: 1px solid var(--m2-border);
    border-radius: var(--m2-r-md);
    box-shadow: var(--m2-shadow-drop);
    padding: 8px 0;
    list-style: none;
    margin: 0;
    display: none;
    z-index: 1100;
    animation: dropdown-slide .18s ease;
}
.m2-header__usercp.open .m2-usercp-dropdown,
.m2-usercp-toggle[aria-expanded="true"] + .m2-usercp-dropdown {
    display: block;
}
.m2-usercp-dropdown .cp-item a,
.m2-header__dropdown .cp-item a {
    display: block;
    padding: 9px 18px;
    color: var(--m2-text);
    font-size: 13.5px;
    transition: background var(--m2-trans), color var(--m2-trans);
}
.m2-usercp-dropdown .cp-item a:hover,
.m2-header__dropdown .cp-item a:hover {
    background: var(--m2-bg-elevated);
    color: var(--m2-gold);
}
.m2-lang-switch {
    display: flex;
    gap: 8px;
    padding: 8px 18px 6px;
    border-bottom: 1px solid var(--m2-border);
    margin-bottom: 4px;
}
.language-flag { width: 22px; height: auto; border-radius: 3px; opacity: .8; transition: opacity .15s; }
.language-flag:hover { opacity: 1; }

/* ============================================================
   SERVER SWITCHER
   ============================================================ */
.m2-server-in-header {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
    position: relative;
}
.m2-server-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--m2-text-muted);
    white-space: nowrap;
    display: none;
}
.m2-server-dropdown { position: relative; }
.m2-server-current {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    background: rgba(255,179,32,.08);
    border: 1px solid var(--m2-gold-border);
    border-radius: 20px;
    color: var(--m2-gold);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .04em;
    cursor: pointer;
    transition: background var(--m2-trans), border-color var(--m2-trans);
    white-space: nowrap;
}
.m2-server-current:hover { background: rgba(255,179,32,.16); border-color: var(--m2-gold); }
.m2-server-arrow { font-size: 10px; }
.m2-server-menu {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 140px;
    background: var(--m2-bg-overlay);
    border: 1px solid var(--m2-border);
    border-radius: var(--m2-r-md);
    box-shadow: var(--m2-shadow-drop);
    overflow: hidden;
    animation: dropdown-slide .18s ease;
    z-index: 1200;
}
.m2-server-menu[hidden] { display: none; }
.m2-server-item {
    display: block;
    padding: 9px 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--m2-text);
    text-decoration: none;
    transition: background var(--m2-trans), color var(--m2-trans);
    white-space: nowrap;
}
.m2-server-item:hover { background: var(--m2-bg-elevated); color: var(--m2-gold); }
.m2-server-item-current { color: var(--m2-gold) !important; background: rgba(255,179,32,.07); }
.m2-server-item-all { border-top: 1px solid var(--m2-border); color: var(--m2-text-muted); }
.m2-server-item-all:hover { color: var(--m2-gold); }
.m2-server-online { font-size: 11px; opacity: .75; font-weight: 400; margin-left: 3px; }

/* ============================================================
   MOBILE NAV
   ============================================================ */
@media (max-width: 1200px) {
    .m2-header__burger,
    .m2-nav-toggle {
        display: flex !important;
    }
    .m2-header__nav {
        position: fixed !important;
        top: var(--m2-header-h);
        left: 0;
        right: 0;
        bottom: 0;
        background: var(--m2-bg-card);
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        padding: 20px;
        gap: 0;
        transform: translateX(-100%);
        transition: transform .28s cubic-bezier(.4,0,.2,1);
        overflow-y: auto;
    }
    .m2-header__nav.open,
    .m2-header__nav[data-open="true"] { transform: translateX(0); }
    .m2-nav-list { flex-direction: column; align-items: flex-start; width: 100%; gap: 0; }
    .m2-nav-item { width: 100%; }
    .m2-header__nav-link {
        height: 48px;
        width: 100%;
        border-bottom: 1px solid var(--m2-border) !important;
        font-size: 15px;
        padding: 0 8px;
    }
}
/* Dynamic collapse — toggled by JS when nav reaches the server switcher */
.m2-header.m2-nav-collapsed .m2-header__burger,
.m2-header.m2-nav-collapsed .m2-nav-toggle {
    display: flex !important;
}
.m2-header.m2-nav-collapsed .m2-header__nav {
    position: fixed !important;
    left: 0 !important;
    top: var(--m2-header-h) !important;
    right: 0;
    bottom: 0;
    transform: translateX(-100%) !important;
    background: var(--m2-bg-card);
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 20px;
    gap: 0;
    transition: transform .28s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
    width: auto;
}
.m2-header.m2-nav-collapsed .m2-header__nav.open,
.m2-header.m2-nav-collapsed .m2-header__nav[data-open="true"] { transform: translateX(0) !important; }
.m2-header.m2-nav-collapsed .m2-nav-list { flex-direction: column; align-items: flex-start; width: 100%; gap: 0; }
.m2-header.m2-nav-collapsed .m2-nav-item { width: 100%; }
.m2-header.m2-nav-collapsed .m2-header__nav-link {
    height: 48px;
    width: 100%;
    border-bottom: 1px solid var(--m2-border) !important;
    font-size: 15px;
    padding: 0 8px;
}

@media (max-width: 600px) {
    .m2-header__inner { padding: 0 12px; gap: 0; }
    .m2-header__logo { width: 160px; }
    .m2-header__divider { display: none; }
}

/* ============================================================
   NEWS TICKER
   ============================================================ */
.m2-ticker-section {
    background: #101012;
    border-bottom: 1px solid var(--m2-border);
    overflow: hidden;
    display: flex;
    align-items: center;
    height: 36px;
    flex-shrink: 0;
}
.m2-ticker-title {
    flex-shrink: 0;
    padding: 0 16px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--m2-gold);
    border-right: 1px solid var(--m2-border);
    height: 100%;
    display: flex;
    align-items: center;
    background: #0d0d0f;
    white-space: nowrap;
}
.m2-ticker { flex: 1; overflow: hidden; }
.m2-ticker-content { display: flex; align-items: center; height: 36px; }
.m2-nt-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 28px;
    font-size: 13px;
    color: var(--m2-text-sub);
    white-space: nowrap;
}
.m2-label { font-size: 10px; padding: 3px 10px; }

/* ============================================================
   HOME
   ============================================================ */
.hero-section,.m2-hero {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background: var(--m2-bg);
}
.hero-section .container { position: relative; z-index: 2; }
.hero-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(11,11,13,.95) 0%, rgba(20,20,22,.7) 100%);
    z-index: 1;
}
.hero-section .slider-text h2 {
    font-family: "Cinzel", serif;
    font-size: clamp(2rem, 5vw, 3.5rem);
    color: #fff;
    line-height: 1.15;
    text-shadow: 0 2px 20px rgba(0,0,0,.7);
    margin-bottom: 16px;
}
.hero-section .slider-text p {
    font-size: 1.05rem;
    color: var(--m2-text-sub);
    max-width: 520px;
    margin-bottom: 28px;
}
.m2-home-section { padding: 56px 0; }
.m2-home-section__title {
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 4px;
    position: relative;
    display: inline-block;
    padding-bottom: 10px;
}
.m2-home-section__title::after {
    content: "";
    position: absolute;
    bottom: 0; left: 0;
    width: 40px; height: 3px;
    background: var(--m2-gold);
    border-radius: 2px;
}
.m2-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}
.m2-card {
    background: var(--m2-bg-card);
    border: 1px solid var(--m2-border);
    border-radius: var(--m2-r-lg);
    overflow: hidden;
    transition: transform var(--m2-trans), border-color var(--m2-trans), box-shadow var(--m2-trans);
}
.m2-card:hover { transform: translateY(-4px); border-color: var(--m2-gold-border); box-shadow: var(--m2-shadow-gold); }
.m2-card__img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; }
.m2-card__body { padding: 18px 20px; }
.m2-card__meta { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.m2-card__date { font-size: 12px; color: var(--m2-text-muted); }
.m2-card__title { font-size: 1rem; font-weight: 600; color: #e8e8e8; margin-bottom: 8px; line-height: 1.4; }
.m2-card__title a { color: inherit; }
.m2-card__title a:hover { color: var(--m2-gold); }
.m2-card__excerpt { font-size: 13px; color: var(--m2-text-sub); line-height: 1.7; }
.m2-card__footer { padding: 12px 20px; border-top: 1px solid var(--m2-border); display: flex; justify-content: flex-end; }
.m2-counter-strip {
    background: var(--m2-bg-card);
    border-top: 1px solid var(--m2-border);
    border-bottom: 1px solid var(--m2-border);
    padding: 28px 0;
}
.m2-counter-strip .container { display: flex; justify-content: space-around; flex-wrap: wrap; gap: 24px; }
.m2-counter-item { text-align: center; }
.m2-counter-item__num { font-size: 2.2rem; font-weight: 700; color: var(--m2-gold); font-family: "Cinzel", serif; line-height: 1; }
.m2-counter-item__label { font-size: 12px; color: var(--m2-text-muted); text-transform: uppercase; letter-spacing: .06em; margin-top: 4px; }
.m2-server-info-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; margin-top: 24px; }
.m2-sinfo-box { background: var(--m2-bg-elevated); border: 1px solid var(--m2-border); border-radius: var(--m2-r-md); padding: 20px; text-align: center; }
.m2-sinfo-box__icon { font-size: 28px; color: var(--m2-gold); margin-bottom: 10px; }
.m2-sinfo-box__label { font-size: 11px; color: var(--m2-text-muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 4px; }
.m2-sinfo-box__val { font-size: 1.15rem; font-weight: 700; color: #fff; }

/* ============================================================
   DOWNLOADS
   ============================================================ */
.m2-dl-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; margin-top: 20px; }
.m2-dl-card {
    background: var(--m2-bg-card);
    border: 1px solid var(--m2-border);
    border-radius: var(--m2-r-md);
    padding: 24px 20px;
    display: flex; flex-direction: column; align-items: center;
    gap: 14px; text-align: center;
    transition: border-color var(--m2-trans), transform var(--m2-trans);
}
.m2-dl-card:hover { border-color: var(--m2-gold-border); transform: translateY(-3px); }
.m2-dl-card__icon { font-size: 40px; color: var(--m2-gold); }
.m2-dl-card__name { font-size: 1rem; font-weight: 600; color: #e8e8e8; }
.m2-dl-card__size { font-size: 12px; color: var(--m2-text-muted); }
.m2-dl-card .site-btn { width: 100%; }

/* ============================================================
   RULES
   ============================================================ */
.m2-rules-wrap { max-width: 820px; margin: 0 auto; }
.m2-rules-wrap h3 { font-size: 1.15rem; color: var(--m2-gold); margin: 2rem 0 .75rem; display: flex; align-items: center; gap: 8px; }
.m2-rules-wrap p { color: var(--m2-text-sub); font-size: 14px; line-height: 1.85; }
.m2-rules-wrap ul { list-style: disc; padding-left: 1.4em; margin-bottom: 1em; }
.m2-rules-wrap ul li { color: var(--m2-text-sub); font-size: 14px; line-height: 1.8; margin-bottom: 4px; }

/* ============================================================
   NEWS DETAIL
   ============================================================ */
.m2-news-detail { max-width: 860px; margin: 0 auto; background: var(--m2-bg-card); border: 1px solid var(--m2-border); border-radius: var(--m2-r-lg); overflow: hidden; }
.m2-news-detail__hero { width: 100%; max-height: 380px; object-fit: cover; display: block; }
.m2-news-detail__body { padding: 32px 36px; }
.m2-news-detail__title { font-size: 1.8rem; font-weight: 700; color: #fff; margin-bottom: 12px; line-height: 1.3; }
.m2-news-detail__meta { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; }
.m2-news-detail__meta span { font-size: 13px; color: var(--m2-text-muted); display: flex; align-items: center; gap: 5px; }
.m2-news-detail__content { font-size: 14.5px; line-height: 1.9; color: var(--m2-text-sub); }
.m2-news-detail__content h2,.m2-news-detail__content h3 { color: #fff; margin: 1.6em 0 .6em; }
.m2-news-detail__content img { max-width: 100%; border-radius: var(--m2-r-md); margin: 1em 0; }
.m2-news-detail__content table { width: 100%; border-collapse: collapse; margin: 1em 0; }
.m2-news-detail__content th,.m2-news-detail__content td { padding: 10px 14px; border: 1px solid var(--m2-border); font-size: 13.5px; }
.m2-news-detail__content th { background: var(--m2-bg-elevated); color: var(--m2-gold); }
@media(max-width:600px){ .m2-news-detail__body { padding: 20px 16px; } }

/* ============================================================
   RANKINGS
   ============================================================ */
.m2-ranking-section { padding: 0; }
.m2-ranking-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-bottom: 20px; }
.m2-ranking-header h2 { font-size: 1.5rem; color: #fff; }
.m2-ranking-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 20px; }
.m2-tab-btn { padding: 8px 18px; border: 1px solid var(--m2-border); border-radius: 20px; background: transparent; color: var(--m2-text-sub); font-size: 13px; cursor: pointer; transition: all var(--m2-trans); }
.m2-tab-btn:hover,.m2-tab-btn.active { background: var(--m2-gold); border-color: var(--m2-gold); color: #111; font-weight: 600; }
.m2-ranking-table-wrap { overflow-x: auto; border-radius: var(--m2-r-md); }
.m2-ranking-table { width: 100%; border-collapse: collapse; background: var(--m2-bg-card); min-width: 500px; }
.m2-ranking-table thead th { padding: 12px 16px; background: var(--m2-bg-elevated); color: var(--m2-gold); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; white-space: nowrap; border-bottom: 1px solid var(--m2-border); }
.m2-ranking-table tbody tr { border-bottom: 1px solid rgba(255,255,255,.04); transition: background var(--m2-trans); }
.m2-ranking-table tbody tr:hover { background: var(--m2-bg-elevated); }
.m2-ranking-table td { padding: 11px 16px; font-size: 13.5px; color: var(--m2-text); white-space: nowrap; vertical-align: middle; }
.m2-rank-badge { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border-radius: 50%; font-size: 12px; font-weight: 700; }
.m2-rank-badge.gold { background: rgba(255,179,32,.15); color: var(--m2-gold); }
.m2-rank-badge.silver { background: rgba(192,192,192,.15); color: #c0c0c0; }
.m2-rank-badge.bronze { background: rgba(205,127,50,.15); color: #cd7f32; }
.m2-rank-badge.other { background: var(--m2-bg-overlay); color: var(--m2-text-muted); }
.m2-status-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; vertical-align: middle; margin-right: 6px; }
.m2-status-dot.online { background: #4caf50; animation: m2-pulse 2s infinite; }
.m2-status-dot.offline { background: #555; }
.m2-class-img { width: 26px; height: 26px; object-fit: contain; border-radius: 4px; vertical-align: middle; }

/* ============================================================
   CASTLE SIEGE
   ============================================================ */
.m2-cs-wrap { max-width: 900px; margin: 0 auto; }
.m2-cs-hero { background: linear-gradient(135deg, #1a1014 0%, #130a18 100%); border: 1px solid var(--m2-border); border-radius: var(--m2-r-lg); padding: 40px; margin-bottom: 24px; text-align: center; }
.m2-cs-hero h2 { font-family: "Cinzel", serif; font-size: 2rem; color: var(--m2-gold); margin-bottom: 8px; }
.m2-cs-hero p { color: var(--m2-text-sub); margin-bottom: 20px; }
.m2-cs-owner-card { display: inline-flex; align-items: center; gap: 14px; background: rgba(255,179,32,.07); border: 1px solid var(--m2-gold-border); border-radius: var(--m2-r-md); padding: 14px 24px; }
.m2-cs-owner-card .owner-label { font-size: 11px; color: var(--m2-text-muted); text-transform: uppercase; letter-spacing: .06em; }
.m2-cs-owner-card .owner-guild { font-size: 1.2rem; font-weight: 700; color: var(--m2-gold); }
.m2-cs-timer { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 20px; }
.m2-cs-timer-box { background: var(--m2-bg-elevated); border: 1px solid var(--m2-border); border-radius: var(--m2-r-md); padding: 16px 20px; text-align: center; min-width: 72px; }
.m2-cs-timer-box .num { font-size: 2rem; font-weight: 700; color: var(--m2-gold); font-family: "Cinzel", serif; }
.m2-cs-timer-box .lbl { font-size: 10px; color: var(--m2-text-muted); text-transform: uppercase; letter-spacing: .05em; }

/* ============================================================
   TIMERS
   ============================================================ */
.m2-timers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
.m2-timer-card { background: var(--m2-bg-card); border: 1px solid var(--m2-border); border-radius: var(--m2-r-md); padding: 20px; }
.m2-timer-card__name { font-size: 15px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.m2-timer-card__next { font-size: 12px; color: var(--m2-text-muted); margin-bottom: 12px; }
.m2-timer-card__countdown { font-size: 1.6rem; font-weight: 700; color: var(--m2-gold); font-family: "Cinzel", serif; letter-spacing: .04em; }

/* ============================================================
   HALL OF FAME
   ============================================================ */
.m2-hof-section { padding: 48px 0; }
.m2-hof-podium { display: flex; align-items: flex-end; justify-content: center; gap: 16px; margin-bottom: 32px; flex-wrap: wrap; }
.m2-hof-podium-item { text-align: center; padding: 28px 24px 20px; border-radius: var(--m2-r-lg); border: 1px solid var(--m2-border); background: var(--m2-bg-card); min-width: 160px; transition: transform var(--m2-trans); }
.m2-hof-podium-item:hover { transform: translateY(-4px); }
.m2-hof-podium-item.rank-1 { background: linear-gradient(160deg,#1c1505 0%,#141416 100%); border-color: var(--m2-gold-border); box-shadow: var(--m2-shadow-gold); }
.m2-hof-podium-item.rank-2 { background: linear-gradient(160deg,#131418 0%,#141416 100%); border-color: rgba(192,192,192,.25); }
.m2-hof-podium-item.rank-3 { background: linear-gradient(160deg,#160f09 0%,#141416 100%); border-color: rgba(205,127,50,.25); }
.m2-hof-crown { font-size: 28px; margin-bottom: 8px; }
.m2-hof-avatar { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; margin: 0 auto 10px; border: 2px solid var(--m2-border); }
.m2-hof-name { font-size: 1rem; font-weight: 700; color: #fff; }
.m2-hof-guild { font-size: 12px; color: var(--m2-text-muted); margin-top: 4px; }
.m2-hof-badge { display: inline-block; margin-top: 8px; padding: 3px 12px; background: rgba(255,179,32,.12); border: 1px solid var(--m2-gold-border); border-radius: 20px; font-size: 11px; font-weight: 700; color: var(--m2-gold); }

/* ============================================================
   PROFILE
   ============================================================ */
.m2-profile-wrap { max-width: 900px; margin: 0 auto; display: grid; grid-template-columns: 280px 1fr; gap: 20px; align-items: start; }
@media(max-width:768px){ .m2-profile-wrap { grid-template-columns: 1fr; } }
.m2-profile-sidebar { background: var(--m2-bg-card); border: 1px solid var(--m2-border); border-radius: var(--m2-r-lg); padding: 28px; text-align: center; }
.m2-profile-avatar { width: 96px; height: 96px; border-radius: 50%; object-fit: cover; border: 3px solid var(--m2-gold); margin: 0 auto 14px; display: block; }
.m2-profile-name { font-size: 1.3rem; font-weight: 700; color: #fff; }
.m2-profile-class { font-size: 13px; color: var(--m2-gold); margin-top: 4px; }
.m2-profile-stats { margin-top: 20px; display: flex; flex-direction: column; gap: 10px; text-align: left; }
.m2-profile-stat { display: flex; justify-content: space-between; font-size: 13px; }
.m2-profile-stat__label { color: var(--m2-text-muted); }
.m2-profile-stat__val { color: #e8e8e8; font-weight: 600; }
.m2-profile-content { background: var(--m2-bg-card); border: 1px solid var(--m2-border); border-radius: var(--m2-r-lg); padding: 24px; }

/* ============================================================
   GUIDES
   ============================================================ */
.m2-guides-layout { display: grid; grid-template-columns: 260px 1fr; gap: 24px; align-items: start; }
@media(max-width:900px){ .m2-guides-layout { grid-template-columns: 1fr; } }
.m2-guides-sidebar { position: sticky; top: calc(var(--m2-header-h) + 16px); background: var(--m2-bg-card); border: 1px solid var(--m2-border); border-radius: var(--m2-r-lg); overflow: hidden; max-height: calc(100vh - var(--m2-header-h) - 32px); overflow-y: auto; }
.m2-guides-menu { list-style: none; padding: 0; margin: 0; }
.guide-category > .m2-guide-cat { padding: 12px 18px; font-size: 13px; font-weight: 700; color: var(--m2-text); cursor: pointer; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--m2-border); transition: color var(--m2-trans), background var(--m2-trans); }
.guide-category > .m2-guide-cat:hover { color: var(--m2-gold); background: var(--m2-bg-elevated); }
.m2-guide-submenu { list-style: none; padding: 0; margin: 0; background: var(--m2-bg-elevated); }
.m2-guide-submenu li a { display: block; padding: 9px 28px; font-size: 13px; color: var(--m2-text-sub); border-bottom: 1px solid rgba(255,255,255,.03); transition: color var(--m2-trans), background var(--m2-trans); }
.m2-guide-submenu li a:hover { color: var(--m2-gold); background: rgba(255,179,32,.06); padding-left: 34px; }
.m2-guide-content { background: var(--m2-bg-card); border: 1px solid var(--m2-border); border-radius: var(--m2-r-lg); padding: 32px; min-height: 400px; }
.m2-guide-content h1 { font-size: 1.8rem; color: #fff; margin-bottom: 16px; }
.m2-guide-content h2 { font-size: 1.3rem; color: var(--m2-gold); margin: 2em 0 .7em; }
.m2-guide-content p { font-size: 14.5px; line-height: 1.9; color: var(--m2-text-sub); margin-bottom: 1em; }
.m2-guide-content img { max-width: 100%; border-radius: var(--m2-r-md); margin: 1em 0; }
.m2-guide-content table { width: 100%; border-collapse: collapse; margin: 1em 0; overflow-x: auto; display: block; }
.m2-guide-content th,.m2-guide-content td { padding: 9px 14px; border: 1px solid var(--m2-border); font-size: 13.5px; }
.m2-guide-content th { background: var(--m2-bg-elevated); color: var(--m2-gold); }
@media(max-width:600px){ .m2-guide-content { padding: 20px 14px; } }

/* ============================================================
   CONTACT
   ============================================================ */
.m2-contact-wrap { max-width: 680px; margin: 0 auto; background: var(--m2-bg-card); border: 1px solid var(--m2-border); border-radius: var(--m2-r-lg); padding: 40px; }
.m2-contact-wrap h2 { font-size: 1.6rem; color: #fff; margin-bottom: 8px; }
.m2-contact-wrap p { color: var(--m2-text-sub); margin-bottom: 24px; }
.m2-form-group { margin-bottom: 18px; }
.m2-form-label { display: block; font-size: 13px; font-weight: 600; color: var(--m2-text-sub); margin-bottom: 6px; }
.m2-form-control { width: 100%; padding: 11px 14px; background: var(--m2-bg-input); border: 1px solid var(--m2-border); border-radius: var(--m2-r-sm); color: var(--m2-text); font-size: 14px; transition: border-color var(--m2-trans); }
.m2-form-control:focus { border-color: var(--m2-gold); }
textarea.m2-form-control { min-height: 130px; resize: vertical; }

/* ============================================================
   PAGINATION
   ============================================================ */
.m2-pagination { display: flex; justify-content: center; gap: 6px; flex-wrap: wrap; margin-top: 28px; }
.m2-pagination a,.m2-pagination span { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: 1px solid var(--m2-border); border-radius: var(--m2-r-sm); font-size: 13px; color: var(--m2-text-sub); transition: all var(--m2-trans); }
.m2-pagination a:hover { border-color: var(--m2-gold); color: var(--m2-gold); }
.m2-pagination .active { background: var(--m2-gold); border-color: var(--m2-gold); color: #111; font-weight: 700; }

/* ============================================================
   ALERTS
   ============================================================ */
.m2-alert { padding: 14px 18px; border-radius: var(--m2-r-md); font-size: 14px; margin-bottom: 16px; display: flex; align-items: flex-start; gap: 10px; border: 1px solid transparent; }
.m2-alert-info { background: rgba(21,101,192,.12); border-color: rgba(21,101,192,.35); color: #90caf9; }
.m2-alert-success { background: rgba(46,125,50,.12); border-color: rgba(46,125,50,.35); color: #a5d6a7; }
.m2-alert-warning { background: rgba(245,124,0,.1); border-color: rgba(245,124,0,.35); color: #ffcc80; }
.m2-alert-danger { background: rgba(183,28,28,.12); border-color: rgba(183,28,28,.35); color: #ef9a9a; }
.alert-danger,.alert.alert-danger { background: rgba(183,28,28,.12) !important; border-color: rgba(183,28,28,.35) !important; color: #ef9a9a !important; border-radius: var(--m2-r-md); }
.alert-success,.alert.alert-success { background: rgba(46,125,50,.12) !important; border-color: rgba(46,125,50,.35) !important; color: #a5d6a7 !important; border-radius: var(--m2-r-md); }
.alert-info,.alert.alert-info { background: rgba(21,101,192,.12) !important; border-color: rgba(21,101,192,.35) !important; color: #90caf9 !important; border-radius: var(--m2-r-md); }
.alert-warning,.alert.alert-warning { background: rgba(245,124,0,.1) !important; border-color: rgba(245,124,0,.35) !important; color: #ffcc80 !important; border-radius: var(--m2-r-md); }

/* ============================================================
   PAGE HEADER / BREADCRUMB
   ============================================================ */
.m2-page-header { padding: 28px 0 16px; border-bottom: 1px solid var(--m2-border); margin-bottom: 28px; }
.m2-page-header h1 { font-size: 1.8rem; font-weight: 700; color: #fff; margin-bottom: 6px; }
.m2-breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--m2-text-muted); }
.m2-breadcrumb a { color: var(--m2-gold); }

/* ============================================================
   GENERIC TABLE
   ============================================================ */
.m2-table-wrap { overflow-x: auto; border-radius: var(--m2-r-md); }
.m2-table { width: 100%; border-collapse: collapse; background: var(--m2-bg-card); min-width: 400px; }
.m2-table thead th { padding: 11px 15px; background: var(--m2-bg-elevated); color: var(--m2-gold); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; border-bottom: 1px solid var(--m2-border); white-space: nowrap; }
.m2-table tbody tr { border-bottom: 1px solid rgba(255,255,255,.04); }
.m2-table tbody tr:hover { background: var(--m2-bg-elevated); }
.m2-table td { padding: 10px 15px; font-size: 13.5px; color: var(--m2-text); vertical-align: middle; }
.m2-table td a { color: var(--m2-gold); }

/* ============================================================
   USERCP
   ============================================================ */
.m2-ucp-wrap { max-width: 720px; margin: 0 auto; }
.m2-ucp-card { background: var(--m2-bg-card); border: 1px solid var(--m2-border); border-radius: var(--m2-r-lg); padding: 32px; margin-bottom: 20px; }
.m2-ucp-card h3 { font-size: 1.1rem; color: var(--m2-gold); margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid var(--m2-border); }

/* ============================================================
   LIVE STREAMS FAB + PANEL
   ============================================================ */
/* When mobile nav is open, push live button behind it */
.m2-nav-open .sp-live-fab,
.m2-nav-open #stream-panel {
  z-index: 990 !important;
}

/* ---- Floating LIVE button ---- */
.sp-live-fab {
  position: fixed;
  left: 16px;
  top: 70px;
  display: none; /* JS sets to flex when streams > 0 */
  align-items: center;
  gap: 6px;
  padding: 7px 11px 7px 9px;
  border-radius: 999px;
  cursor: pointer;
  z-index: 10000;
  backdrop-filter: blur(10px);
  background: rgb(0 0 0 / 82%);
  border: 1px solid rgb(255 179 32 / 45%);
  box-shadow: 0 4px 16px rgb(255 179 32 / 18%);
  transition: transform 0.2s ease, box-shadow 0.3s ease;
  user-select: none;
}
.sp-live-fab:hover {
  transform: translateY(-2px) scale(1.06);
  box-shadow: 0 6px 22px rgb(255 179 32 / 45%);
}

/* Pulsing red dot */
.sp-live-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ff4444;
  flex: 0 0 auto;
  animation: sp-rec 1.4s ease-in-out infinite;
}
@keyframes sp-rec {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.15; }
}

/* "LIVE" text label */
.sp-live-label {
  color: #ffb320;
  font: 700 11px/1 system-ui, sans-serif;
  letter-spacing: 1px;
  flex: 0 0 auto;
}

/* Total count badge */
.sp-live-count {
  display: none; /* JS sets to inline-flex when > 0 */
  align-items: center;
  justify-content: center;
  min-width: 17px;
  height: 17px;
  padding: 0 4px;
  border-radius: 999px;
  background: #ffb320;
  color: #000;
  font: 700 9px/1 system-ui, sans-serif;
  flex: 0 0 auto;
}

/* ---- Stream panel ---- */
#stream-panel {
  position: fixed;
  left: 16px;
  top: 116px;
  width: min(92vw, 420px);
  max-height: min(70vh, 560px);
  background: rgb(0 0 0 / 90%);
  color: #e8e8e8;
  border: 1px solid rgb(255 179 32 / 35%);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgb(255 179 32 / 15%), inset 0 1px 0 rgb(255 179 32 / 8%);
  z-index: 10000;
  backdrop-filter: blur(14px) saturate(150%);
}
#stream-panel[hidden] { display: none !important; }
#stream-panel .sp-header {
  display: flex;
  align-items: center;
  padding: 8px 10px;
  background: rgb(255 179 32 / 8%);
  border-bottom: 1px solid rgb(255 179 32 / 20%);
  gap: 6px;
}
#stream-panel .sp-body {
  padding: 8px;
  overflow: auto;
  max-height: calc(70vh - 90px);
}

/* ---- Tabs bar ---- */
.sp-tabs-bar {
  display: flex;
  gap: 4px;
  flex: 1;
}
.sp-tab-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1px solid transparent;
  background: transparent;
  color: #888;
  font: 600 12px/1 system-ui, sans-serif;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.sp-tab-btn.active {
  background: rgb(255 179 32 / 15%);
  border-color: rgb(255 179 32 / 30%);
  color: #ffb320;
}
.sp-tab-btn:hover:not(.active) {
  background: rgb(255 255 255 / 5%);
  color: #ccc;
}
.sp-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 16px;
  height: 16px;
  padding: 0 3px;
  border-radius: 999px;
  background: rgb(255 179 32 / 20%);
  color: #ffb320;
  font: 700 9px/1 system-ui, sans-serif;
}

/* ---- Close button ---- */
#sp-close {
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #888;
  flex: 0 0 auto;
}
#sp-close:hover { color: #ffb320; }
#sp-close .close-icon { width: 18px; height: 18px; display: block; pointer-events: none; }

/* ---- Stream cards ---- */
.sp-card {
  display: flex;
  gap: 10px;
  padding: 8px;
  border-radius: 8px;
  text-decoration: none !important;
  color: inherit;
  border: 1px solid rgb(255 179 32 / 10%);
  background: rgb(255 179 32 / 4%);
  transition: all 0.2s ease;
  margin-bottom: 6px;
}
.sp-card:hover {
  background: rgb(255 179 32 / 12%);
  border-color: rgb(255 179 32 / 40%);
  color: inherit;
}
.sp-card .thumb {
  width: 120px;
  height: 68px;
  background: #0d0b00;
  border-radius: 6px;
  overflow: hidden;
  flex: 0 0 auto;
  box-shadow: 0 0 10px rgb(255 179 32 / 12%);
}
.sp-card .thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sp-card .meta { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.sp-card .title {
  font: 600 13px/1.2 system-ui, sans-serif;
  color: #ffb320;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sp-card .ch { display: flex; align-items: center; gap: 8px; color: #aaa; font: 500 12px/1 system-ui, sans-serif; }
.sp-badge { padding: 2px 6px; border-radius: 999px; font: 700 10px/1 system-ui, sans-serif; text-transform: uppercase; letter-spacing: .4px; }
.sp-badge.twitch { background: rgb(145 70 255 / 20%); color: #bf94ff; border: 1px solid rgb(145 70 255 / 40%); }
.sp-badge.youtube { background: rgb(255 0 0 / 20%); color: #ff6666; border: 1px solid rgb(255 0 0 / 40%); }
.sp-card .viewers { margin-left: auto; color: #ffb320; }
.sp-card .user { font-size: 11px; color: #aaa; }
.sp-empty, .sp-loading, .sp-error { padding: 14px; color: #888; text-align: center; font-size: 13px; }
@media(max-width:480px){ #stream-panel { width: calc(100vw - 24px); left: 12px; } }

/* ============================================================
   ADMIN CP BUTTON (injected by CMS for admins)
   ============================================================ */
.a-button {
    position: fixed;
    top: 70px;
    right: 10px;
    z-index: 9999;
    background: #fff !important;
    border: 2px solid #000 !important;
    color: #000 !important;
    font-weight: 700 !important;
    border-radius: 6px;
    padding: 6px 14px;
    font-size: 13px;
    text-decoration: none;
    box-shadow: 0 2px 8px rgba(0,0,0,.4);
}
.a-button:hover {
    background: #ffb320 !important;
    border-color: #ffb320 !important;
    color: #000 !important;
}

/* ============================================================
   FOOTER
   ============================================================ */
.m2-footer { background: var(--m2-bg-card); border-top: 1px solid var(--m2-border); padding: 24px 0; margin-top: auto; }
.m2-footer-inner { max-width: 1180px; margin: 0 auto; padding: 0 20px; }
.m2-copy { font-size: 13px; color: var(--m2-text-muted); margin: 0; }
.m2-social { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border: 1px solid var(--m2-border); border-radius: 50%; color: var(--m2-text-muted); margin-left: 8px; transition: border-color var(--m2-trans), color var(--m2-trans), background var(--m2-trans); }
.m2-social:hover { border-color: var(--m2-gold); color: var(--m2-gold); background: rgba(255,179,32,.07); }
.m2-social i { font-size: 16px !important; }

/* ============================================================
   PAGE INFO SECTION (banner at top of inner pages)
   ============================================================ */
.page-info-section { height: 320px; position: relative; }
.page-info-section .pi-content { position: absolute; width: 100%; bottom: 65px; left: 0; z-index: 2; }
.page-info-section .pi-content h2 { font-size: 60px; margin-bottom: 25px; font-weight: 400; }

/* ============================================================
   CKEDITOR / RICH TEXT OUTPUT
   ============================================================ */
.ck-content,.ckeditor-output { font-size: 14.5px; line-height: 1.9; color: var(--m2-text-sub); }
.ck-content h2,.ckeditor-output h2 { color: #fff; font-size: 1.35rem; margin: 1.6em 0 .6em; }
.ck-content h3,.ckeditor-output h3 { color: var(--m2-gold); font-size: 1.1rem; margin: 1.2em 0 .5em; }
.ck-content img,.ckeditor-output img { max-width: 100%; border-radius: var(--m2-r-md); }
.ck-content figure.image,.ckeditor-output figure.image { margin: 1em auto; display: block; text-align: center; }
.ck-content figure.image img,.ckeditor-output figure.image img { max-width: 100%; height: auto; display: block; margin: 0 auto; }
.ck-content table,.ckeditor-output table { width: 100%; border-collapse: collapse; }
.ck-content th,.ckeditor-output th { background: var(--m2-bg-elevated); color: var(--m2-gold); padding: 9px 14px; border: 1px solid var(--m2-border); }
.ck-content td,.ckeditor-output td { padding: 9px 14px; border: 1px solid var(--m2-border); color: var(--m2-text-sub); font-size: 13.5px; }

/* ============================================================
   UTILITIES + MISC
   ============================================================ */
.text-gold { color: var(--m2-gold) !important; }
.text-muted-m2 { color: var(--m2-text-muted) !important; }
.visually-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
.m2-ref-wrap { display: flex; gap: 8px; align-items: center; max-width: 480px; }
.m2-ref-wrap input { flex: 1; background: var(--m2-bg-input); border: 1px solid var(--m2-border); border-radius: var(--m2-r-sm); color: var(--m2-text); padding: 9px 12px; font-size: 13px; }
.m2-skeleton { background: var(--m2-bg-elevated); border-radius: var(--m2-r-sm); position: relative; overflow: hidden; }
.m2-skeleton::after { content: ""; position: absolute; top: 0; left: -100%; bottom: 0; width: 60%; background: linear-gradient(90deg, transparent, rgba(255,255,255,.04), transparent); animation: shimmer-gray 1.4s infinite; }
.m2-zoom-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.88); z-index: 9999; display: flex; align-items: center; justify-content: center; cursor: zoom-out; }
.m2-zoom-overlay img { max-width: 92vw; max-height: 90vh; border-radius: var(--m2-r-md); box-shadow: 0 24px 80px rgba(0,0,0,.8); }
.cookie-notice-pro-container { background: #141416 !important; border: 1px solid var(--m2-border) !important; border-radius: var(--m2-r-lg) !important; }
.cookie-notice-pro-btn.accept { background: var(--m2-gold) !important; color: #111 !important; }
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--m2-bg); }
::-webkit-scrollbar-thumb { background: #333; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--m2-gold-dim); }
:focus-visible { outline: 2px solid var(--m2-gold); outline-offset: 2px; }

/* ── END ── */
