/* SlotStruck upgraded UI */
:root{
    --ss-bg:#05070d;
    --ss-bg2:#0b101a;
    --ss-panel:#101826;
    --ss-panel2:#151f31;
    --ss-line:rgba(167,184,216,.18);
    --ss-text:#f7f9ff;
    --ss-muted:#aebbd4;
    --ss-purple:#855cff;
    --ss-blue:#00d4ff;
    --ss-green:#21e891;
    --ss-gold:#ffd76a;
    --ss-danger:#ff4d7d;
    --ss-radius:18px;
    --ss-shadow:0 24px 70px rgba(0,0,0,.42);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    background:
        radial-gradient(circle at 22% 0%,rgba(133,92,255,.18),transparent 32rem),
        radial-gradient(circle at 78% 8%,rgba(0,212,255,.12),transparent 30rem),
        linear-gradient(180deg,#05070d,#070b12 35%,#05070d);
    color:var(--ss-text);
    font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    min-height:100vh;
}

a{color:inherit}
img{max-width:100%}
.ss-container{width:min(1400px,calc(100% - 40px));margin-inline:auto}

.ss-site-header{
    position:sticky;
    top:0;
    z-index:100;
    background:rgba(5,7,13,.82);
    backdrop-filter:blur(18px);
    border-bottom:1px solid var(--ss-line);
}
.ss-header-inner{
    width:min(1530px,calc(100% - 40px));
    margin:auto;
    height:82px;
    display:flex;
    align-items:center;
    gap:26px;
}
.ss-logo img{width:236px;height:auto;display:block}
.ss-main-nav{
    margin-left:auto;
    display:flex;
    align-items:center;
    gap:8px;
}
.ss-main-nav a{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:12px 14px;
    border-radius:999px;
    color:#dce5f8;
    text-decoration:none;
    font-size:13px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.02em;
    transition:.2s ease;
}
.ss-main-nav a svg{width:16px;height:16px;fill:currentColor}
.ss-main-nav a:hover,.ss-main-nav a.is-active{
    background:linear-gradient(135deg,rgba(133,92,255,.22),rgba(0,212,255,.12));
    color:white;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
.ss-header-search{
    width:245px;
    height:44px;
    display:flex;
    align-items:center;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.12);
    border-radius:999px;
    overflow:hidden;
}
.ss-header-search input{
    flex:1;
    min-width:0;
    background:transparent;
    border:0;
    outline:0;
    color:white;
    padding:0 0 0 16px;
}
.ss-header-search button{
    width:44px;
    height:44px;
    border:0;
    background:transparent;
    color:white;
    cursor:pointer;
}
.ss-header-search svg{width:20px;height:20px;fill:currentColor}
.ss-mobile-toggle{display:none}

.ss-page{padding-bottom:70px}
.ss-hero-section{
    position:relative;
    overflow:hidden;
    padding:78px 0 54px;
}
.ss-hero-bg{position:absolute;inset:0;pointer-events:none}
.ss-lightning-orb{
    position:absolute;
    width:360px;
    height:360px;
    filter:blur(30px);
    border-radius:999px;
    opacity:.35;
    animation:ssFloat 8s ease-in-out infinite;
}
.ss-lightning-orb.one{left:8%;top:6%;background:var(--ss-purple)}
.ss-lightning-orb.two{right:12%;top:12%;background:var(--ss-blue);animation-delay:-3s}
@keyframes ssFloat{50%{transform:translateY(20px) scale(1.08)}}

.ss-hero-grid{
    position:relative;
    display:grid;
    grid-template-columns:minmax(0,1.1fr) 440px;
    gap:44px;
    align-items:center;
}
.ss-kicker{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:#a8f4ff;
    font-size:13px;
    font-weight:900;
    letter-spacing:.12em;
    text-transform:uppercase;
}
.ss-kicker svg{width:18px;height:18px;fill:var(--ss-blue)}
.ss-hero-copy h1{
    max-width:780px;
    margin:16px 0;
    font-size:clamp(46px,7vw,92px);
    line-height:.9;
    letter-spacing:-.07em;
    text-transform:uppercase;
}
.ss-hero-copy p{
    max-width:720px;
    color:#c7d2e8;
    font-size:18px;
    line-height:1.7;
}
.ss-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:28px 0}
.ss-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:52px;
    padding:0 22px;
    border-radius:14px;
    color:white;
    text-decoration:none;
    border:1px solid rgba(255,255,255,.14);
    background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
    font-weight:950;
    cursor:pointer;
    transition:.22s ease;
}
.ss-btn svg{width:18px;height:18px;fill:currentColor}
.ss-btn:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.28)}
.ss-btn-primary{background:linear-gradient(135deg,var(--ss-purple),#a557ff 55%,#28d7ff);box-shadow:0 18px 45px rgba(133,92,255,.28)}
.ss-btn-ghost{background:rgba(255,255,255,.05)}
.ss-btn-small{min-height:44px;padding-inline:16px;border-radius:12px;font-size:13px}

.ss-stat-pills{display:flex;gap:10px;flex-wrap:wrap}
.ss-stat-pills span{
    display:inline-flex;
    gap:8px;
    align-items:center;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.1);
    padding:10px 14px;
    border-radius:999px;
    color:#cbd6ec;
}
.ss-stat-pills strong{color:white}

.ss-hero-panel{
    background:linear-gradient(180deg,rgba(16,24,38,.92),rgba(10,14,24,.92));
    border:1px solid rgba(255,255,255,.13);
    border-radius:26px;
    box-shadow:var(--ss-shadow);
    padding:18px;
}
.ss-panel-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin-bottom:10px;
    color:#dbe6ff;
    font-weight:900;
}
.ss-panel-top span{display:flex;align-items:center;gap:8px}
.ss-panel-top svg{width:18px;height:18px;fill:var(--ss-gold)}
.ss-panel-top a{color:#9eeeff;text-decoration:none;font-size:13px}
.ss-mini-list{display:grid;gap:10px}
.ss-mini-slot{
    display:grid;
    grid-template-columns:78px 1fr 18px;
    gap:12px;
    align-items:center;
    padding:10px;
    text-decoration:none;
    border-radius:16px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.06);
    transition:.18s ease;
}
.ss-mini-slot:hover{background:rgba(255,255,255,.08);transform:translateX(3px)}
.ss-mini-slot img{width:78px;height:50px;object-fit:cover;border-radius:11px}
.ss-mini-slot strong{display:block;font-size:14px}
.ss-mini-slot small{display:block;color:#aebbd4;margin-top:3px}
.ss-mini-slot svg{width:18px;height:18px;fill:#b8c6e0}

.ss-section-head{
    margin:58px 0 22px;
    display:flex;
    justify-content:space-between;
    align-items:end;
    gap:24px;
}
.ss-section-head h2{
    margin:8px 0 6px;
    font-size:clamp(30px,4vw,52px);
    text-transform:uppercase;
    letter-spacing:-.045em;
}
.ss-section-head p{margin:0;color:#b8c4dc}

.ss-layout-with-sidebar{
    display:grid;
    grid-template-columns:minmax(0,1fr) 340px;
    gap:28px;
    align-items:start;
}
.ss-home-sidebar{display:grid;gap:22px}
.ss-side-card{
    padding:20px;
    border-radius:var(--ss-radius);
    background:linear-gradient(180deg,rgba(18,27,43,.92),rgba(9,13,22,.92));
    border:1px solid var(--ss-line);
}
.ss-side-card h3{margin:0 0 16px;display:flex;align-items:center;gap:10px;text-transform:uppercase}
.ss-side-card h3 svg{width:18px;height:18px;fill:var(--ss-gold)}
.ss-side-card a{
    display:flex;
    justify-content:space-between;
    gap:12px;
    padding:12px 0;
    border-top:1px solid rgba(255,255,255,.08);
    text-decoration:none;
}
.ss-side-card a span{font-weight:800}
.ss-side-card a strong{color:#9eeeff;white-space:nowrap}

.ss-slot-grid{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:18px;
}
.ss-slot-grid-wide{grid-template-columns:repeat(5,minmax(0,1fr))}
.ss-slot-card{
    position:relative;
    display:block;
    overflow:hidden;
    border-radius:18px;
    background:linear-gradient(180deg,rgba(15,23,37,.98),rgba(8,11,18,.98));
    border:1px solid rgba(170,189,220,.16);
    color:white;
    text-decoration:none;
    box-shadow:0 12px 36px rgba(0,0,0,.28);
    transition:.22s ease;
}
.ss-slot-card:hover{transform:translateY(-6px);border-color:rgba(0,212,255,.32);box-shadow:0 20px 60px rgba(0,212,255,.1)}
.ss-slot-art{position:relative;aspect-ratio:300/173;overflow:hidden;background:#111927}
.ss-slot-art img{width:100%;height:100%;object-fit:cover;display:block;transition:.3s ease}
.ss-slot-card:hover .ss-slot-art img{transform:scale(1.05)}
.ss-status-badge{
    position:absolute;
    left:10px;
    top:10px;
    z-index:2;
    padding:6px 10px;
    border-radius:999px;
    background:linear-gradient(135deg,#1d1171,#6c4cff);
    border:1px solid rgba(255,255,255,.3);
    font-size:11px;
    font-weight:950;
    box-shadow:0 8px 22px rgba(0,0,0,.32);
}
.ss-card-glow{
    position:absolute;
    inset:auto 0 0;
    height:46%;
    background:linear-gradient(transparent,rgba(0,0,0,.75));
}
.ss-slot-body{padding:14px}
.ss-slot-body h3{margin:0 0 8px;font-size:17px;line-height:1.18}
.ss-slot-body p{margin:0 0 12px;color:#c7d3e9}
.ss-slot-meta{display:flex;gap:10px;flex-wrap:wrap;color:#d7e4f7;font-size:12px}
.ss-slot-meta span{display:inline-flex;align-items:center;gap:5px}
.ss-slot-meta svg{width:14px;height:14px;fill:#9eeeff}

.ss-search-hero,.ss-calendar-hero{
    margin:42px 0 30px;
    padding:34px;
    border-radius:28px;
    background:linear-gradient(135deg,rgba(21,31,49,.92),rgba(9,13,23,.96));
    border:1px solid var(--ss-line);
    box-shadow:var(--ss-shadow);
}
.ss-search-hero h1,.ss-calendar-hero h1{
    margin: 8px 0 6px;
    font-size: clamp(34px, 5vw, 66px);
    line-height: .9;
    letter-spacing: -.025em;
    text-transform: uppercase;
}
.ss-search-hero p,.ss-calendar-hero p{color:#becae1}
.ss-big-search{display:flex;gap:12px;margin-top:22px}
.ss-big-search input{
    flex:1;
    min-height:58px;
    border-radius:16px;
    border:1px solid rgba(255,255,255,.14);
    background:rgba(255,255,255,.06);
    color:white;
    padding:0 18px;
    font-size:16px;
    outline:0;
}
.ss-search-results{display:grid;gap:12px}
.ss-search-result{
    display:grid;
    grid-template-columns:130px 1fr 20px;
    gap:16px;
    align-items:center;
    padding:12px;
    border-radius:18px;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.08);
    text-decoration:none;
    transition:.2s ease;
}
.ss-search-result:hover{transform:translateX(4px);background:rgba(255,255,255,.08)}
.ss-search-result img{width:130px;height:75px;object-fit:cover;border-radius:13px}
.ss-search-result strong{font-size:18px;display:block}
.ss-search-result small{color:#b9c5dc;margin-top:5px;display:block}
.ss-search-result svg{width:20px;height:20px;fill:#9eeeff}
.ss-empty-state{
    padding:54px 24px;
    text-align:center;
    border-radius:24px;
    border:1px dashed rgba(255,255,255,.18);
    background:rgba(255,255,255,.03);
    color:#bfcce5;
}
.ss-empty-state svg{width:40px;height:40px;fill:var(--ss-blue)}

.ss-calendar-hero{display:flex;justify-content:space-between;align-items:end;gap:22px}
.ss-calendar-controls{display:flex;gap:10px;flex-wrap:wrap}
.ss-calendar-grid{
    display:grid;
    grid-template-columns:repeat(7,minmax(0,1fr));
    gap:10px;
}
.ss-calendar-weekday{
    color:#94a3bd;
    font-size:12px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.1em;
    padding:0 8px 4px;
}
.ss-calendar-day{
    min-height:168px;
    padding:12px;
    border-radius:18px;
    background:linear-gradient(180deg,rgba(18,27,43,.9),rgba(9,13,22,.9));
    border:1px solid rgba(255,255,255,.1);
}
.ss-calendar-day.is-muted{opacity:.38}
.ss-calendar-day.is-today{border-color:rgba(0,212,255,.6);box-shadow:0 0 0 1px rgba(0,212,255,.18),0 18px 50px rgba(0,212,255,.08)}
.ss-day-number{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.ss-day-number span{font-weight:950}
.ss-day-number strong{font-size:12px;background:var(--ss-purple);border-radius:999px;padding:3px 8px}
.ss-day-slots{display:grid;gap:7px}
.ss-calendar-slot{
    display:grid;
    grid-template-columns:42px minmax(0,1fr);
    gap:8px;
    align-items:center;
    text-decoration:none;
    padding:6px;
    border-radius:11px;
    background:rgba(255,255,255,.04);
}
.ss-calendar-slot img{width:42px;height:28px;object-fit:cover;border-radius:7px}
.ss-calendar-slot strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px}
.ss-calendar-slot small{display:block;color:#aebbd4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11px}
.ss-more-slots{font-size:12px;color:#9eeeff}

.ss-timeline{display:grid;gap:18px}
.ss-timeline-date{display:grid;grid-template-columns:44px 1fr;gap:14px}
.ss-timeline-marker{
    width:44px;height:44px;border-radius:999px;
    display:grid;place-items:center;
    background:linear-gradient(135deg,var(--ss-purple),var(--ss-blue));
}
.ss-timeline-marker svg{width:22px;height:22px;fill:white}
.ss-timeline-content{
    background:rgba(255,255,255,.045);
    border:1px solid rgba(255,255,255,.09);
    border-radius:20px;
    padding:18px;
}
.ss-timeline-content h3{margin:0 0 12px}
.ss-timeline-slots{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.ss-timeline-slots a{
    display:grid;
    grid-template-columns:80px 1fr;
    gap:10px;
    align-items:center;
    text-decoration:none;
    padding:8px;
    border-radius:14px;
    background:rgba(255,255,255,.04);
}
.ss-timeline-slots img{width:80px;height:48px;object-fit:cover;border-radius:10px}
.ss-timeline-slots strong,.ss-timeline-slots small{display:block}
.ss-timeline-slots small{color:#aebbd4}

@media(max-width:1200px){
    .ss-slot-grid,.ss-slot-grid-wide{grid-template-columns:repeat(4,minmax(0,1fr))}
    .ss-layout-with-sidebar{grid-template-columns:1fr}
    .ss-home-sidebar{grid-template-columns:1fr 1fr}
}
@media(max-width:940px){
    .ss-header-inner{height:auto;min-height:76px;flex-wrap:wrap;padding:14px 0}
    .ss-mobile-toggle{display:flex;margin-left:auto;width:42px;height:42px;border:1px solid rgba(255,255,255,.14);border-radius:12px;background:rgba(255,255,255,.06);align-items:center;justify-content:center;flex-direction:column;gap:5px}
    .ss-mobile-toggle span{width:18px;height:2px;background:white;border-radius:99px}
    .ss-main-nav{display:none;order:3;width:100%;margin-left:0;flex-direction:column;align-items:stretch}
    .ss-main-nav.is-open{display:flex}
    .ss-main-nav a{justify-content:center}
    .ss-header-search{order:4;width:100%;display:flex}
    .ss-hero-grid{grid-template-columns:1fr}
    .ss-slot-grid,.ss-slot-grid-wide{grid-template-columns:repeat(3,minmax(0,1fr))}
    .ss-calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .ss-calendar-weekday{display:none}
    .ss-calendar-hero{display:block}
    .ss-calendar-controls{margin-top:18px}
    .ss-timeline-slots{grid-template-columns:1fr}
}
@media(max-width:640px){
    .ss-container,.ss-header-inner{width:min(100% - 24px,1400px)}
    .ss-logo img{width:190px}
    .ss-hero-section{padding:42px 0}
    .ss-hero-copy h1{font-size:44px}
    .ss-slot-grid,.ss-slot-grid-wide{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
    .ss-slot-body h3{font-size:15px}
    .ss-section-head{display:block}
    .ss-home-sidebar{grid-template-columns:1fr}
    .ss-big-search{display:block}
    .ss-big-search .ss-btn{width:100%;margin-top:10px}
    .ss-search-result{grid-template-columns:90px 1fr 18px}
    .ss-search-result img{width:90px;height:56px}
    .ss-calendar-grid{grid-template-columns:1fr}
}


/* Compact homepage + upgraded footer */
.ss-home-compact{
    padding-top:0;
}

.ss-home-topbar{
    position:relative;
    overflow:hidden;
    padding:12px 0 18px;
    border-bottom:1px solid rgba(255,255,255,.06);
    background:
        radial-gradient(circle at 18% 0%,rgba(133,92,255,.20),transparent 34rem),
        radial-gradient(circle at 82% 0%,rgba(0,212,255,.12),transparent 32rem),
        linear-gradient(180deg,rgba(9,14,24,.82),rgba(5,7,13,.22));
}

.ss-home-topbar::after{
    content:"";
    position:absolute;
    inset:auto 0 0;
    height:1px;
    background:linear-gradient(90deg,transparent,rgba(0,212,255,.55),rgba(133,92,255,.55),transparent);
}

.ss-home-topbar-inner{
    position:relative;
    display:flex;
    align-items:end;
    justify-content:space-between;
    gap:22px;
}

.ss-home-topbar h1{
    margin:8px 0 6px;
    font-size:clamp(34px,5vw,68px);
    line-height:.9;
    letter-spacing:-.06em;
    text-transform:uppercase;
}

.ss-home-topbar p{
    margin:0;
    color:#c3cfe6;
    font-size:16px;
}

.ss-home-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    justify-content:flex-end;
}

.ss-section-head-tight{
    margin-top:30px;
}

.ss-slot-grid-featured{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:22px;
}

.ss-slot-card-xl{
    border-radius:22px;
}

.ss-slot-card-xl .ss-slot-body{
    padding:17px;
}

.ss-slot-card-xl .ss-slot-body h3{
    font-size:20px;
}

.ss-slot-card-xl .ss-slot-body p{
    font-size:15px;
}

.ss-grid-ad-card{
    min-height:100%;
    border-radius:22px;
    overflow:hidden;
    background:
        linear-gradient(180deg,rgba(19,29,47,.9),rgba(8,12,21,.94));
    border:1px solid rgba(170,189,220,.18);
    box-shadow:0 12px 36px rgba(0,0,0,.28);
    display:flex;
    align-items:center;
    justify-content:center;
}

.ss-grid-ad-card .ad,
.ss-grid-ad-card .ss-ad,
.ss-grid-ad-card > *{
    width:100%;
    min-height:100%;
    border-radius:22px;
}

.ss-grid-ad-card .ss-ad-sidebar{
    min-height:360px;
}

.ss-site-footer{
    position:relative;
    margin-top:74px;
    padding:54px 0 24px;
    overflow:hidden;
    background:
        radial-gradient(circle at 15% 0%,rgba(133,92,255,.18),transparent 28rem),
        radial-gradient(circle at 85% 15%,rgba(0,212,255,.13),transparent 30rem),
        linear-gradient(180deg,#080d16,#05070d);
    border-top:1px solid rgba(255,255,255,.10);
}

.ss-footer-strike{
    position:absolute;
    top:0;
    left:0;
    right:0;
    height:1px;
    background:linear-gradient(90deg,transparent,var(--ss-blue),var(--ss-purple),var(--ss-gold),transparent);
}

.ss-footer-grid{
    display:grid;
    grid-template-columns:minmax(0,1.5fr) .7fr .7fr 1fr;
    gap:34px;
    align-items:start;
}

.ss-footer-logo img{
    width:230px;
    display:block;
    margin-bottom:18px;
}

.ss-footer-brand p,
.ss-footer-panel p{
    color:#b9c6dd;
    line-height:1.7;
    margin:0 0 18px;
}

.ss-footer-badges{
    display:flex;
    gap:9px;
    flex-wrap:wrap;
}

.ss-footer-badges span{
    display:inline-flex;
    align-items:center;
    gap:7px;
    padding:8px 11px;
    border-radius:999px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.10);
    color:#dce6f8;
    font-size:12px;
    font-weight:800;
}

.ss-footer-badges svg{
    width:14px;
    height:14px;
    fill:var(--ss-blue);
}

.ss-footer-col h3,
.ss-footer-panel h3{
    margin:0 0 16px;
    font-size:15px;
    text-transform:uppercase;
    letter-spacing:.08em;
    color:#fff;
}

.ss-footer-col a{
    display:block;
    padding:7px 0;
    color:#b9c6dd;
    text-decoration:none;
    transition:.18s ease;
}

.ss-footer-col a:hover{
    color:#fff;
    transform:translateX(3px);
}

.ss-footer-panel{
    padding:20px;
    border-radius:22px;
    background:linear-gradient(180deg,rgba(19,29,47,.88),rgba(9,13,22,.92));
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 18px 50px rgba(0,0,0,.26);
}

.ss-footer-panel h3{
    display:flex;
    align-items:center;
    gap:9px;
}

.ss-footer-panel h3 svg{
    width:18px;
    height:18px;
    fill:var(--ss-gold);
}

.ss-footer-bottom{
    margin-top:34px;
    padding-top:20px;
    border-top:1px solid rgba(255,255,255,.08);
    display:flex;
    justify-content:space-between;
    gap:16px;
    flex-wrap:wrap;
    color:#8f9bb2;
    font-size:13px;
}

@media(max-width:1200px){
    .ss-slot-grid-featured{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }
    .ss-footer-grid{
        grid-template-columns:1fr 1fr;
    }
}

@media(max-width:760px){
    .ss-home-topbar-inner{
        display:block;
    }
    .ss-home-actions{
        justify-content:flex-start;
        margin-top:16px;
    }
    .ss-slot-grid-featured{
        grid-template-columns:repeat(2,minmax(0,1fr));
        gap:14px;
    }
    .ss-slot-card-xl .ss-slot-body h3{
        font-size:16px;
    }
    .ss-grid-ad-card{
        grid-column:1 / -1;
    }
    .ss-footer-grid{
        grid-template-columns:1fr;
    }
    .ss-footer-bottom{
        display:block;
    }
    .ss-footer-bottom span{
        display:block;
        margin-top:8px;
    }
}


/* v3 homepage/list/search upgrades */
.ss-home-aboutbar{
    padding:26px 0 18px;
}

.ss-home-aboutbar .ss-home-topbar-inner{
    align-items:center;
}

.ss-home-aboutbar h1{
    max-width:980px;
    font-size:clamp(34px,4.8vw,64px);
}

.ss-home-aboutbar p{
    max-width:920px;
    line-height:1.6;
}

.ss-home-summary{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    justify-content:flex-end;
    min-width:260px;
}

.ss-home-summary span{
    padding:10px 13px;
    border-radius:999px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.11);
    color:#cbd6ec;
}

.ss-home-summary strong{
    color:#fff;
}

.ss-header-search{
    position:relative;
    overflow:visible;
}

.ss-header-search form{
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
}

.ss-search-popover{
    position:absolute;
    top:calc(100% + 10px);
    right:0;
    width:min(390px,90vw);
    padding:10px;
    border-radius:18px;
    background:linear-gradient(180deg,rgba(18,27,43,.98),rgba(7,11,20,.98));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:0 24px 80px rgba(0,0,0,.52);
    z-index:200;
}

.ss-suggest-item{
    display:grid;
    grid-template-columns:72px 1fr;
    gap:12px;
    align-items:center;
    padding:9px;
    text-decoration:none;
    border-radius:13px;
}

.ss-suggest-item:hover{
    background:rgba(255,255,255,.07);
}

.ss-suggest-item img{
    width:72px;
    height:42px;
    object-fit:cover;
    border-radius:9px;
}

.ss-suggest-item strong,
.ss-suggest-item small{
    display:block;
}

.ss-suggest-item small,
.ss-suggest-empty{
    color:#aebbd4;
}

.ss-suggest-empty{
    padding:16px;
}

.ss-slot-card .ss-slot-art{
    display:block;
}

.ss-slot-body h3 a,
.ss-provider-link{
    color:inherit;
    text-decoration:none;
}

.ss-provider-link{
    display:inline-flex;
    color:#b9c9e7;
    margin-bottom:12px;
    transition:.18s ease;
}

.ss-provider-link:hover{
    color:#9eeeff;
}

.ss-icon-pill-stack{
    position:absolute;
    top:10px;
    right:10px;
    z-index:3;
    display:flex;
    flex-direction:column;
    gap:6px;
    align-items:flex-end;
}

.ss-icon-pill{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:5px;
    max-width:34px;
    height:28px;
    padding:0 8px;
    border-radius:999px;
    color:white;
    font-size:11px;
    font-weight:950;
    line-height:1;
    border:1px solid rgba(255,255,255,.28);
    box-shadow:0 8px 22px rgba(0,0,0,.34);
    overflow:hidden;
    white-space:nowrap;
    transition:.2s ease;
}

.ss-slot-card:hover .ss-icon-pill{
    max-width:130px;
}

.ss-icon-pill svg{
    width:14px;
    height:14px;
    flex:0 0 14px;
    fill:currentColor;
}

.ss-icon-pill em{
    font-style:normal;
    opacity:0;
    max-width:0;
    transition:.2s ease;
}

.ss-slot-card:hover .ss-icon-pill em{
    opacity:1;
    max-width:90px;
}

.ss-pill-purple{background:linear-gradient(135deg,#532dff,#9b5cff)}
.ss-pill-green{background:linear-gradient(135deg,#00a85a,#21e891)}
.ss-pill-blue{background:linear-gradient(135deg,#0077ff,#00d4ff)}
.ss-pill-red{background:linear-gradient(135deg,#ff2e5f,#c40025)}
.ss-pill-orange{background:linear-gradient(135deg,#ff7a1a,#ffbd4a)}
.ss-pill-pink{background:linear-gradient(135deg,#ff3bbd,#894cff)}
.ss-pill-gold{background:linear-gradient(135deg,#c99100,#ffd76a);color:#241600}
.ss-pill-slate{background:linear-gradient(135deg,#2f405b,#5e708e)}

.ss-list-grid{
    margin-top:26px;
}

.ss-pagination{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
    margin:42px 0 10px;
}

.ss-pagination a{
    min-width:44px;
    height:44px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:6px;
    padding:0 14px;
    border-radius:13px;
    text-decoration:none;
    color:#eaf2ff;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.11);
    font-weight:900;
}

.ss-pagination a.is-current,
.ss-pagination a:hover{
    background:linear-gradient(135deg,var(--ss-purple),var(--ss-blue));
    color:#fff;
}

.ss-pagination svg{
    width:16px;
    height:16px;
    fill:currentColor;
}

@media(max-width:760px){
    .ss-home-aboutbar .ss-home-topbar-inner{
        display:block;
    }
    .ss-home-summary{
        justify-content:flex-start;
        margin-top:14px;
    }
    .ss-icon-pill{
        max-width:30px;
        height:26px;
    }
    .ss-slot-card:hover .ss-icon-pill{
        max-width:30px;
    }
    .ss-icon-pill em{
        display:none;
    }
}


/* Polished campaign ad system */
.ss-ad-unit{
    position:relative;
    isolation:isolate;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    text-decoration:none;
    color:#fff;
    background:
        radial-gradient(circle at 20% 0%,rgba(133,92,255,.22),transparent 18rem),
        radial-gradient(circle at 80% 100%,rgba(0,212,255,.14),transparent 18rem),
        linear-gradient(180deg,rgba(19,29,47,.94),rgba(8,12,21,.96));
    border:1px solid rgba(170,189,220,.26);
    box-shadow:0 16px 46px rgba(0,0,0,.28);
    transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}

.ss-ad-unit:hover{
    transform:translateY(-2px);
    border-color:rgba(0,212,255,.46);
    box-shadow:0 22px 70px rgba(0,212,255,.10),0 20px 60px rgba(0,0,0,.32);
}

.ss-ad-unit img{
    width:100%;
    object-fit:cover;
    display:block;
    transition:transform .28s ease;
}

.ss-ad-unit:hover img{
    transform:scale(1.035);
}

.ss-ad-shine{
    position:absolute;
    inset:0;
    background:
        linear-gradient(115deg,transparent 0%,rgba(255,255,255,.18) 38%,transparent 58%),
        linear-gradient(180deg,transparent,rgba(0,0,0,.22));
    transform:translateX(-120%);
    transition:transform .6s ease;
    pointer-events:none;
}

.ss-ad-unit:hover .ss-ad-shine{
    transform:translateX(120%);
}

.ss-ad-label{
    position:absolute;
    top:10px;
    right:10px;
    z-index:3;
    padding:5px 8px;
    border-radius:999px;
    background:rgba(5,7,13,.72);
    border:1px solid rgba(255,255,255,.22);
    color:#dce9ff;
    font-size:10px;
    font-weight:950;
    text-transform:uppercase;
    letter-spacing:.06em;
    backdrop-filter:blur(8px);
}

.ss-ad-text-wrap{
    position:relative;
    z-index:2;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:6px;
    padding:20px;
    text-align:center;
}

.ss-ad-text-wrap strong{
    color:#fff;
    font-size:clamp(16px,1.5vw,22px);
    font-weight:950;
    line-height:1.05;
}

.ss-ad-text-wrap small{
    color:#bed0ed;
    font-size:13px;
}

.ss-ad-bolt{
    position:absolute;
    right:18px;
    bottom:14px;
    z-index:1;
    color:rgba(255,215,106,.28);
    transform:rotate(10deg);
}

.ss-ad-bolt svg{
    width:58px;
    height:58px;
    fill:currentColor;
}

.ss-ad-size-728x90,
.ss-ad-placement-728x90{
    width:min(728px,100%);
    min-height:90px;
    border-radius:18px;
    margin:22px auto;
}

.ss-ad-size-370x300,
.ss-ad-placement-370x300,
.ss-ad-placement-sidebar{
    width:100%;
    min-height:300px;
    border-radius:22px;
}

.ss-grid-ad-card{
    min-height:100%;
    border-radius:22px;
    overflow:hidden;
    background:transparent;
    border:0;
    box-shadow:none;
}

.ss-grid-ad-card .ss-ad-unit{
    width:100%;
    height:100%;
    min-height:360px;
    border-radius:22px;
}

.ss-grid-ad-card .ss-ad-size-370x300,
.ss-grid-ad-card .ss-ad-placement-sidebar{
    min-height:100%;
}

.ss-ad-placeholder{
    border-style:dashed;
    opacity:.88;
}

.ss-ad-placeholder::before{
    content:"";
    position:absolute;
    inset:-80px;
    background:conic-gradient(from 180deg,transparent,rgba(0,212,255,.10),transparent,rgba(133,92,255,.12),transparent);
    animation:ssAdSpin 8s linear infinite;
    z-index:0;
}

@keyframes ssAdSpin{
    to{transform:rotate(360deg)}
}

.ss-side-card .ss-ad-unit,
.ss-home-sidebar .ss-ad-unit{
    margin:0;
}

@media(max-width:760px){
    .ss-ad-size-728x90,
    .ss-ad-placement-728x90{
        min-height:76px;
        border-radius:15px;
    }

    .ss-grid-ad-card .ss-ad-unit{
        min-height:250px;
    }

    .ss-ad-label{
        top:8px;
        right:8px;
    }
}


/* v4 homepage hero art + strict 3-row homepage grids */
.ss-home-art-card{
    position:relative;
    width:min(520px,38vw);
    min-height:150px;
    align-self:stretch;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:visible;
}

.ss-home-art-placeholder{
    position:absolute;
    inset:16px 0 8px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:14px;
    padding:20px 26px;
    border-radius:28px;
    background:
        radial-gradient(circle at 20% 20%,rgba(255,215,106,.16),transparent 15rem),
        radial-gradient(circle at 80% 0%,rgba(0,212,255,.16),transparent 16rem),
        linear-gradient(135deg,rgba(16,24,38,.86),rgba(7,11,20,.76));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:0 24px 70px rgba(0,0,0,.28);
}

.ss-art-bolt{
    width:58px;
    height:58px;
    border-radius:20px;
    display:grid;
    place-items:center;
    background:linear-gradient(135deg,var(--ss-purple),var(--ss-blue));
    box-shadow:0 18px 42px rgba(0,212,255,.16);
    flex:0 0 auto;
}

.ss-art-bolt svg{
    width:32px;
    height:32px;
    fill:#fff;
}

.ss-art-copy strong,
.ss-art-copy small{
    display:block;
}

.ss-art-copy strong{
    font-size:18px;
    line-height:1.1;
}

.ss-art-copy small{
    color:#b7c5df;
    margin-top:4px;
}

.ss-home-hero-img{
    position:absolute;
    right:-16px;
    bottom:-18px;
    z-index:2;
    max-width:115%;
    max-height:230px;
    object-fit:contain;
    filter:drop-shadow(0 26px 38px rgba(0,0,0,.45));
    pointer-events:none;
}

.ss-home-compact .ss-slot-grid-featured{
    grid-auto-rows:1fr;
}

/* Hide any accidental extra homepage cards after 12 visual items */
.ss-home-compact .ss-slot-grid-featured > :nth-child(n+13){
    display:none;
}

@media(max-width:940px){
    .ss-home-art-card{
        width:100%;
        min-height:170px;
        margin-top:18px;
    }
    .ss-home-topbar-inner{
        align-items:flex-start;
    }
}

@media(max-width:760px){
    .ss-home-art-card{
        min-height:140px;
    }
    .ss-home-art-placeholder{
        inset:8px 0;
        justify-content:flex-start;
    }
    .ss-home-hero-img{
        max-height:170px;
        right:-28px;
    }
}


/* Final homepage hero artwork using assets/images/hero-header.png */
.ss-home-topbar{
    position:relative;
    overflow:hidden;
    padding:12px 0 10px;
    background:
        radial-gradient(circle at 20% 10%, rgba(123,92,255,.25), transparent 35rem),
        radial-gradient(circle at 80% 10%, rgba(0,212,255,.18), transparent 35rem),
        linear-gradient(180deg,#090d16,#05070d);
}

.ss-home-topbar:before{
    content:"";
    position:absolute;
    right:0;
    top:0;
    width:45%;
    height:100%;
    background:
        radial-gradient(circle at center,
        rgba(0,212,255,.08),
        transparent 70%);
    pointer-events:none;
}

.ss-home-topbar-inner{
    position:relative;
    z-index:2;
}

.ss-home-art-card{
    position:relative;
    width:min(700px,45vw);
    min-height:220px;
    display:flex;
    align-items:flex-end;
    justify-content:flex-end;
    overflow:visible;
    pointer-events:none;
}

.ss-home-art-placeholder,
.ss-art-bolt,
.ss-art-copy{
    display:none !important;
}

.ss-home-hero-img{
    width:100%;
    max-width:700px;
    height:auto;
    display:block;
    object-fit:contain;
    filter:
        drop-shadow(0 25px 50px rgba(0,0,0,.45))
        drop-shadow(0 0 40px rgba(255,215,0,.08));
    animation:ssHeroFloat 5.5s ease-in-out infinite;
}

@keyframes ssHeroFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-6px)}
}

@media(max-width:1100px){
    .ss-home-topbar-inner{
        flex-direction:column;
        align-items:flex-start;
    }

    .ss-home-art-card{
        width:100%;
        justify-content:center;
        min-height:150px;
        margin-top:20px;
    }

    .ss-home-hero-img{
        max-width:500px;
    }
}

@media(max-width:760px){
    .ss-home-topbar{
        padding:12px 0 12px;
    }

    .ss-home-art-card{
        min-height:110px;
    }

    .ss-home-hero-img{
        max-width:100%;
    }
}

/* SlotStruck news page redesign */
.ss-news-redesign{
    padding-bottom:80px;
}

.ss-news-hero-v2{
    position:relative;
    overflow:hidden;
    padding:54px 0 42px;
    border-bottom:1px solid rgba(255,255,255,.07);
    background:
        radial-gradient(circle at 18% 0%,rgba(133,92,255,.22),transparent 34rem),
        radial-gradient(circle at 78% 6%,rgba(0,212,255,.13),transparent 32rem),
        linear-gradient(180deg,rgba(10,15,26,.92),rgba(5,7,13,.35));
}

.ss-news-hero-v2::after{
    content:"";
    position:absolute;
    inset:auto 0 0;
    height:1px;
    background:linear-gradient(90deg,transparent,rgba(0,212,255,.55),rgba(133,92,255,.55),transparent);
}

.ss-news-hero-v2-inner{
    position:relative;
    z-index:2;
    display:grid;
    grid-template-columns:minmax(0,1fr) 280px;
    gap:30px;
    align-items:end;
}

.ss-news-hero-copy h1{
    max-width:860px;
    margin:13px 0 14px;
    font-size:clamp(40px,5.4vw,78px);
    line-height:.92;
    letter-spacing:-.025em;
    text-transform:uppercase;
}

.ss-news-hero-copy p{
    max-width:830px;
    margin:0;
    color:#c7d3ea;
    font-size:17px;
    line-height:1.7;
}

.ss-news-hero-pills{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:22px;
}

.ss-news-hero-pills span{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:10px 13px;
    border-radius:999px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.11);
    color:#dce8fb;
    font-size:13px;
    font-weight:850;
}

.ss-news-hero-pills svg{
    width:15px;
    height:15px;
    fill:#9eeeff;
}

.ss-news-hero-panel{
    min-height:168px;
    padding:24px;
    border-radius:26px;
    background:
        radial-gradient(circle at 30% 0%,rgba(255,215,106,.14),transparent 12rem),
        linear-gradient(180deg,rgba(18,27,43,.94),rgba(8,12,21,.95));
    border:1px solid rgba(255,255,255,.13);
    box-shadow:0 22px 70px rgba(0,0,0,.32);
}

.ss-news-hero-panel span,
.ss-news-hero-panel small{
    display:block;
    color:#aebbd4;
    font-size:13px;
    font-weight:850;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.ss-news-hero-panel strong{
    display:block;
    margin:9px 0 4px;
    font-size:58px;
    line-height:1;
    letter-spacing:-.07em;
}

.ss-news-layout{
    display:grid;
    grid-template-columns:minmax(0,1fr) 360px;
    gap:28px;
    align-items:start;
    margin-top:34px;
}

.ss-news-main-col{
    min-width:0;
}

.ss-featured-news-v2{
    display:grid;
    grid-template-columns:minmax(0,.95fr) minmax(360px,1fr);
    gap:0;
    overflow:hidden;
    border-radius:28px;
    background:
        linear-gradient(180deg,rgba(19,29,47,.95),rgba(8,12,21,.97));
    border:1px solid rgba(170,189,220,.18);
    box-shadow:0 22px 70px rgba(0,0,0,.34);
}

.ss-featured-news-v2-img{
    position:relative;
    min-height:390px;
    display:block;
    overflow:hidden;
    background:#0d1422;
    text-decoration:none;
}

.ss-featured-news-v2-img::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.54));
}

.ss-featured-news-v2-img img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .35s ease;
}

.ss-featured-news-v2:hover .ss-featured-news-v2-img img{
    transform:scale(1.045);
}

.ss-featured-news-v2-img span{
    position:absolute;
    left:18px;
    top:18px;
    z-index:2;
    display:inline-flex;
    align-items:center;
    gap:7px;
    padding:8px 12px;
    border-radius:999px;
    color:#fff;
    background:linear-gradient(135deg,var(--ss-purple),var(--ss-blue));
    border:1px solid rgba(255,255,255,.28);
    box-shadow:0 12px 30px rgba(0,0,0,.35);
    font-size:12px;
    font-weight:950;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.ss-featured-news-v2-img span svg{
    width:14px;
    height:14px;
    fill:currentColor;
}

.ss-featured-news-v2-copy{
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:38px;
}

.ss-featured-news-v2-copy time,
.ss-news-card-v2-body time{
    color:#9eeeff;
    font-size:12px;
    font-weight:950;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.ss-featured-news-v2-copy h2{
    margin:12px 0 14px;
    font-size:clamp(30px,3vw,48px);
    line-height:1.02;
    letter-spacing:-.05em;
}

.ss-featured-news-v2-copy a,
.ss-news-card-v2-body a,
.ss-read-link-v2{
    color:inherit;
    text-decoration:none;
}

.ss-featured-news-v2-copy h2 a:hover,
.ss-news-card-v2-body h3 a:hover{
    color:#9eeeff;
}

.ss-featured-news-v2-copy p{
    margin:0 0 24px;
    color:#c5d1e8;
    font-size:16px;
    line-height:1.75;
}

.ss-news-section-title{
    display:flex;
    justify-content:space-between;
    gap:24px;
    align-items:end;
    margin:36px 0 18px;
}

.ss-news-section-title h2{
    margin:8px 0 0;
    font-size:clamp(30px,3.6vw,48px);
    text-transform:uppercase;
    letter-spacing:-.05em;
}

.ss-news-section-title p{
    max-width:360px;
    margin:0;
    color:#aebbd4;
    line-height:1.6;
    text-align:right;
}

.ss-news-card-grid-v2{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
}

.ss-news-card-v2{
    overflow:hidden;
    border-radius:22px;
    background:
        linear-gradient(180deg,rgba(18,27,43,.94),rgba(8,12,21,.96));
    border:1px solid rgba(170,189,220,.15);
    box-shadow:0 14px 42px rgba(0,0,0,.24);
    transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease;
}

.ss-news-card-v2:hover{
    transform:translateY(-5px);
    border-color:rgba(0,212,255,.32);
    box-shadow:0 22px 62px rgba(0,212,255,.08),0 18px 50px rgba(0,0,0,.32);
}

.ss-news-card-v2-img{
    display:block;
    aspect-ratio:16/9;
    overflow:hidden;
    background:#0d1422;
}

.ss-news-card-v2-img img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .3s ease;
}

.ss-news-card-v2:hover .ss-news-card-v2-img img{
    transform:scale(1.045);
}

.ss-news-card-v2-body{
    padding:20px;
}

.ss-news-card-v2-body h3{
    margin:9px 0 10px;
    font-size:22px;
    line-height:1.16;
    letter-spacing:-.025em;
}

.ss-news-card-v2-body p{
    margin:0 0 18px;
    color:#b9c6dd;
    line-height:1.65;
}

.ss-read-link-v2{
    display:inline-flex;
    align-items:center;
    gap:7px;
    color:#9eeeff;
    font-size:13px;
    font-weight:950;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.ss-read-link-v2 svg{
    width:15px;
    height:15px;
    fill:currentColor;
    transition:transform .18s ease;
}

.ss-read-link-v2:hover svg{
    transform:translateX(3px);
}

.ss-news-inline-ad{
    grid-column:1 / -1;
    display:flex;
    justify-content:center;
    padding:2px 0;
}

.ss-news-sidebar{
    display:grid;
    gap:22px;
}

.ss-news-side-card{
    padding:20px;
    border-radius:24px;
    background:linear-gradient(180deg,rgba(18,27,43,.94),rgba(8,12,21,.96));
    border:1px solid rgba(170,189,220,.16);
    box-shadow:0 14px 44px rgba(0,0,0,.24);
}

.ss-news-side-card h3{
    display:flex;
    align-items:center;
    gap:9px;
    margin:0 0 12px;
    font-size:15px;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.ss-news-side-card h3 svg{
    width:17px;
    height:17px;
    fill:var(--ss-gold);
}

.ss-news-side-list{
    display:grid;
}

.ss-news-side-list a{
    padding:13px 0;
    border-top:1px solid rgba(255,255,255,.08);
    text-decoration:none;
}

.ss-news-side-list span,
.ss-news-side-list small{
    display:block;
}

.ss-news-side-list span{
    color:#eef4ff;
    font-weight:850;
    line-height:1.35;
}

.ss-news-side-list small{
    margin-top:5px;
    color:#9eeeff;
    font-size:12px;
    font-weight:850;
    text-transform:uppercase;
    letter-spacing:.05em;
}

.ss-news-side-list a:hover span{
    color:#9eeeff;
}

.ss-news-side-ad .ss-ad-unit{
    width:100%;
    margin:0;
}

.ss-news-side-ad-sticky{
    position:sticky;
    top:104px;
}

.ss-news-empty{
    margin-top:34px;
}

@media(max-width:1200px){
    .ss-news-layout{
        grid-template-columns:1fr;
    }

    .ss-news-sidebar{
        grid-template-columns:1fr 1fr;
    }

    .ss-news-side-card{
        order:3;
        grid-column:1 / -1;
    }

    .ss-news-side-ad-sticky{
        position:relative;
        top:auto;
    }
}

@media(max-width:940px){
    .ss-news-hero-v2-inner{
        grid-template-columns:1fr;
        align-items:start;
    }

    .ss-news-hero-panel{
        min-height:auto;
    }

    .ss-featured-news-v2{
        grid-template-columns:1fr;
    }

    .ss-featured-news-v2-img{
        min-height:280px;
    }

    .ss-news-section-title{
        display:block;
    }

    .ss-news-section-title p{
        max-width:none;
        margin-top:8px;
        text-align:left;
    }
}

@media(max-width:700px){
    .ss-news-hero-v2{
        padding:34px 0 28px;
    }

    .ss-news-hero-copy h1{
        font-size:40px;
    }

    .ss-news-hero-copy p{
        font-size:15px;
    }

    .ss-news-layout{
        margin-top:22px;
    }

    .ss-featured-news-v2,
    .ss-news-card-v2,
    .ss-news-side-card{
        border-radius:18px;
    }

    .ss-featured-news-v2-img{
        min-height:210px;
    }

    .ss-featured-news-v2-copy,
    .ss-news-card-v2-body{
        padding:18px;
    }

    .ss-news-card-grid-v2,
    .ss-news-sidebar{
        grid-template-columns:1fr;
    }

    .ss-news-card-v2-body h3{
        font-size:20px;
    }
}

/* SlotStruck single article redesign */
.ss-article-page{
    position:relative;
    overflow:hidden;
}

.ss-article-page::before{
    content:"";
    position:absolute;
    inset:0 0 auto;
    height:520px;
    pointer-events:none;
    background:
        radial-gradient(circle at 18% 8%,rgba(133,92,255,.22),transparent 34rem),
        radial-gradient(circle at 82% 3%,rgba(0,212,255,.16),transparent 34rem),
        linear-gradient(180deg,rgba(13,20,34,.84),rgba(5,7,13,0));
    z-index:-1;
}

.ss-article-hero{
    padding:44px 0 30px;
}

.ss-article-hero-inner{
    max-width:1120px;
}

.ss-article-back{
    display:inline-flex;
    align-items:center;
    gap:8px;
    margin-bottom:20px;
    color:#b9c8e4;
    text-decoration:none;
    font-weight:900;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.04em;
    transition:.18s ease;
}

.ss-article-back:hover{
    color:#fff;
    transform:translateX(-3px);
}

.ss-article-back svg{
    width:16px;
    height:16px;
    fill:currentColor;
}

.ss-article-hero h1{
    max-width:1020px;
    margin:14px 0 18px;
    font-size:clamp(42px,6.4vw,82px);
    line-height:.92;
    letter-spacing:-.062em;
    text-wrap:balance;
}

.ss-article-hero p{
    max-width:820px;
    margin:0;
    color:#c6d2ea;
    font-size:18px;
    line-height:1.7;
}

.ss-article-meta-row{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:24px;
}

.ss-article-meta-row span{
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:38px;
    padding:0 13px;
    border-radius:999px;
    color:#e2ecff;
    background:rgba(255,255,255,.065);
    border:1px solid rgba(255,255,255,.12);
    font-size:13px;
    font-weight:850;
}

.ss-article-meta-row svg{
    width:15px;
    height:15px;
    fill:#9eeeff;
}

.ss-article-shell{
    display:grid;
    grid-template-columns:minmax(0,1fr) 360px;
    gap:28px;
    align-items:start;
}

.ss-article-card{
    overflow:hidden;
    border-radius:30px;
    background:
        linear-gradient(180deg,rgba(18,27,43,.96),rgba(8,12,21,.98));
    border:1px solid rgba(170,189,220,.18);
    box-shadow:0 28px 90px rgba(0,0,0,.38);
}

.ss-article-image-wrap{
    position:relative;
    aspect-ratio:16/7;
    min-height:320px;
    overflow:hidden;
    background:#0d1422;
}

.ss-article-image-wrap img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.ss-article-image-overlay{
    position:absolute;
    inset:0;
    background:
        linear-gradient(180deg,rgba(5,7,13,0),rgba(5,7,13,.54)),
        radial-gradient(circle at 18% 12%,rgba(133,92,255,.18),transparent 24rem);
}

.ss-article-content{
    padding:clamp(22px,4vw,48px);
}

.ss-article-intro-card{
    margin-bottom:34px;
    padding:22px 24px;
    border-radius:22px;
    background:
        radial-gradient(circle at 0% 0%,rgba(0,212,255,.13),transparent 18rem),
        linear-gradient(135deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
    border:1px solid rgba(255,255,255,.12);
}

.ss-article-intro-card strong{
    display:block;
    margin-bottom:8px;
    color:#fff;
    font-size:13px;
    font-weight:950;
    text-transform:uppercase;
    letter-spacing:.1em;
}

.ss-article-intro-card p{
    margin:0;
    color:#d8e5fb;
    line-height:1.75;
    font-size:17px;
}

.ss-prose{
    color:#d7e2f5;
    font-size:18px;
    line-height:1.86;
}

.ss-prose > *:first-child{
    margin-top:0;
}

.ss-prose p{
    margin:0 0 1.35em;
}

.ss-prose h2,
.ss-prose h3,
.ss-prose h4{
    color:#fff;
    line-height:1.08;
    letter-spacing:-.035em;
    text-wrap:balance;
}

.ss-prose h2{
    margin:1.55em 0 .55em;
    font-size:clamp(30px,3.4vw,46px);
}

.ss-prose h3{
    margin:1.45em 0 .5em;
    font-size:clamp(24px,2.4vw,32px);
}

.ss-prose a{
    color:#9eeeff;
    font-weight:850;
    text-decoration:none;
    border-bottom:1px solid rgba(158,238,255,.35);
}

.ss-prose ul,
.ss-prose ol{
    margin:0 0 1.4em;
    padding-left:1.25em;
}

.ss-prose li{
    margin:.45em 0;
}

.ss-prose blockquote{
    margin:2em 0;
    padding:22px 24px;
    border-left:4px solid var(--ss-blue);
    border-radius:18px;
    background:rgba(255,255,255,.055);
    color:#fff;
    font-weight:800;
}

.ss-prose img{
    width:100%;
    height:auto;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.1);
    box-shadow:0 16px 44px rgba(0,0,0,.24);
}

.ss-article-sidebar{
    display:grid;
    gap:20px;
}

.ss-article-side-card,
.ss-article-ad-card{
    border-radius:24px;
    background:linear-gradient(180deg,rgba(18,27,43,.94),rgba(8,12,21,.96));
    border:1px solid rgba(170,189,220,.16);
    box-shadow:0 18px 50px rgba(0,0,0,.26);
}

.ss-article-side-card{
    padding:22px;
}

.ss-article-sticky-card{
    position:sticky;
    top:104px;
}

.ss-article-side-card h3{
    margin:12px 0 10px;
    color:#fff;
    font-size:24px;
    line-height:1.08;
    letter-spacing:-.035em;
}

.ss-article-side-card p{
    color:#b9c7e1;
    line-height:1.65;
    margin:0 0 18px;
}

.ss-side-title{
    display:flex;
    align-items:center;
    gap:9px;
    margin:0 0 16px !important;
    font-size:16px !important;
    text-transform:uppercase;
    letter-spacing:.06em !important;
}

.ss-side-title svg{
    width:18px;
    height:18px;
    fill:var(--ss-gold);
}

.ss-article-ad-card{
    overflow:hidden;
    min-height:300px;
}

.ss-article-ad-card .ss-ad-unit{
    min-height:300px;
    height:100%;
    margin:0;
    border-radius:24px;
}

.ss-article-related-list{
    display:grid;
    gap:10px;
}

.ss-article-related-list a{
    display:grid;
    grid-template-columns:78px 1fr;
    gap:12px;
    align-items:center;
    padding:9px;
    border-radius:16px;
    text-decoration:none;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.07);
    transition:.18s ease;
}

.ss-article-related-list a:hover{
    transform:translateX(3px);
    background:rgba(255,255,255,.07);
    border-color:rgba(0,212,255,.24);
}

.ss-article-related-list img{
    width:78px;
    height:52px;
    object-fit:cover;
    border-radius:11px;
}

.ss-article-related-list strong,
.ss-article-related-list small{
    display:block;
}

.ss-article-related-list strong{
    color:#fff;
    font-size:13px;
    line-height:1.22;
}

.ss-article-related-list small{
    margin-top:4px;
    color:#9dabc5;
    font-size:12px;
}

.ss-article-bottom-ad{
    margin:28px 0 8px;
}

.ss-article-related-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
}

.ss-article-empty{
    margin-top:44px;
}

@media(max-width:1100px){
    .ss-article-shell{
        grid-template-columns:1fr;
    }

    .ss-article-sidebar{
        grid-template-columns:1fr 1fr;
    }

    .ss-article-sticky-card{
        position:relative;
        top:auto;
    }

    .ss-article-sidebar .ss-article-side-card:last-child{
        grid-column:1 / -1;
    }
}

@media(max-width:760px){
    .ss-article-hero{
        padding:30px 0 22px;
    }

    .ss-article-hero h1{
        font-size:38px;
    }

    .ss-article-hero p,
    .ss-prose{
        font-size:16px;
    }

    .ss-article-card{
        border-radius:22px;
    }

    .ss-article-image-wrap{
        aspect-ratio:16/10;
        min-height:210px;
    }

    .ss-article-content{
        padding:20px;
    }

    .ss-article-intro-card{
        padding:18px;
        border-radius:18px;
    }

    .ss-article-sidebar,
    .ss-article-related-grid{
        grid-template-columns:1fr;
    }
}

/* SlotStruck card badge/icon responsive fix
   Paste at the very bottom of assets/css/slotstruck-ui.css */

.ss-slot-card{
    isolation:isolate;
}

.ss-slot-art{
    overflow:hidden;
}

.ss-icon-pill-stack{
    top:8px;
    right:8px;
    max-height:calc(100% - 16px);
    display:flex;
    flex-direction:column;
    gap:5px;
    align-items:flex-end;
    pointer-events:none;
}

.ss-icon-pill{
    width:28px;
    height:28px;
    max-width:28px;
    min-width:28px;
    padding:0;
    border-radius:999px;
    display:inline-grid;
    place-items:center;
    flex:0 0 auto;
    pointer-events:auto;
}

.ss-icon-pill svg{
    width:13px;
    height:13px;
    margin:0;
}

.ss-icon-pill em{
    display:none !important;
}

/* Let labels expand only on roomy desktop cards */
@media (min-width:1280px){
    .ss-slot-grid-featured .ss-slot-card:hover .ss-icon-pill{
        width:auto;
        max-width:122px;
        min-width:28px;
        padding:0 8px;
        display:inline-flex;
    }

    .ss-slot-grid-featured .ss-slot-card:hover .ss-icon-pill em{
        display:inline !important;
        opacity:1;
        max-width:84px;
        overflow:hidden;
        text-overflow:ellipsis;
    }
}

/* Medium desktop/tablet: fewer, smaller icons so they stay inside the art */
@media (max-width:1180px){
    .ss-icon-pill-stack{
        top:7px;
        right:7px;
        gap:4px;
    }

    .ss-icon-pill{
        width:26px;
        height:26px;
        min-width:26px;
        max-width:26px;
    }

    .ss-icon-pill svg{
        width:12px;
        height:12px;
    }

    .ss-icon-pill-stack .ss-icon-pill:nth-child(n+5){
        display:none;
    }
}

/* Small cards: move icons to a clean bottom row overlay */
@media (max-width:860px){
    .ss-icon-pill-stack{
        top:auto;
        right:8px;
        bottom:8px;
        left:8px;
        max-height:none;
        flex-direction:row;
        justify-content:flex-end;
        gap:5px;
    }

    .ss-icon-pill{
        width:25px;
        height:25px;
        min-width:25px;
        max-width:25px;
        box-shadow:0 8px 18px rgba(0,0,0,.28);
    }

    .ss-icon-pill-stack .ss-icon-pill:nth-child(n+5){
        display:none;
    }
}

/* Very narrow mobile: show only the most important three */
@media (max-width:520px){
    .ss-icon-pill-stack{
        right:6px;
        bottom:6px;
        left:6px;
        gap:4px;
    }

    .ss-icon-pill{
        width:23px;
        height:23px;
        min-width:23px;
        max-width:23px;
    }

    .ss-icon-pill svg{
        width:11px;
        height:11px;
    }

    .ss-icon-pill-stack .ss-icon-pill:nth-child(n+4){
        display:none;
    }
}

/* Mobile card polish: tighter cards + better section CTA spacing */
@media (max-width: 760px){
    .ss-section-head{
        margin:34px 0 20px;
        gap:14px;
    }

    .ss-section-head h2{
        margin-bottom:8px;
        line-height:.95;
    }

    .ss-section-head p{
        margin-bottom:14px;
        line-height:1.45;
    }

    .ss-section-head .ss-btn,
    .ss-section-head a.ss-btn{
        margin-top:8px;
    }

    .ss-slot-grid,
    .ss-slot-grid-wide,
    .ss-slot-grid-featured{
        grid-template-columns:repeat(2,minmax(0,1fr));
        gap:14px;
        align-items:start;
    }

    .ss-slot-card{
        min-height:0;
        border-radius:18px;
        display:flex;
        flex-direction:column;
    }

    .ss-slot-art{
        aspect-ratio:16 / 9;
        flex:0 0 auto;
    }

    .ss-slot-body{
        padding:13px 14px 14px;
        flex:0 0 auto;
    }

    .ss-slot-body h3{
        margin:0 0 7px;
        font-size:15px;
        line-height:1.18;
        display:-webkit-box;
        -webkit-line-clamp:2;
        -webkit-box-orient:vertical;
        overflow:hidden;
    }

    .ss-provider-link,
    .ss-slot-body p{
        margin-bottom:10px;
        font-size:13px;
        line-height:1.3;
        display:-webkit-box;
        -webkit-line-clamp:1;
        -webkit-box-orient:vertical;
        overflow:hidden;
    }

    .ss-slot-meta{
        gap:8px;
        font-size:11px;
        line-height:1.2;
    }

    .ss-slot-meta span{
        white-space:nowrap;
    }

    .ss-icon-pill-stack{
        top:auto;
        right:8px;
        bottom:8px;
        flex-direction:row;
        gap:5px;
        max-width:calc(100% - 16px);
        overflow:hidden;
    }

    .ss-icon-pill{
        width:24px;
        height:24px;
        max-width:24px;
        padding:0;
        flex:0 0 24px;
        border-radius:999px;
    }

    .ss-icon-pill svg{
        width:13px;
        height:13px;
    }

    .ss-icon-pill em{
        display:none !important;
    }

    .ss-slot-card:hover .ss-icon-pill{
        max-width:24px;
        transform:none;
    }

    .ss-slot-card .ss-icon-pill-stack .ss-icon-pill:nth-child(n+5){
        display:none;
    }
}

@media (max-width: 430px){
    .ss-slot-grid,
    .ss-slot-grid-wide,
    .ss-slot-grid-featured{
        gap:12px;
    }

    .ss-slot-body{
        padding:12px;
    }

    .ss-slot-body h3{
        font-size:14px;
    }

    .ss-provider-link,
    .ss-slot-body p{
        font-size:12.5px;
    }

    .ss-slot-meta{
        font-size:10.5px;
    }
}

/* ============================================================
   SlotStruck v10 responsive card cleanup
   Fixes mobile homepage/list card height, row gaps, icon badges,
   and section CTA spacing. Keep this block at the very bottom.
   ============================================================ */

/* Stop previous equal-row rule from forcing huge vertical gaps */
.ss-home-compact .ss-slot-grid-featured,
.ss-slot-grid-featured{
    grid-auto-rows:auto !important;
    align-items:start !important;
}

/* Cards should size to their content unless a row naturally needs to match */
.ss-slot-card{
    height:auto !important;
    min-height:0 !important;
}

.ss-slot-grid .ss-slot-card,
.ss-slot-grid-wide .ss-slot-card,
.ss-slot-grid-featured .ss-slot-card{
    align-self:start;
}

/* Keep the ad from stretching nearby card rows */
.ss-grid-ad-card{
    min-height:0 !important;
    align-self:start !important;
}

.ss-grid-ad-card .ss-ad-unit,
.ss-grid-ad-card .ss-ad-size-370x300,
.ss-grid-ad-card .ss-ad-placement-sidebar,
.ss-grid-ad-card .ss-ad-sidebar{
    min-height:300px;
}

/* More stable desktop/tablet card rhythm */
.ss-slot-grid,
.ss-slot-grid-wide,
.ss-slot-grid-featured{
    align-items:start;
}

.ss-slot-body h3{
    overflow-wrap:normal;
    word-break:normal;
}

.ss-provider-link,
.ss-slot-body p{
    overflow-wrap:anywhere;
}

/* Make badge stack behave predictably across all resolutions */
.ss-icon-pill-stack{
    pointer-events:none;
}

.ss-icon-pill{
    pointer-events:auto;
    transform:none !important;
}

.ss-slot-card:hover .ss-icon-pill{
    transform:none !important;
}

/* Tablet/mobile card system */
@media(max-width:760px){
    .ss-page{
        padding-bottom:46px;
    }

    .ss-container,
    .ss-header-inner{
        width:min(100% - 24px,1400px);
    }

    .ss-section-head,
    .ss-section-head-tight{
        margin:32px 0 18px !important;
        display:block;
    }

    .ss-section-head h2{
        margin:0 0 8px !important;
        font-size:clamp(30px,8vw,38px);
        line-height:.94;
        letter-spacing:-.055em;
    }

    .ss-section-head p{
        margin:0 0 16px !important;
        color:#c4d0e7;
        line-height:1.45;
    }

    .ss-section-head .ss-btn,
    .ss-section-head a.ss-btn{
        margin-top:2px !important;
        min-height:40px;
        padding:0 14px;
        border-radius:13px;
        font-size:12px;
    }

    .ss-slot-grid,
    .ss-slot-grid-wide,
    .ss-slot-grid-featured{
        grid-template-columns:repeat(2,minmax(0,1fr)) !important;
        gap:14px !important;
        row-gap:16px !important;
        align-items:start !important;
        grid-auto-rows:auto !important;
    }

    .ss-slot-grid .ss-slot-card,
    .ss-slot-grid-wide .ss-slot-card,
    .ss-slot-grid-featured .ss-slot-card{
        display:flex !important;
        flex-direction:column;
        height:auto !important;
        min-height:0 !important;
        align-self:start !important;
        border-radius:17px;
        overflow:hidden;
        box-shadow:0 10px 26px rgba(0,0,0,.24);
    }

    .ss-slot-card:hover{
        transform:none;
    }

    .ss-slot-art{
        aspect-ratio:16 / 9 !important;
        min-height:0 !important;
        flex:0 0 auto !important;
        border-radius:0;
    }

    .ss-slot-art img{
        height:100%;
        object-fit:cover;
    }

    .ss-slot-body{
        display:block !important;
        flex:0 0 auto !important;
        padding:12px 13px 13px !important;
        min-height:94px;
    }

    .ss-slot-body h3{
        margin:0 0 7px !important;
        font-size:15px !important;
        line-height:1.18 !important;
        letter-spacing:-.015em;
        display:-webkit-box;
        -webkit-line-clamp:2;
        -webkit-box-orient:vertical;
        overflow:hidden;
        min-height:0;
    }

    .ss-provider-link,
    .ss-slot-body p{
        display:block !important;
        margin:0 0 10px !important;
        color:#cbd8f1;
        font-size:13px !important;
        line-height:1.25 !important;
        white-space:nowrap;
        overflow:hidden;
        text-overflow:ellipsis;
    }

    .ss-slot-meta{
        display:flex;
        align-items:center;
        gap:8px !important;
        flex-wrap:nowrap !important;
        overflow:hidden;
        color:#dce8fb;
        font-size:10.5px !important;
        line-height:1.2;
    }

    .ss-slot-meta span{
        min-width:0;
        white-space:nowrap;
        overflow:hidden;
        text-overflow:ellipsis;
    }

    .ss-slot-meta span:nth-child(n+3){
        display:none;
    }

    .ss-slot-meta svg{
        width:12px !important;
        height:12px !important;
        flex:0 0 12px;
    }

    .ss-status-badge{
        left:7px;
        top:7px;
        padding:5px 8px;
        font-size:10px;
    }

    .ss-card-glow{
        height:50%;
    }

    /* Icons sit neatly on the image and never affect card height */
    .ss-icon-pill-stack{
        top:auto !important;
        right:7px !important;
        bottom:7px !important;
        left:auto !important;
        max-width:calc(100% - 14px);
        max-height:none !important;
        display:flex !important;
        flex-direction:row !important;
        justify-content:flex-end;
        align-items:center;
        gap:4px !important;
        overflow:hidden;
        z-index:4;
    }

    .ss-icon-pill{
        width:24px !important;
        height:24px !important;
        min-width:24px !important;
        max-width:24px !important;
        flex:0 0 24px !important;
        padding:0 !important;
        border-radius:999px !important;
        display:grid !important;
        place-items:center !important;
        box-shadow:0 7px 16px rgba(0,0,0,.32);
    }

    .ss-icon-pill svg{
        width:12px !important;
        height:12px !important;
    }

    .ss-icon-pill em{
        display:none !important;
    }

    .ss-slot-card .ss-icon-pill-stack .ss-icon-pill:nth-child(n+4){
        display:none !important;
    }

    /* Full-width ad on mobile without poisoning grid row heights */
    .ss-grid-ad-card{
        grid-column:1 / -1 !important;
        width:100%;
        min-height:0 !important;
        margin:4px 0 2px;
        border-radius:18px;
    }

    .ss-grid-ad-card .ss-ad-unit,
    .ss-grid-ad-card .ss-ad-size-370x300,
    .ss-grid-ad-card .ss-ad-placement-sidebar,
    .ss-grid-ad-card .ss-ad-sidebar{
        min-height:190px !important;
        height:auto !important;
        border-radius:18px !important;
    }
}

/* Very small phones */
@media(max-width:430px){
    .ss-slot-grid,
    .ss-slot-grid-wide,
    .ss-slot-grid-featured{
        gap:12px !important;
        row-gap:14px !important;
    }

    .ss-slot-body{
        padding:11px 11px 12px !important;
        min-height:90px;
    }

    .ss-slot-body h3{
        font-size:14px !important;
        line-height:1.17 !important;
    }

    .ss-provider-link,
    .ss-slot-body p{
        font-size:12px !important;
    }

    .ss-slot-meta{
        font-size:10px !important;
        gap:6px !important;
    }

    .ss-icon-pill{
        width:22px !important;
        height:22px !important;
        min-width:22px !important;
        max-width:22px !important;
        flex-basis:22px !important;
    }

    .ss-icon-pill svg{
        width:11px !important;
        height:11px !important;
    }

    .ss-grid-ad-card .ss-ad-unit,
    .ss-grid-ad-card .ss-ad-size-370x300,
    .ss-grid-ad-card .ss-ad-placement-sidebar,
    .ss-grid-ad-card .ss-ad-sidebar{
        min-height:170px !important;
    }
}

/* Ultra narrow fallback: one-column cards are cleaner than squeezed cards */
@media(max-width:340px){
    .ss-slot-grid,
    .ss-slot-grid-wide,
    .ss-slot-grid-featured{
        grid-template-columns:1fr !important;
    }

    .ss-slot-body{
        min-height:0;
    }
}

/* SlotStruck sidebar navigation layout
   Paste at the very bottom of assets/css/slotstruck-ui.css after uploading the new header/footer. */

body{
    overflow-x:hidden;
}

.ss-app-shell{
    min-height:100vh;
    display:grid;
    grid-template-columns:270px minmax(0,1fr);
    background:
        radial-gradient(circle at 22% 0%,rgba(133,92,255,.16),transparent 34rem),
        radial-gradient(circle at 80% 8%,rgba(0,212,255,.12),transparent 34rem),
        linear-gradient(180deg,#05070d,#070b12 38%,#05070d);
}

.ss-main-shell{
    min-width:0;
    border-left:1px solid rgba(167,184,216,.11);
}

.ss-side-nav{
    position:sticky;
    top:0;
    height:100dvh;
    display:flex;
    flex-direction:column;
    padding:28px 18px 18px;
    background:
        radial-gradient(circle at 50% 0%,rgba(0,212,255,.13),transparent 18rem),
        linear-gradient(180deg,rgba(12,18,30,.98),rgba(5,7,13,.98));
    border-right:1px solid rgba(255,255,255,.08);
    box-shadow:18px 0 60px rgba(0,0,0,.18);
    z-index:90;
}

.ss-side-logo{
    display:block;
    padding:0 8px 22px;
}

.ss-side-logo img{
    width:220px;
    max-width:100%;
    display:block;
}

.ss-side-tagline{
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:38px;
    margin:0 0 18px;
    padding:0 12px;
    border-radius:999px;
    color:#dce8fb;
    background:rgba(255,255,255,.055);
    border:1px solid rgba(255,255,255,.10);
    font-size:11px;
    font-weight:950;
    letter-spacing:.08em;
    text-transform:uppercase;
}

.ss-side-links{
    display:grid;
    gap:9px;
}

.ss-side-links a{
    position:relative;
    display:grid;
    grid-template-columns:42px minmax(0,1fr);
    align-items:center;
    gap:10px;
    min-height:58px;
    padding:8px 12px;
    border-radius:16px;
    color:#c9d5eb;
    text-decoration:none;
    background:rgba(255,255,255,.035);
    border:1px solid transparent;
    font-size:14px;
    font-weight:950;
    transition:.2s ease;
}

.ss-side-links a::before{
    content:"";
    position:absolute;
    left:-1px;
    top:12px;
    bottom:12px;
    width:3px;
    border-radius:99px;
    background:transparent;
}

.ss-side-links a:hover,
.ss-side-links a.is-active{
    color:#fff;
    background:linear-gradient(135deg,rgba(133,92,255,.20),rgba(0,212,255,.12));
    border-color:rgba(0,212,255,.22);
    transform:translateX(2px);
}

.ss-side-links a.is-active::before{
    background:linear-gradient(180deg,var(--ss-blue),var(--ss-green));
}

.ss-side-icon{
    width:38px;
    height:38px;
    display:grid;
    place-items:center;
    border-radius:13px;
    color:#9eeeff;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.10);
}

.ss-side-icon svg{
    width:18px;
    height:18px;
    fill:currentColor;
}

.ss-side-responsible{
    margin-top:auto;
    padding:16px;
    border-radius:18px;
    background:linear-gradient(180deg,rgba(0,212,255,.095),rgba(255,255,255,.035));
    border:1px solid rgba(0,212,255,.18);
}

.ss-side-responsible strong,
.ss-side-responsible span{
    display:block;
}

.ss-side-responsible strong{
    color:#fff;
    margin-bottom:6px;
    font-size:13px;
}

.ss-side-responsible span{
    color:#b7c5dd;
    font-size:12px;
    line-height:1.45;
}

.ss-top-strip{
    position:sticky;
    top:0;
    z-index:80;
    min-height:104px;
    display:grid;
    grid-template-columns:minmax(0,1fr) 280px;
    gap:22px;
    align-items:center;
    padding:14px 40px;
    background:rgba(5,7,13,.78);
    backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(255,255,255,.08);
}

.ss-top-ad-slot{
    display:flex;
    justify-content:center;
    min-width:0;
}

.ss-top-ad-slot .ss-ad-unit,
.ss-top-ad-slot .ss-ad-size-728x90,
.ss-top-ad-slot .ss-ad-placement-728x90,
.ss-top-ad-placeholder{
    width:min(728px,100%);
    min-height:74px;
    margin:0;
    border-radius:18px;
}

.ss-top-ad-placeholder{
    display:grid;
    place-items:center;
    border:1px dashed rgba(0,212,255,.30);
    background:
        radial-gradient(circle at 30% 0%,rgba(0,212,255,.10),transparent 16rem),
        rgba(255,255,255,.035);
    color:#aebbd4;
    text-align:center;
}

.ss-top-ad-placeholder span,
.ss-top-ad-placeholder strong{
    display:block;
}

.ss-top-ad-placeholder span{
    font-size:10px;
    font-weight:950;
    letter-spacing:.16em;
    text-transform:uppercase;
    color:#9eeeff;
}

.ss-top-ad-placeholder strong{
    margin-top:-14px;
    font-size:13px;
}

.ss-top-strip .ss-header-search{
    width:100%;
    justify-self:end;
}

.ss-mobile-header,
.ss-mobile-menu{
    display:none;
}

/* Disable legacy horizontal header when old CSS is still present */
.ss-site-header{
    display:none;
}

.ss-site-footer-sidebar{
    margin-top:64px;
}

@media(max-width:1180px){
    .ss-app-shell{
        grid-template-columns:232px minmax(0,1fr);
    }

    .ss-side-logo img{
        width:190px;
    }

    .ss-top-strip{
        grid-template-columns:minmax(0,1fr) 250px;
        padding-inline:24px;
    }
}

@media(max-width:940px){
    .ss-app-shell{
        display:block;
    }

    .ss-main-shell{
        border-left:0;
    }

    .ss-side-nav{
        display:none;
    }

    .ss-mobile-header{
        position:sticky;
        top:0;
        z-index:100;
        min-height:82px;
        display:flex;
        align-items:center;
        justify-content:space-between;
        gap:18px;
        padding:14px 18px;
        background:rgba(5,7,13,.86);
        backdrop-filter:blur(18px);
        border-bottom:1px solid rgba(255,255,255,.08);
    }

    .ss-mobile-logo img{
        width:200px;
        display:block;
    }

    .ss-mobile-toggle{
        display:flex;
        width:44px;
        height:44px;
        border:1px solid rgba(255,255,255,.14);
        border-radius:14px;
        background:rgba(255,255,255,.06);
        align-items:center;
        justify-content:center;
        flex-direction:column;
        gap:5px;
    }

    .ss-mobile-toggle span{
        width:19px;
        height:2px;
        background:white;
        border-radius:99px;
    }

    .ss-mobile-menu{
        display:none;
        padding:10px 18px 16px;
        background:rgba(5,7,13,.94);
        border-bottom:1px solid rgba(255,255,255,.08);
    }

    .ss-mobile-menu.is-open{
        display:grid;
        gap:8px;
    }

    .ss-mobile-menu a{
        display:flex;
        align-items:center;
        justify-content:center;
        gap:8px;
        min-height:44px;
        border-radius:14px;
        text-decoration:none;
        color:#dce8fb;
        background:rgba(255,255,255,.045);
        border:1px solid rgba(255,255,255,.08);
        font-size:13px;
        font-weight:950;
        text-transform:uppercase;
    }

    .ss-mobile-menu a.is-active{
        background:linear-gradient(135deg,rgba(133,92,255,.25),rgba(0,212,255,.13));
        color:#fff;
    }

    .ss-mobile-menu svg{
        width:16px;
        height:16px;
        fill:currentColor;
    }

    .ss-top-strip{
        position:relative;
        top:auto;
        display:flex;
        flex-direction:column-reverse;
        gap:12px;
        min-height:0;
        padding:12px 18px 14px;
        background:rgba(5,7,13,.72);
    }

    .ss-top-strip .ss-header-search{
        width:100%;
        height:44px;
    }

    .ss-top-ad-slot{
        width:100%;
    }

    .ss-top-ad-slot .ss-ad-unit,
    .ss-top-ad-slot .ss-ad-size-728x90,
    .ss-top-ad-slot .ss-ad-placement-728x90,
    .ss-top-ad-placeholder{
        min-height:64px;
        border-radius:15px;
    }
}

@media(max-width:560px){
    .ss-mobile-logo img{
        width:180px;
    }

    .ss-top-strip{
        padding-inline:12px;
    }
}

/* SlotStruck sidebar v2: square sidebar ad + lightning nav icons
   Paste after sidebar-layout-patch.css, or replace that patch with this one. */

.ss-side-nav{
    padding-top:24px;
    gap:0;
}

.ss-side-logo{
    padding:0 8px 26px;
}

.ss-side-logo img{
    width:218px;
    filter:drop-shadow(0 10px 26px rgba(0,0,0,.35));
}

.ss-side-tagline{
    display:none !important;
}

.ss-side-links{
    gap:10px;
}

.ss-side-links a{
    isolation:isolate;
    overflow:hidden;
    min-height:58px;
    border-radius:17px;
    background:
        radial-gradient(circle at 0% 50%,rgba(0,212,255,.055),transparent 12rem),
        rgba(255,255,255,.032);
    border-color:rgba(255,255,255,.045);
}

.ss-side-links a::after{
    content:"";
    position:absolute;
    inset:-1px;
    z-index:-1;
    opacity:0;
    background:
        linear-gradient(115deg,transparent 0%,rgba(255,255,255,.18) 37%,transparent 56%),
        radial-gradient(circle at 18% 50%,rgba(0,212,255,.20),transparent 12rem),
        radial-gradient(circle at 100% 50%,rgba(133,92,255,.18),transparent 12rem);
    transform:translateX(-65%);
    transition:opacity .2s ease, transform .55s ease;
}

.ss-side-links a:hover::after,
.ss-side-links a.is-active::after{
    opacity:1;
    transform:translateX(0);
}

.ss-side-links a:hover,
.ss-side-links a.is-active{
    border-color:rgba(0,212,255,.24);
    box-shadow:
        inset 0 0 0 1px rgba(255,255,255,.045),
        0 14px 34px rgba(0,212,255,.055);
}

.ss-side-links a:hover .ss-side-icon,
.ss-side-links a.is-active .ss-side-icon{
    color:#fff;
    border-color:rgba(0,212,255,.42);
    background:
        radial-gradient(circle at 35% 20%,rgba(255,255,255,.20),transparent 2.2rem),
        linear-gradient(135deg,rgba(133,92,255,.45),rgba(0,212,255,.26));
    box-shadow:
        0 0 0 1px rgba(255,255,255,.06),
        0 0 26px rgba(0,212,255,.18),
        0 10px 28px rgba(0,0,0,.24);
}

.ss-side-links a:hover .ss-lightning-icon,
.ss-side-links a.is-active .ss-lightning-icon{
    animation:ssBoltPulse .85s ease both;
}

.ss-side-links a:hover .ss-li-spark,
.ss-side-links a.is-active .ss-li-spark{
    animation:ssSparkFlash .75s ease both;
}

.ss-side-icon{
    position:relative;
    width:40px;
    height:40px;
    border-radius:15px;
    color:#9eeeff;
    background:
        radial-gradient(circle at 30% 20%,rgba(0,212,255,.13),transparent 2rem),
        linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.028));
    border:1px solid rgba(158,238,255,.15);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.055);
}

.ss-side-icon::before{
    content:"";
    position:absolute;
    inset:-9px;
    opacity:0;
    border-radius:20px;
    background:conic-gradient(from 120deg,transparent,rgba(0,212,255,.34),transparent,rgba(133,92,255,.30),transparent);
    filter:blur(9px);
    transition:opacity .22s ease;
}

.ss-side-links a:hover .ss-side-icon::before,
.ss-side-links a.is-active .ss-side-icon::before{
    opacity:.75;
}

.ss-lightning-icon{
    position:relative;
    z-index:2;
    width:22px !important;
    height:22px !important;
    display:block;
    fill:none !important;
}

.ss-lightning-icon .ss-li-line{
    fill:none;
    stroke:currentColor;
    stroke-width:1.9;
    stroke-linecap:round;
    stroke-linejoin:round;
    vector-effect:non-scaling-stroke;
}

.ss-lightning-icon .ss-li-glow{
    fill:currentColor;
    opacity:.12;
}

.ss-lightning-icon .ss-li-bolt{
    fill:currentColor;
    opacity:.95;
}

.ss-lightning-icon .ss-li-spark{
    fill:none;
    stroke:currentColor;
    stroke-width:1.8;
    stroke-linecap:round;
    opacity:.82;
}

@keyframes ssBoltPulse{
    0%{transform:scale(1) rotate(0deg);filter:drop-shadow(0 0 0 rgba(0,212,255,0))}
    38%{transform:scale(1.12) rotate(-4deg);filter:drop-shadow(0 0 10px rgba(0,212,255,.72))}
    100%{transform:scale(1) rotate(0deg);filter:drop-shadow(0 0 5px rgba(0,212,255,.34))}
}

@keyframes ssSparkFlash{
    0%,100%{opacity:.4;stroke-dasharray:1 10;stroke-dashoffset:0}
    45%{opacity:1;stroke-dasharray:10 1;stroke-dashoffset:-6}
}

.ss-side-square-ad{
    margin:18px 0 0;
    border-radius:20px;
    overflow:hidden;
    min-height:190px;
    background:
        radial-gradient(circle at 18% 0%,rgba(0,212,255,.14),transparent 12rem),
        linear-gradient(180deg,rgba(18,27,43,.92),rgba(7,11,20,.94));
    border:1px solid rgba(0,212,255,.16);
    box-shadow:0 18px 46px rgba(0,0,0,.22);
}

.ss-side-square-ad .ss-ad-unit,
.ss-side-square-ad .ss-ad-size-370x300,
.ss-side-square-ad .ss-ad-placement-370x300,
.ss-side-square-ad .ss-ad-placement-sidebar{
    width:100%;
    min-height:190px;
    height:190px;
    margin:0;
    border-radius:20px;
}

.ss-side-square-ad .ss-ad-unit img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.ss-side-ad-placeholder{
    min-height:190px;
    display:grid;
    place-items:center;
    gap:4px;
    padding:18px;
    text-align:center;
    border:1px dashed rgba(0,212,255,.28);
    border-radius:20px;
    background:
        linear-gradient(115deg,transparent,rgba(255,255,255,.06),transparent),
        rgba(255,255,255,.035);
    color:#dce8fb;
}

.ss-side-ad-placeholder span,
.ss-side-ad-placeholder strong{
    display:block;
}

.ss-side-ad-placeholder span{
    color:#9eeeff;
    font-size:10px;
    font-weight:950;
    letter-spacing:.16em;
    text-transform:uppercase;
}

.ss-side-ad-placeholder strong{
    max-width:150px;
    font-size:15px;
    line-height:1.18;
}

.ss-side-responsible{
    margin-top:auto;
}

/* Mobile keeps the new themed icons but stays compact. */
@media(max-width:940px){
    .ss-mobile-menu a{
        justify-content:flex-start;
        padding:0 14px;
    }

    .ss-mobile-menu .ss-lightning-icon{
        width:18px !important;
        height:18px !important;
    }
}

@media(max-height:760px) and (min-width:941px){
    .ss-side-logo{
        padding-bottom:18px;
    }

    .ss-side-links{
        gap:7px;
    }

    .ss-side-links a{
        min-height:52px;
    }

    .ss-side-square-ad{
        min-height:150px;
        margin-top:14px;
    }

    .ss-side-square-ad .ss-ad-unit,
    .ss-side-square-ad .ss-ad-size-370x300,
    .ss-side-square-ad .ss-ad-placement-370x300,
    .ss-side-square-ad .ss-ad-placement-sidebar,
    .ss-side-ad-placeholder{
        min-height:150px;
        height:150px;
    }

    .ss-side-responsible{
        padding:13px;
    }
}

/* SlotStruck sidebar v3 refinements
   Paste after sidebar-layout-patch.css and sidebar-layout-v2-patch.css. */

/* Hide generated ad labels because campaign creatives already contain their own disclosure. */
.ss-top-ad-slot .ss-ad-label,
.ss-side-square-ad .ss-ad-label,
.ss-grid-ad-card .ss-ad-label,
.ss-play-ad-wrap .ss-ad-label,
.ss-news-inline-ad .ss-ad-label,
.ss-news-side-ad .ss-ad-label,
.ss-article-ad-card .ss-ad-label{
    display:none !important;
}

/* Center the top 728x90 against the content area while keeping search on the right. */
@media(min-width:1181px){
    .ss-top-strip{
        grid-template-columns:280px minmax(520px,728px) 280px;
        justify-content:center;
        padding-inline:28px;
    }

    .ss-top-ad-slot{
        grid-column:2;
        justify-content:center;
        width:100%;
    }

    .ss-top-strip .ss-header-search{
        grid-column:3;
        width:280px;
        justify-self:end;
    }
}

@media(min-width:941px) and (max-width:1180px){
    .ss-top-strip{
        grid-template-columns:1fr 250px;
    }

    .ss-top-ad-slot{
        justify-content:center;
    }
}

/* Better themed New Slots icon: slot-machine 7 with cherry/bolt details. */
.ss-slot-seven-icon .ss-li-fruit{
    fill:currentColor;
    opacity:.95;
}

.ss-side-links a:hover .ss-slot-seven-icon .ss-li-fruit,
.ss-side-links a.is-active .ss-slot-seven-icon .ss-li-fruit,
.ss-mobile-menu a:hover .ss-slot-seven-icon .ss-li-fruit,
.ss-mobile-menu a.is-active .ss-slot-seven-icon .ss-li-fruit{
    animation:ssFruitPop .7s ease both;
}

.ss-side-links a:hover .ss-slot-seven-icon .ss-li-bolt,
.ss-side-links a.is-active .ss-slot-seven-icon .ss-li-bolt,
.ss-mobile-menu a:hover .ss-slot-seven-icon .ss-li-bolt,
.ss-mobile-menu a.is-active .ss-slot-seven-icon .ss-li-bolt{
    animation:ssSevenZap .72s ease both;
}

@keyframes ssFruitPop{
    0%{transform:translateY(0) scale(1);opacity:.72}
    42%{transform:translateY(-1.8px) scale(1.18);opacity:1;filter:drop-shadow(0 0 8px rgba(255,215,106,.7))}
    100%{transform:translateY(0) scale(1);opacity:.96}
}

@keyframes ssSevenZap{
    0%{filter:drop-shadow(0 0 0 rgba(0,212,255,0))}
    45%{filter:drop-shadow(0 0 10px rgba(0,212,255,.85)) drop-shadow(0 0 8px rgba(133,92,255,.55))}
    100%{filter:drop-shadow(0 0 5px rgba(0,212,255,.35))}
}

/* Give the fitted sidebar ad a little more polish without allowing labels to cover creative. */
.ss-side-square-ad{
    position:relative;
}

.ss-side-square-ad .ss-ad-unit::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(0,0,0,.08));
}

/* SlotStruck sidebar/top mobile banner fix v4
   Keeps 728x90 creatives fully visible on mobile instead of cropping the sides. */
@media (max-width: 940px){
    .ss-top-strip{
        overflow:hidden;
    }

    .ss-top-ad-slot{
        width:100%;
        max-width:100%;
        min-width:0;
        display:flex;
        justify-content:center;
        align-items:center;
        overflow:hidden;
        padding:0;
    }

    .ss-top-ad-slot .ss-ad-unit,
    .ss-top-ad-slot .ss-ad-size-728x90,
    .ss-top-ad-slot .ss-ad-placement-728x90,
    .ss-top-ad-placeholder{
        width:100% !important;
        max-width:728px !important;
        min-width:0 !important;
        min-height:0 !important;
        height:auto !important;
        aspect-ratio:728 / 90;
        margin:0 auto !important;
        border-radius:14px;
        overflow:hidden;
    }

    .ss-top-ad-slot .ss-ad-unit img,
    .ss-top-ad-slot .ss-ad-size-728x90 img,
    .ss-top-ad-slot .ss-ad-placement-728x90 img{
        width:100% !important;
        height:100% !important;
        object-fit:contain !important;
        object-position:center !important;
        display:block;
        transform:none !important;
    }

    .ss-top-ad-slot .ss-ad-unit:hover img{
        transform:none !important;
    }
}

@media (max-width: 560px){
    .ss-top-strip{
        padding:12px 10px 14px;
    }

    .ss-top-ad-slot .ss-ad-unit,
    .ss-top-ad-slot .ss-ad-size-728x90,
    .ss-top-ad-slot .ss-ad-placement-728x90,
    .ss-top-ad-placeholder{
        border-radius:12px;
    }
}

/* On very narrow phones, keep the banner readable without side clipping. */
@media (max-width: 380px){
    .ss-top-strip{
        padding-inline:8px;
    }

    .ss-top-ad-slot .ss-ad-unit,
    .ss-top-ad-slot .ss-ad-size-728x90,
    .ss-top-ad-slot .ss-ad-placement-728x90,
    .ss-top-ad-placeholder{
        border-radius:10px;
    }
}


/* SlotStruck sidebar/header responsive v5 fix
   Put this at the very bottom of assets/css/slotstruck-ui.css. */

/* Prevent generated ad labels from covering creatives. */
.ss-ad-label{display:none !important;}

/* Top strip: never let the search be chopped by the 728 banner. */
.ss-top-strip{
    min-width:0;
    overflow:hidden;
}

.ss-top-ad-slot,
.ss-top-strip .ss-header-search{
    min-width:0;
}

.ss-top-ad-slot .ss-ad-unit,
.ss-top-ad-slot .ss-ad-size-728x90,
.ss-top-ad-slot .ss-ad-placement-728x90,
.ss-top-ad-placeholder{
    width:100%;
    max-width:728px;
    min-width:0;
    aspect-ratio:728 / 90;
    min-height:0 !important;
    height:auto !important;
    margin:0 auto;
}

.ss-top-ad-slot .ss-ad-unit img,
.ss-top-ad-slot .ss-ad-size-728x90 img,
.ss-top-ad-slot .ss-ad-placement-728x90 img{
    width:100%;
    height:100%;
    object-fit:contain;
    object-position:center;
    display:block;
}

/* Wide desktop: centered ad + visible search. */
@media (min-width: 1501px){
    .ss-top-strip{
        display:grid;
        grid-template-columns:minmax(0,1fr) minmax(520px,728px) minmax(240px,280px);
        gap:22px;
        justify-content:center;
        padding:14px 34px;
    }

    .ss-top-ad-slot{grid-column:2;}
    .ss-top-strip .ss-header-search{grid-column:3;width:100%;max-width:280px;justify-self:end;}
}

/* Common laptop size with the sidebar: shrink the banner instead of clipping search. */
@media (min-width: 1181px) and (max-width: 1500px){
    .ss-top-strip{
        display:grid;
        grid-template-columns:minmax(360px,728px) minmax(210px,250px);
        gap:16px;
        padding:12px 20px;
        min-height:86px;
    }

    .ss-top-ad-slot{justify-content:center;}
    .ss-top-strip .ss-header-search{width:100%;max-width:250px;justify-self:end;}
}

/* Smaller desktop/tablet with sidebar: keep both items, with a compact search. */
@media (min-width: 941px) and (max-width: 1180px){
    .ss-top-strip{
        display:grid;
        grid-template-columns:minmax(300px,1fr) minmax(190px,230px);
        gap:14px;
        padding:12px 16px;
        min-height:78px;
    }

    .ss-top-strip .ss-header-search{width:100%;max-width:230px;}
}

/* Mobile: search first, banner below, no clipping. */
@media (max-width: 940px){
    .ss-top-strip{
        display:flex;
        flex-direction:column;
        gap:10px;
        padding:12px;
        overflow:hidden;
    }

    .ss-top-strip .ss-header-search{
        width:100%;
        max-width:none;
        flex:0 0 auto;
    }

    .ss-top-ad-slot{
        width:100%;
        max-width:100%;
        margin:0;
        padding:0;
        overflow:hidden;
        border-radius:12px;
    }

    .ss-top-ad-slot .ss-ad-unit,
    .ss-top-ad-slot .ss-ad-size-728x90,
    .ss-top-ad-slot .ss-ad-placement-728x90,
    .ss-top-ad-placeholder{
        width:100%;
        max-width:100%;
        border-radius:12px;
    }
}

@media (max-width: 480px){
    .ss-top-strip{
        padding:10px 10px 12px;
    }

    .ss-top-ad-slot{
        border-radius:10px;
    }

    .ss-top-ad-slot .ss-ad-unit,
    .ss-top-ad-slot .ss-ad-size-728x90,
    .ss-top-ad-slot .ss-ad-placement-728x90,
    .ss-top-ad-placeholder{
        border-radius:10px;
    }
}

/* SlotStruck top banner/search final responsive fix v6
   Paste at the very bottom of assets/css/slotstruck-ui.css */

/* Make the top strip predictable: centered ad, search never clipped */
.ss-main-shell{
    min-width:0;
}

.ss-top-strip{
    width:100%;
    min-width:0;
    display:grid !important;
    grid-template-columns:minmax(240px,1fr) minmax(320px,728px) minmax(240px,1fr);
    align-items:center;
    gap:18px;
    padding:14px clamp(18px,2.2vw,34px) !important;
    overflow:hidden;
}

.ss-top-ad-slot{
    grid-column:2;
    justify-self:center;
    width:100%;
    max-width:728px;
    min-width:0;
    height:auto;
    aspect-ratio:728 / 90;
    overflow:hidden;
    border-radius:16px;
}

.ss-top-strip .ss-header-search{
    grid-column:3;
    justify-self:end;
    width:min(100%,320px) !important;
    min-width:220px;
    max-width:320px;
    flex:0 1 auto;
}

/* Normalize whatever render_ad() outputs inside the top slot */
.ss-top-ad-slot .ss-ad-unit,
.ss-top-ad-slot .ss-ad-size-728x90,
.ss-top-ad-slot .ss-ad-placement-728x90,
.ss-top-ad-slot .ss-ad-banner,
.ss-top-ad-slot > a,
.ss-top-ad-slot > div{
    width:100% !important;
    max-width:728px !important;
    height:100% !important;
    min-height:0 !important;
    aspect-ratio:728 / 90;
    margin:0 auto !important;
    border-radius:16px;
    overflow:hidden;
}

.ss-top-ad-slot img,
.ss-top-ad-slot .ss-ad-unit img,
.ss-top-ad-slot .ss-ad-size-728x90 img,
.ss-top-ad-slot .ss-ad-placement-728x90 img{
    width:100% !important;
    height:100% !important;
    display:block !important;
    object-fit:contain !important;
    object-position:center !important;
    transform:none !important;
}

.ss-top-ad-slot .ss-ad-unit:hover img{
    transform:none !important;
}

/* Prevent generated ad labels/shines from covering supplied banner creative */
.ss-top-ad-slot .ss-ad-label,
.ss-top-ad-slot .ss-ad-shine,
.ss-top-ad-slot .ss-ad-bolt{
    display:none !important;
}

/* Laptop widths: keep search visible, let banner scale down gracefully */
@media (max-width:1500px){
    .ss-top-strip{
        grid-template-columns:minmax(0,1fr) minmax(300px,640px) minmax(240px,300px);
        gap:16px;
    }
}

@media (max-width:1280px){
    .ss-top-strip{
        grid-template-columns:minmax(280px,1fr) minmax(230px,300px);
        gap:16px;
    }

    .ss-top-ad-slot{
        grid-column:1;
        justify-self:center;
        max-width:728px;
    }

    .ss-top-strip .ss-header-search{
        grid-column:2;
        width:100% !important;
        min-width:0;
        max-width:300px;
    }
}

/* When the available content width gets tight, stack instead of squashing */
@media (max-width:1080px){
    .ss-top-strip{
        grid-template-columns:1fr;
        gap:12px;
        padding:12px 16px !important;
    }

    .ss-top-ad-slot,
    .ss-top-strip .ss-header-search{
        grid-column:1;
        justify-self:center;
    }

    .ss-top-ad-slot{
        width:min(728px,100%);
    }

    .ss-top-strip .ss-header-search{
        width:min(100%,420px) !important;
        max-width:420px;
    }
}

/* Mobile header: logo/menu, search, then a clean proportional banner */
@media (max-width:760px){
    .ss-top-strip{
        display:flex !important;
        flex-direction:column;
        align-items:stretch;
        gap:10px;
        padding:10px 10px 12px !important;
        overflow:visible;
    }

    .ss-top-strip .ss-header-search{
        order:1;
        width:100% !important;
        max-width:none;
        min-width:0;
        height:42px;
        justify-self:stretch;
    }

    .ss-top-ad-slot{
        order:2;
        width:100%;
        max-width:none;
        aspect-ratio:728 / 90;
        border-radius:12px;
        justify-self:stretch;
    }

    .ss-top-ad-slot .ss-ad-unit,
    .ss-top-ad-slot .ss-ad-size-728x90,
    .ss-top-ad-slot .ss-ad-placement-728x90,
    .ss-top-ad-slot .ss-ad-banner,
    .ss-top-ad-slot > a,
    .ss-top-ad-slot > div{
        max-width:none !important;
        border-radius:12px;
    }

    .ss-top-ad-slot img,
    .ss-top-ad-slot .ss-ad-unit img,
    .ss-top-ad-slot .ss-ad-size-728x90 img,
    .ss-top-ad-slot .ss-ad-placement-728x90 img{
        object-fit:contain !important;
    }
}

/* Fix top banner rounded-edge gaps */
.ss-top-ad-slot{
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    overflow:visible !important;
}

.ss-top-ad-slot .ss-ad-unit,
.ss-top-ad-slot .ss-ad-size-728x90,
.ss-top-ad-slot .ss-ad-placement-728x90{
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    overflow:hidden !important;
    border-radius:14px !important;
}

.ss-top-ad-slot .ss-ad-unit img,
.ss-top-ad-slot .ss-ad-size-728x90 img,
.ss-top-ad-slot .ss-ad-placement-728x90 img{
    width:100% !important;
    height:100% !important;
    display:block !important;
    object-fit:cover !important;
    border-radius:14px !important;
}

.ss-top-ad-slot .ss-ad-shine,
.ss-top-ad-slot .ss-ad-bolt,
.ss-top-ad-slot .ss-ad-label{
    display:none !important;
}

/* Mobile slot cards: equal heights + clean title clamping */
@media (max-width: 760px){
    .ss-slot-grid,
    .ss-slot-grid-featured,
    .ss-slot-grid-wide{
        align-items:stretch;
    }

    .ss-slot-card{
        height:100%;
        display:flex;
        flex-direction:column;
    }

    .ss-slot-art{
        flex:0 0 auto;
    }

    .ss-slot-body{
        flex:1;
        display:grid;
        grid-template-rows:auto auto 1fr;
        padding:12px;
        min-height:126px;
    }

    .ss-slot-body h3{
        min-height:38px;
        margin:0 0 7px;
        font-size:15px;
        line-height:1.25;
    }

    .ss-slot-body h3,
    .ss-slot-body h3 a{
        display:-webkit-box;
        -webkit-line-clamp:2;
        -webkit-box-orient:vertical;
        overflow:hidden;
    }

    .ss-slot-body p,
    .ss-provider-link{
        min-height:18px;
        margin:0 0 9px;
        font-size:13px;
        line-height:1.3;
        white-space:nowrap;
        overflow:hidden;
        text-overflow:ellipsis;
    }

    .ss-slot-meta{
        align-self:end;
        min-height:18px;
        gap:7px;
        font-size:10px;
        line-height:1.2;
    }

    .ss-slot-meta span{
        white-space:nowrap;
    }
}

@media (max-width: 420px){
    .ss-slot-body{
        min-height:132px;
    }

    .ss-slot-body h3{
        min-height:40px;
        font-size:14px;
    }

    .ss-slot-meta{
        font-size:9.5px;
        gap:5px;
    }
}

/* Keep grid ads full-size after mobile equal-card patch */
.ss-slot-grid > .ss-grid-ad-card,
.ss-slot-grid-featured > .ss-grid-ad-card,
.ss-slot-grid-wide > .ss-grid-ad-card{
    height:100%;
    min-height:0;
    align-self:stretch;
}

.ss-grid-ad-card{
    display:flex !important;
    align-items:stretch !important;
    justify-content:stretch !important;
}

.ss-grid-ad-card .ss-ad-unit,
.ss-grid-ad-card .ss-ad-size-370x300,
.ss-grid-ad-card .ss-ad-placement-370x300,
.ss-grid-ad-card .ss-ad-placement-sidebar{
    width:100% !important;
    height:100% !important;
    min-height:100% !important;
    aspect-ratio:auto !important;
    border-radius:22px !important;
}

.ss-grid-ad-card .ss-ad-unit img,
.ss-grid-ad-card .ss-ad-size-370x300 img,
.ss-grid-ad-card .ss-ad-placement-370x300 img,
.ss-grid-ad-card .ss-ad-placement-sidebar img{
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    display:block !important;
    border-radius:22px !important;
}

@media (max-width: 760px){
    .ss-slot-grid > .ss-grid-ad-card,
    .ss-slot-grid-featured > .ss-grid-ad-card,
    .ss-slot-grid-wide > .ss-grid-ad-card{
        grid-column:1 / -1;
        min-height:260px;
    }

    .ss-grid-ad-card .ss-ad-unit,
    .ss-grid-ad-card .ss-ad-size-370x300,
    .ss-grid-ad-card .ss-ad-placement-370x300,
    .ss-grid-ad-card .ss-ad-placement-sidebar{
        min-height:260px !important;
        height:260px !important;
    }
}

@media (min-width: 761px){
    .ss-slot-grid > .ss-grid-ad-card,
    .ss-slot-grid-featured > .ss-grid-ad-card,
    .ss-slot-grid-wide > .ss-grid-ad-card{
        min-height:100%;
    }
}

/* SlotStruck display font: Newake */
@font-face{
    font-family:"Newake";
    src:url("/assets/fonts/Muroslant.otf") format("opentype");
    font-weight:400 950;
    font-style:normal;
    font-display:swap;
}

/* Keep body text readable */
body,
input,
textarea,
select{
    font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Use Urban Shadow for branded UI/display text */
h1,
.ss-btn,
.ss-play-btn,
.ss-article-hero h1,
.ss-calendar-title,
.ss-kicker,
.ss-play-kicker,
.ss-play-chip,
.ss-play-stat,
.ss-pill,
.ss-status-badge,
.ss-icon-pill,
.ss-pagination a,
.ss-footer-col h3,
.ss-footer-panel h3,
.ss-footer-badges span{
    font-family:"Newake", Inter, ui-sans-serif, system-ui, sans-serif;
    letter-spacing:.12em;
}

/* Prevent the display font from getting too cramped */
.ss-hero-copy h1,
.ss-home-topbar h1,
.ss-play-copy h1,
.ss-news-hero-copy h1,
.ss-article-hero h1{
    letter-spacing:-.025em;
}

/* Keep long-form content clean */
p,
li,
.ss-prose,
.ss-play-review,
.ss-article-content,
.ss-news-card-v2-body p,
.ss-featured-news-v2-copy p,
.ss-slot-body p,
.ss-provider-link,
.ss-slot-meta,
.ss-play-subline,
.ss-play-demo-panel small{
    font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* SlotStruck simple lightning page loader */
.ss-page-loader{
    position:fixed;
    inset:0;
    z-index:2147483000;
    display:grid;
    place-items:center;
    background:
        radial-gradient(circle at 50% 45%,rgba(42,220,255,.105),transparent 17rem),
        rgba(3,5,10,.965);
    opacity:1;
    visibility:visible;
    transition:opacity .42s ease,visibility .42s ease;
}

.ss-page-loader.is-done{
    opacity:0;
    visibility:hidden;
    pointer-events:none;
}

.ss-loader-core{
    position:relative;
    width:112px;
    height:112px;
    display:grid;
    place-items:center;
    isolation:isolate;
}

.ss-loader-orbit{
    position:absolute;
    inset:10px;
    border-radius:999px;
    border:1px solid rgba(145,236,255,.18);
    border-top-color:rgba(235,253,255,.92);
    border-right-color:rgba(97,224,255,.52);
    filter:
        drop-shadow(0 0 10px rgba(89,219,255,.35))
        drop-shadow(0 0 26px rgba(89,219,255,.16));
    animation:ssLoaderOrbit .72s cubic-bezier(.55,.02,.32,1) infinite;
}

.ss-loader-orbit::after{
    content:"";
    position:absolute;
    inset:10px;
    border-radius:inherit;
    border:1px solid rgba(255,255,255,.055);
}

.ss-loader-bolt{
    position:relative;
    z-index:3;
    width:54px;
    height:80px;
    overflow:visible;
    transform-origin:50% 50%;
    color:#ecfbff;
    filter:
        drop-shadow(0 0 9px rgba(239,253,255,.72))
        drop-shadow(0 0 22px rgba(35,213,255,.48))
        drop-shadow(0 0 44px rgba(35,213,255,.18));
    animation:ssLoaderBolt 1.34s cubic-bezier(.7,0,.18,1) infinite;
}

.ss-loader-bolt path{
    fill:currentColor;
}

.ss-loader-strike{
    position:absolute;
    z-index:2;
    top:-26px;
    left:50%;
    width:2px;
    height:150px;
    border-radius:999px;
    transform:translateX(-50%) scaleY(0);
    transform-origin:50% 0;
    background:linear-gradient(
        180deg,
        transparent,
        rgba(255,255,255,.95) 30%,
        rgba(90,224,255,.92) 54%,
        transparent
    );
    filter:
        blur(.2px)
        drop-shadow(0 0 12px rgba(134,235,255,.9))
        drop-shadow(0 0 34px rgba(44,213,255,.28));
    opacity:0;
    animation:ssLoaderStrike 1.34s cubic-bezier(.7,0,.18,1) infinite;
}

.ss-loader-spark{
    position:absolute;
    z-index:4;
    left:50%;
    top:50%;
    width:4px;
    height:4px;
    margin:-2px 0 0 -2px;
    border-radius:999px;
    background:#f4fdff;
    box-shadow:0 0 11px rgba(110,229,255,.92);
    opacity:0;
    transform:translate3d(0,0,0) scale(.6);
    animation:ssLoaderSpark 1.34s cubic-bezier(.12,.8,.22,1) infinite;
}

.ss-loader-spark-1{--spark-x:34px;--spark-y:-30px;animation-delay:.08s}
.ss-loader-spark-2{--spark-x:-36px;--spark-y:-22px;animation-delay:.11s}
.ss-loader-spark-3{--spark-x:42px;--spark-y:10px;animation-delay:.14s}
.ss-loader-spark-4{--spark-x:-42px;--spark-y:14px;animation-delay:.16s}
.ss-loader-spark-5{--spark-x:21px;--spark-y:42px;animation-delay:.19s}
.ss-loader-spark-6{--spark-x:-18px;--spark-y:43px;animation-delay:.21s}

@keyframes ssLoaderOrbit{
    0%{transform:rotate(0deg) scale(.96);opacity:.95}
    65%{transform:rotate(470deg) scale(1);opacity:.9}
    72%{transform:rotate(520deg) scale(1.1);opacity:.18}
    100%{transform:rotate(620deg) scale(.96);opacity:.85}
}

@keyframes ssLoaderBolt{
    0%{transform:rotate(0deg) scale(.88);opacity:.95}
    48%{transform:rotate(610deg) scale(1);opacity:1}
    61%{transform:rotate(720deg) translateY(0) scale(1.02);opacity:1}
    70%{transform:rotate(720deg) translateY(18px) scale(1.18);opacity:1}
    77%{transform:rotate(720deg) translateY(12px) scale(.98);opacity:.78}
    100%{transform:rotate(720deg) translateY(0) scale(.88);opacity:.95}
}

@keyframes ssLoaderStrike{
    0%,54%{opacity:0;transform:translateX(-50%) scaleY(0)}
    62%{opacity:.95;transform:translateX(-50%) scaleY(.18)}
    70%{opacity:1;transform:translateX(-50%) scaleY(1)}
    82%,100%{opacity:0;transform:translateX(-50%) scaleY(0)}
}

@keyframes ssLoaderSpark{
    0%,58%{
        opacity:0;
        transform:translate3d(0,0,0) scale(.4);
    }
    68%{
        opacity:1;
        transform:translate3d(calc(var(--spark-x) * .28),calc(var(--spark-y) * .28),0) scale(1);
    }
    88%,100%{
        opacity:0;
        transform:translate3d(var(--spark-x),var(--spark-y),0) scale(.1);
    }
}

@media (prefers-reduced-motion:reduce){
    .ss-page-loader{
        transition:opacity .22s ease,visibility .22s ease;
    }

    .ss-loader-orbit,
    .ss-loader-bolt,
    .ss-loader-strike,
    .ss-loader-spark{
        animation:none !important;
    }

    .ss-loader-orbit{
        opacity:.55;
    }

    .ss-loader-bolt{
        transform:none;
    }

    .ss-loader-strike,
    .ss-loader-spark{
        display:none;
    }
}

/* SlotStruck news header compact alignment fix
   Paste at the very bottom of /assets/css/slotstruck-ui.css */

/* New redesigned news header */
.ss-news-hero-v2{
    padding:32px 0 24px !important;
    min-height:0 !important;
    background:
        radial-gradient(circle at 18% 0%, rgba(133,92,255,.16), transparent 30rem),
        radial-gradient(circle at 78% 4%, rgba(0,212,255,.10), transparent 30rem),
        linear-gradient(180deg, rgba(9,14,24,.84), rgba(5,7,13,.28)) !important;
}

.ss-news-hero-v2-inner{
    display:block !important;
    max-width:1120px !important;
}

.ss-news-hero-copy{
    max-width:860px !important;
}

.ss-news-hero-copy .ss-kicker,
.ss-news-hero-v2 .ss-kicker{
    font-size:11px !important;
    line-height:1.2 !important;
    letter-spacing:.10em !important;
    margin-bottom:0 !important;
}

.ss-news-hero-copy .ss-kicker svg,
.ss-news-hero-v2 .ss-kicker svg{
    width:14px !important;
    height:14px !important;
}

.ss-news-hero-copy h1{
    max-width:760px !important;
    margin:14px 0 10px !important;
    font-size:clamp(36px, 4vw, 58px) !important;
    line-height:.94 !important;
    letter-spacing:-.035em !important;
}

.ss-news-hero-copy p{
    max-width:720px !important;
    font-size:15.5px !important;
    line-height:1.55 !important;
    color:#c5d0e4 !important;
}

.ss-news-hero-pills{
    margin-top:18px !important;
    gap:8px !important;
}

.ss-news-hero-pills span{
    min-height:34px !important;
    padding:0 11px !important;
    gap:7px !important;
    font-size:12px !important;
    line-height:1 !important;
    border-radius:999px !important;
}

.ss-news-hero-pills svg{
    width:13px !important;
    height:13px !important;
}

.ss-news-hero-panel{
    display:none !important;
}

/* Older news.php header class fallback */
.ss-news-hero{
    padding:32px 0 24px !important;
    min-height:0 !important;
}

.ss-news-hero-inner{
    display:block !important;
    max-width:1120px !important;
}

.ss-news-hero h1{
    max-width:760px !important;
    margin:14px 0 10px !important;
    font-size:clamp(36px, 4vw, 58px) !important;
    line-height:.94 !important;
    letter-spacing:-.035em !important;
}

.ss-news-hero p{
    max-width:720px !important;
    font-size:15.5px !important;
    line-height:1.55 !important;
}

.ss-news-hero-card{
    display:none !important;
}

@media (max-width:760px){
    .ss-news-hero-v2,
    .ss-news-hero{
        padding:24px 0 20px !important;
    }

    .ss-news-hero-copy h1,
    .ss-news-hero h1{
        font-size:34px !important;
        line-height:.96 !important;
        margin:12px 0 9px !important;
    }

    .ss-news-hero-copy p,
    .ss-news-hero p{
        font-size:14.5px !important;
        line-height:1.5 !important;
    }

    .ss-news-hero-pills{
        margin-top:14px !important;
    }

    .ss-news-hero-pills span{
        min-height:32px !important;
        font-size:11.5px !important;
        padding:0 10px !important;
    }
}

/* SlotStruck news page: align with standard slot listing pages
   Add at the very bottom of /assets/css/slotstruck-ui.css */

.ss-news-index{
    padding-bottom:70px;
}

.ss-news-index-head{
    position:relative;
    overflow:hidden;
    padding:32px 0 14px;
    border-bottom:1px solid rgba(103,232,255,.22);
    background:
        radial-gradient(circle at 20% 0%, rgba(133,92,255,.16), transparent 30rem),
        radial-gradient(circle at 78% 8%, rgba(0,212,255,.14), transparent 32rem),
        linear-gradient(180deg, rgba(9,14,24,.88), rgba(5,7,13,.36));
}

.ss-news-index-head::after{
    content:"";
    position:absolute;
    inset:auto 0 0;
    height:1px;
    background:linear-gradient(90deg,transparent,rgba(0,212,255,.55),rgba(133,92,255,.35),transparent);
    opacity:.75;
}

.ss-news-index-head .ss-container{
    position:relative;
    z-index:2;
}

.ss-news-index-head .ss-kicker svg{
    width:14px;
    height:14px;
}

.ss-news-index-head h1{
    max-width:760px;
    margin:14px 0 5px;
    font-size:clamp(36px,4vw,58px);
    line-height:.93;
    letter-spacing:-.025em;
    text-transform:uppercase;
}

.ss-news-index-head p{
    max-width:780px;
    margin:0;
    color:#c7d2e8;
    font-size:15px;
    line-height:1.5;
}

.ss-news-index-wrap{
    padding-top:28px;
}

.ss-news-index-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:22px;
    align-items:stretch;
}

.ss-news-index-card{
    position:relative;
    display:flex;
    flex-direction:column;
    min-width:0;
    overflow:hidden;
    border-radius:22px;
    color:white;
    text-decoration:none;
    background:linear-gradient(180deg,rgba(15,23,37,.98),rgba(8,11,18,.98));
    border:1px solid rgba(170,189,220,.16);
    box-shadow:0 12px 36px rgba(0,0,0,.28);
    transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease;
}

.ss-news-index-card:hover{
    transform:translateY(-6px);
    border-color:rgba(0,212,255,.32);
    box-shadow:0 20px 60px rgba(0,212,255,.1),0 18px 50px rgba(0,0,0,.32);
}

.ss-news-index-card-img{
    position:relative;
    display:block;
    overflow:hidden;
    aspect-ratio:300 / 173;
    background:#111927;
}

.ss-news-index-card-img::after{
    content:"";
    position:absolute;
    inset:auto 0 0;
    height:48%;
    background:linear-gradient(transparent,rgba(0,0,0,.72));
    pointer-events:none;
}

.ss-news-index-card-img img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
    transition:transform .3s ease;
}

.ss-news-index-card:hover .ss-news-index-card-img img{
    transform:scale(1.05);
}

.ss-news-index-body{
    flex:1;
    display:flex;
    flex-direction:column;
    padding:17px;
}

.ss-news-index-date{
    display:inline-flex;
    align-items:center;
    gap:6px;
    margin-bottom:9px;
    color:#9eeeff;
    font-size:11px;
    font-weight:950;
    letter-spacing:.07em;
    text-transform:uppercase;
}

.ss-news-index-date svg{
    width:13px;
    height:13px;
    fill:currentColor;
}

.ss-news-index-body h2,
.ss-news-index-body h3{
    margin:0 0 9px;
    color:#fff;
    font-size:20px;
    line-height:1.16;
    letter-spacing:-.015em;
}

.ss-news-index-body h2 a,
.ss-news-index-body h3 a{
    color:inherit;
    text-decoration:none;
}

.ss-news-index-body h2 a:hover,
.ss-news-index-body h3 a:hover{
    color:#9eeeff;
}

.ss-news-index-body p{
    margin:0 0 16px;
    color:#b9c6dd;
    font-size:14px;
    line-height:1.55;
    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

.ss-news-index-link{
    display:inline-flex;
    align-items:center;
    gap:7px;
    margin-top:auto;
    color:#9eeeff;
    font-size:12px;
    font-weight:950;
    letter-spacing:.04em;
    text-transform:uppercase;
    text-decoration:none;
}

.ss-news-index-link svg{
    width:14px;
    height:14px;
    fill:currentColor;
    transition:transform .18s ease;
}

.ss-news-index-link:hover svg{
    transform:translateX(3px);
}

.ss-news-index-ad{
    min-height:100%;
    border-radius:22px;
    overflow:hidden;
    background:transparent;
}

.ss-news-index-ad .ss-ad-unit,
.ss-news-index-ad .ss-ad-size-370x300,
.ss-news-index-ad .ss-ad-placement-370x300,
.ss-news-index-ad .ss-ad-placement-sidebar{
    width:100% !important;
    height:100% !important;
    min-height:100% !important;
    margin:0 !important;
    border-radius:22px !important;
}

.ss-news-index-ad img{
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    display:block !important;
}

.ss-news-inline-banner{
    grid-column:1 / -1;
    display:flex;
    justify-content:center;
    padding:2px 0;
}

.ss-news-inline-banner .ss-ad-unit,
.ss-news-inline-banner .ss-ad-size-728x90,
.ss-news-inline-banner .ss-ad-placement-728x90{
    margin:0 auto !important;
}

/* If older news-v2 markup is still cached somewhere, force it back into the same left-aligned rhythm. */
.ss-news-hero-v2{
    padding:32px 0 14px !important;
}

.ss-news-hero-v2-inner{
    width:min(1400px,calc(100% - 40px)) !important;
    max-width:none !important;
    display:block !important;
    margin-inline:auto !important;
}

.ss-news-hero-copy{
    max-width:780px !important;
}

.ss-news-hero-pills,
.ss-news-hero-panel{
    display:none !important;
}

.ss-news-hero-copy h1{
    font-size:clamp(36px,4vw,58px) !important;
    margin:14px 0 5px !important;
    line-height:.93 !important;
    letter-spacing:-.025em !important;
}

.ss-news-hero-copy p{
    max-width:780px !important;
    font-size:15px !important;
    line-height:1.5 !important;
}

@media(max-width:1200px){
    .ss-news-index-grid{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }
}

@media(max-width:760px){
    .ss-news-index-head{
        padding:24px 0 18px;
    }

    .ss-news-index-head h1{
        font-size:34px;
        margin:12px 0 7px;
    }

    .ss-news-index-head p{
        font-size:14px;
        line-height:1.45;
    }

    .ss-news-index-wrap{
        padding-top:18px;
    }

    .ss-news-index-grid{
        grid-template-columns:repeat(2,minmax(0,1fr));
        gap:14px;
    }

    .ss-news-index-card{
        border-radius:18px;
    }

    .ss-news-index-body{
        padding:12px;
        min-height:150px;
    }

    .ss-news-index-body h2,
    .ss-news-index-body h3{
        min-height:38px;
        font-size:15px;
        line-height:1.25;
        display:-webkit-box;
        -webkit-line-clamp:2;
        -webkit-box-orient:vertical;
        overflow:hidden;
    }

    .ss-news-index-body p{
        display:none;
    }

    .ss-news-index-date{
        font-size:10px;
        margin-bottom:7px;
    }

    .ss-news-index-link{
        font-size:10px;
    }

    .ss-news-index-ad{
        grid-column:1 / -1;
        min-height:260px;
    }

    .ss-news-index-ad .ss-ad-unit,
    .ss-news-index-ad .ss-ad-size-370x300,
    .ss-news-index-ad .ss-ad-placement-370x300,
    .ss-news-index-ad .ss-ad-placement-sidebar{
        min-height:260px !important;
        height:260px !important;
    }
}

@media(max-width:420px){
    .ss-news-index-grid{
        gap:12px;
    }

    .ss-news-index-body{
        min-height:142px;
        padding:11px;
    }

    .ss-news-index-body h2,
    .ss-news-index-body h3{
        font-size:14px;
    }
}



/* SlotStruck news article page: align with the new compact news/listing style
   Add at the very bottom of /assets/css/slotstruck-ui.css */

.ss-news-article-page{
    padding-bottom:70px;
}

.ss-news-article-head{
    position:relative;
    overflow:hidden;
    padding:30px 0 18px;
    border-bottom:1px solid rgba(103,232,255,.22);
    background:
        radial-gradient(circle at 20% 0%, rgba(133,92,255,.16), transparent 30rem),
        radial-gradient(circle at 78% 8%, rgba(0,212,255,.14), transparent 32rem),
        linear-gradient(180deg, rgba(9,14,24,.88), rgba(5,7,13,.36));
}

.ss-news-article-head::after{
    content:"";
    position:absolute;
    inset:auto 0 0;
    height:1px;
    background:linear-gradient(90deg,transparent,rgba(0,212,255,.55),rgba(133,92,255,.35),transparent);
    opacity:.75;
}

.ss-news-article-head .ss-container{
    position:relative;
    z-index:2;
}

.ss-news-article-back{
    display:inline-flex;
    align-items:center;
    gap:7px;
    margin:0 0 16px;
    color:#aebbd4;
    text-decoration:none;
    font-size:12px;
    font-weight:950;
    line-height:1;
    text-transform:uppercase;
    letter-spacing:.06em;
    transition:color .18s ease, transform .18s ease;
}

.ss-news-article-back:hover{
    color:#fff;
    transform:translateX(-3px);
}

.ss-news-article-back svg{
    width:14px;
    height:14px;
    fill:currentColor;
}

.ss-news-article-head .ss-kicker svg{
    width:14px;
    height:14px;
}

.ss-news-article-head h1{
    max-width:960px;
    margin:14px 0 8px;
    font-size:clamp(36px,4.3vw,64px);
    line-height:.94;
    letter-spacing:-.025em;
    text-transform:uppercase;
    text-wrap:balance;
}

.ss-news-article-head p{
    max-width:780px;
    margin:0;
    color:#c7d2e8;
    font-size:15px;
    line-height:1.55;
}

.ss-news-article-meta{
    display:flex;
    flex-wrap:wrap;
    gap:9px;
    margin-top:15px;
}

.ss-news-article-meta span{
    display:inline-flex;
    align-items:center;
    gap:7px;
    min-height:34px;
    padding:0 12px;
    border-radius:999px;
    color:#dce8fb;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.11);
    font-size:12px;
    font-weight:850;
}

.ss-news-article-meta svg{
    width:13px;
    height:13px;
    fill:#9eeeff;
}

.ss-news-article-wrap{
    padding-top:28px;
}

.ss-news-article-layout{
    display:grid;
    grid-template-columns:minmax(0,1fr) 340px;
    gap:28px;
    align-items:start;
}

.ss-news-article-main{
    min-width:0;
    overflow:hidden;
    border-radius:24px;
    background:linear-gradient(180deg,rgba(15,23,37,.98),rgba(8,11,18,.98));
    border:1px solid rgba(170,189,220,.16);
    box-shadow:0 18px 56px rgba(0,0,0,.30);
}

.ss-news-article-image{
    position:relative;
    overflow:hidden;
    aspect-ratio:16 / 7;
    min-height:260px;
    background:#111927;
}

.ss-news-article-image::after{
    content:"";
    position:absolute;
    inset:auto 0 0;
    height:45%;
    background:linear-gradient(transparent,rgba(0,0,0,.68));
    pointer-events:none;
}

.ss-news-article-image img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
}

.ss-news-article-content{
    padding:clamp(22px,3.5vw,42px);
}

.ss-news-article-summary{
    margin:0 0 28px;
    padding:18px 20px;
    border-radius:18px;
    color:#dce8fb;
    background:
        radial-gradient(circle at 0% 0%,rgba(0,212,255,.10),transparent 18rem),
        linear-gradient(135deg,rgba(255,255,255,.065),rgba(255,255,255,.028));
    border:1px solid rgba(255,255,255,.11);
}

.ss-news-article-summary strong{
    display:block;
    margin-bottom:7px;
    color:#9eeeff;
    font-size:11px;
    font-weight:950;
    line-height:1;
    letter-spacing:.10em;
    text-transform:uppercase;
}

.ss-news-article-summary p{
    margin:0;
    color:#d7e2f5;
    font-size:16px;
    line-height:1.65;
}

.ss-news-article-content .ss-prose,
.ss-news-article-content .ss-prose p,
.ss-news-article-content .ss-prose li{
    color:#d7e2f5;
    font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size:17px;
    line-height:1.82;
}

.ss-news-article-content .ss-prose > *:first-child{
    margin-top:0;
}

.ss-news-article-content .ss-prose p{
    margin:0 0 1.28em;
}

.ss-news-article-content .ss-prose h2,
.ss-news-article-content .ss-prose h3,
.ss-news-article-content .ss-prose h4{
    color:#fff;
    line-height:1.08;
    letter-spacing:-.025em;
    text-wrap:balance;
}

.ss-news-article-content .ss-prose h2{
    margin:1.45em 0 .55em;
    font-size:clamp(28px,3vw,42px);
}

.ss-news-article-content .ss-prose h3{
    margin:1.35em 0 .5em;
    font-size:clamp(23px,2.2vw,30px);
}

.ss-news-article-content .ss-prose a{
    color:#9eeeff;
    font-weight:850;
    text-decoration:none;
    border-bottom:1px solid rgba(158,238,255,.35);
}

.ss-news-article-content .ss-prose ul,
.ss-news-article-content .ss-prose ol{
    margin:0 0 1.35em;
    padding-left:1.25em;
}

.ss-news-article-content .ss-prose li{
    margin:.42em 0;
}

.ss-news-article-content .ss-prose blockquote{
    margin:1.8em 0;
    padding:18px 20px;
    border-left:3px solid var(--ss-blue);
    border-radius:16px;
    background:rgba(255,255,255,.055);
    color:#fff;
    font-weight:800;
}

.ss-news-article-content .ss-prose img{
    width:100%;
    height:auto;
    border-radius:18px;
    border:1px solid rgba(255,255,255,.1);
    box-shadow:0 16px 44px rgba(0,0,0,.24);
}

.ss-news-article-sidebar{
    display:grid;
    gap:20px;
    min-width:0;
}

.ss-news-article-side-card,
.ss-news-article-ad-card{
    overflow:hidden;
    border-radius:22px;
    background:linear-gradient(180deg,rgba(15,23,37,.98),rgba(8,11,18,.98));
    border:1px solid rgba(170,189,220,.16);
    box-shadow:0 12px 36px rgba(0,0,0,.28);
}

.ss-news-article-side-card{
    padding:20px;
}

.ss-news-article-side-card h3{
    margin:0 0 10px;
    color:#fff;
    font-size:22px;
    line-height:1.1;
    letter-spacing:-.015em;
}

.ss-news-article-side-card p{
    margin:0 0 16px;
    color:#b9c6dd;
    font-size:14px;
    line-height:1.55;
}

.ss-news-article-side-title{
    display:flex;
    align-items:center;
    gap:8px;
    margin:0 0 14px !important;
    color:#fff;
    font-size:14px !important;
    line-height:1 !important;
    text-transform:uppercase;
    letter-spacing:.07em !important;
}

.ss-news-article-side-title svg{
    width:15px;
    height:15px;
    fill:var(--ss-gold);
}

.ss-news-article-ad-card .ss-ad-unit,
.ss-news-article-ad-card .ss-ad-size-370x300,
.ss-news-article-ad-card .ss-ad-placement-370x300,
.ss-news-article-ad-card .ss-ad-placement-sidebar{
    width:100% !important;
    min-height:300px !important;
    margin:0 !important;
    border-radius:22px !important;
}

.ss-news-article-sticky{
    position:sticky;
    top:104px;
}

.ss-news-article-list{
    display:grid;
    gap:10px;
}

.ss-news-article-list a{
    display:grid;
    grid-template-columns:74px minmax(0,1fr);
    gap:11px;
    align-items:center;
    padding:9px;
    border-radius:14px;
    color:inherit;
    text-decoration:none;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.07);
    transition:transform .18s ease, background .18s ease, border-color .18s ease;
}

.ss-news-article-list a:hover{
    transform:translateX(3px);
    background:rgba(255,255,255,.07);
    border-color:rgba(0,212,255,.24);
}

.ss-news-article-list img{
    width:74px;
    height:48px;
    object-fit:cover;
    border-radius:10px;
    background:#111927;
}

.ss-news-article-list strong,
.ss-news-article-list small{
    display:block;
}

.ss-news-article-list strong{
    color:#fff;
    font-size:13px;
    line-height:1.22;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.ss-news-article-list small{
    margin-top:4px;
    color:#9eeeff;
    font-size:11px;
    font-weight:850;
    text-transform:uppercase;
    letter-spacing:.05em;
}

.ss-news-article-bottom-ad{
    display:flex;
    justify-content:center;
    margin:28px 0 8px;
}

.ss-news-article-bottom-ad .ss-ad-unit,
.ss-news-article-bottom-ad .ss-ad-size-728x90,
.ss-news-article-bottom-ad .ss-ad-placement-728x90{
    margin:0 auto !important;
}

.ss-news-article-related-head{
    margin-top:38px;
}

.ss-news-article-related-grid{
    margin-top:18px;
}

/* Hide older oversized article styles if any old markup is still cached. */
.ss-article-hero{
    padding:30px 0 18px !important;
}

.ss-article-hero h1{
    font-size:clamp(36px,4.3vw,64px) !important;
    line-height:.94 !important;
    letter-spacing:-.025em !important;
}

.ss-article-image-wrap{
    min-height:260px !important;
}

@media(max-width:1180px){
    .ss-news-article-layout{
        grid-template-columns:1fr;
    }

    .ss-news-article-sidebar{
        grid-template-columns:1fr 1fr;
    }

    .ss-news-article-sticky{
        position:relative;
        top:auto;
    }
}

@media(max-width:760px){
    .ss-news-article-head{
        padding:24px 0 18px;
    }

    .ss-news-article-back{
        margin-bottom:13px;
        font-size:11px;
    }

    .ss-news-article-head h1{
        margin:12px 0 7px;
        font-size:34px;
        line-height:.96;
    }

    .ss-news-article-head p{
        font-size:14px;
        line-height:1.48;
    }

    .ss-news-article-meta{
        gap:7px;
        margin-top:12px;
    }

    .ss-news-article-meta span{
        min-height:31px;
        padding:0 10px;
        font-size:11px;
    }

    .ss-news-article-wrap{
        padding-top:18px;
    }

    .ss-news-article-layout{
        gap:18px;
    }

    .ss-news-article-main,
    .ss-news-article-side-card,
    .ss-news-article-ad-card{
        border-radius:18px;
    }

    .ss-news-article-image{
        aspect-ratio:16 / 10;
        min-height:190px;
    }

    .ss-news-article-content{
        padding:18px;
    }

    .ss-news-article-summary{
        padding:16px;
        border-radius:16px;
        margin-bottom:22px;
    }

    .ss-news-article-summary p,
    .ss-news-article-content .ss-prose,
    .ss-news-article-content .ss-prose p,
    .ss-news-article-content .ss-prose li{
        font-size:15.5px;
        line-height:1.72;
    }

    .ss-news-article-sidebar{
        grid-template-columns:1fr;
        gap:16px;
    }

    .ss-news-article-related-head{
        margin-top:30px;
    }
}
/* Homepage hero art: keep Zeus below the copy on smaller screens */
@media (max-width: 1100px){
    .ss-home-topbar{
        padding-bottom:0 !important;
    }

    .ss-home-topbar-inner{
        display:flex !important;
        flex-direction:column !important;
        align-items:flex-start !important;
        justify-content:flex-start !important;
        gap:0 !important;
    }

    .ss-home-topbar-inner > :not(.ss-home-art-card){
        position:relative;
        z-index:3;
        max-width:820px;
    }

    .ss-home-art-card{
        position:relative !important;
        z-index:1;
        width:100% !important;
        min-height:0 !important;
        height:auto !important;
        margin:12px 0 0 !important;
        display:flex !important;
        align-items:flex-end !important;
        justify-content:center !important;
        overflow:hidden !important;
        pointer-events:none;
    }

    .ss-home-hero-img{
        position:relative !important;
        inset:auto !important;
        right:auto !important;
        bottom:auto !important;
        left:auto !important;
        width:min(520px,100%) !important;
        max-width:520px !important;
        max-height:none !important;
        height:auto !important;
        margin:0 auto -2px !important;
        display:block !important;
        object-fit:contain !important;
        transform:none !important;
        animation:ssHeroFloatMobile 5.5s ease-in-out infinite !important;
    }
}

@keyframes ssHeroFloatMobile{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-5px)}
}

@media (max-width: 760px){
    .ss-home-topbar{
        padding:24px 0 0 !important;
    }

    .ss-home-topbar h1{
        max-width:100%;
        margin-bottom:8px;
    }

    .ss-home-topbar p{
        max-width:100%;
        line-height:1.55;
    }

    .ss-home-art-card{
        margin-top:6px !important;
    }

    .ss-home-hero-img{
        width:min(390px,100%) !important;
        max-width:390px !important;
        margin-bottom:-1px !important;
    }
}

@media (max-width: 430px){
    .ss-home-art-card{
        margin-top:2px !important;
    }

    .ss-home-hero-img{
        width:min(360px,104%) !important;
        max-width:360px !important;
    }
}

/* Calendar page: restore full-width header band */
.ss-cal-v2{
    padding-top:0 !important;
}

.ss-cal-v2 > .ss-cal-shell{
    width:100% !important;
    max-width:none !important;
    margin-inline:0 !important;
}

.ss-cal-v2 .ss-cal-topline{
    position:relative !important;
    isolation:isolate !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:24px !important;
    min-height:156px !important;
    margin:0 0 24px !important;
    padding:32px max(22px, calc((100% - 1460px) / 2)) 28px !important;
    overflow:hidden !important;
    border-bottom:1px solid rgba(0,212,255,.22) !important;
    box-shadow:inset 0 -1px 0 rgba(255,255,255,.04) !important;
}

.ss-cal-v2 .ss-cal-topline::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:-2;
    background:
        linear-gradient(90deg,rgba(133,92,255,.12),transparent 46%,rgba(0,212,255,.10)),
        radial-gradient(circle at 50% 100%,rgba(0,212,255,.075),transparent 34rem);
    pointer-events:none;
}

.ss-cal-v2 .ss-cal-topline::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    height:1px;
    z-index:-1;
    background:linear-gradient(90deg,transparent,rgba(0,212,255,.58),rgba(133,92,255,.42),transparent);
    pointer-events:none;
}

.ss-cal-v2 .ss-cal-title,
.ss-cal-v2 .ss-cal-actions{
    position:relative !important;
    z-index:2 !important;
}

.ss-cal-v2 .ss-cal-title h1{
    max-width:980px !important;
    margin:10px 0 6px !important;
    font-size:clamp(38px,4.5vw,68px) !important;
    line-height:.9 !important;
    letter-spacing:-.025em !important;
    text-transform:uppercase !important;
}

.ss-cal-v2 .ss-cal-title p{
    max-width:760px !important;
    margin:0 !important;
    color:#c8d4eb !important;
    font-size:16px !important;
    line-height:1.55 !important;
}

.ss-cal-v2 .ss-cal-actions{
    flex:0 0 auto !important;
}

.ss-cal-v2 .ss-cal-toolbar,
.ss-cal-v2 .ss-cal-grid-wrap,
.ss-cal-v2 .ss-cal-release-head,
.ss-cal-v2 .ss-cal-list{
    width:min(1460px,calc(100% - 44px)) !important;
    margin-left:auto !important;
    margin-right:auto !important;
}

.ss-cal-v2 .ss-cal-toolbar{
    margin-top:0 !important;
    margin-bottom:24px !important;
}

.ss-cal-v2 .ss-cal-grid-wrap{
    margin-top:0 !important;
}

.ss-cal-v2 .ss-cal-release-head{
    margin-top:38px !important;
    margin-bottom:18px !important;
}

/* Safety net for the older calendar markup if that file is still cached somewhere. */
.ss-page > .ss-container > .ss-calendar-hero{
    position:relative !important;
    width:calc(100% + 44px) !important;
    margin:0 -22px 30px !important;
    padding:32px 22px 28px !important;
    border-radius:0 !important;
    background:
        radial-gradient(circle at 14% 0%,rgba(133,92,255,.24),transparent 36rem),
        radial-gradient(circle at 82% 4%,rgba(0,212,255,.18),transparent 34rem),
        linear-gradient(180deg,rgba(10,15,26,.96),rgba(4,25,34,.68)) !important;
    border:0 !important;
    border-bottom:1px solid rgba(0,212,255,.22) !important;
    box-shadow:inset 0 -1px 0 rgba(255,255,255,.04) !important;
}

@media(max-width:900px){
    .ss-cal-v2 .ss-cal-topline{
        display:block !important;
        min-height:0 !important;
        padding:28px max(22px, calc((100% - 1460px) / 2)) 24px !important;
    }

    .ss-cal-v2 .ss-cal-actions{
        justify-content:flex-start !important;
        margin-top:16px !important;
    }
}

@media(max-width:560px){
    .ss-cal-v2 .ss-cal-topline{
        padding:24px 12px 22px !important;
        margin-bottom:18px !important;
    }

    .ss-cal-v2 .ss-cal-title h1{
        font-size:36px !important;
        line-height:.94 !important;
    }

    .ss-cal-v2 .ss-cal-title p{
        font-size:14px !important;
        line-height:1.5 !important;
    }

    .ss-cal-v2 .ss-cal-toolbar,
    .ss-cal-v2 .ss-cal-grid-wrap,
    .ss-cal-v2 .ss-cal-release-head,
    .ss-cal-v2 .ss-cal-list{
        width:min(100% - 24px,1460px) !important;
    }
}

/* ============================================================
   Desktop slot card equal-height fix
   Keeps desktop/tablet grid cards aligned when titles wrap.
   Must stay after the v10 responsive card cleanup block.
   ============================================================ */
@media (min-width: 761px){
    .ss-slot-grid,
    .ss-slot-grid-wide,
    .ss-slot-grid-featured{
        align-items:stretch !important;
        grid-auto-rows:auto !important;
    }

    .ss-slot-grid > .ss-slot-card,
    .ss-slot-grid-wide > .ss-slot-card,
    .ss-slot-grid-featured > .ss-slot-card{
        align-self:stretch !important;
        height:100% !important;
        display:flex !important;
        flex-direction:column;
    }

    .ss-slot-card .ss-slot-art{
        flex:0 0 auto;
    }

    .ss-slot-card .ss-slot-body{
        flex:1 1 auto;
        display:grid;
        grid-template-rows:auto auto 1fr;
    }

    .ss-slot-body h3,
    .ss-slot-body h3 a{
        display:-webkit-box;
        -webkit-line-clamp:2;
        -webkit-box-orient:vertical;
        overflow:hidden;
    }

    .ss-slot-body h3{
        min-height:calc(2 * 1.18em);
    }

    .ss-provider-link,
    .ss-slot-body p{
        white-space:nowrap;
        overflow:hidden;
        text-overflow:ellipsis;
    }

    .ss-slot-meta{
        align-self:end;
        margin-top:auto;
    }

    .ss-grid-ad-card{
        align-self:stretch !important;
        height:100% !important;
    }
}


/* ============================================================
   SlotStruck mobile menu + mobile-only in-grid ad fix
   Add at the very bottom of /assets/css/style.css
   ============================================================ */
:root{
    --ss-mobile-header-h:82px;
}

@media (max-width:940px){
    .ss-mobile-header{
        position:sticky !important;
        top:0 !important;
        z-index:1200 !important;
    }

    .ss-mobile-menu{
        position:fixed !important;
        left:0 !important;
        right:0 !important;
        top:var(--ss-mobile-header-h,82px) !important;
        z-index:1199 !important;
        display:none !important;
        width:100% !important;
        max-height:calc(100dvh - var(--ss-mobile-header-h,82px)) !important;
        overflow-y:auto !important;
        padding:10px 18px 16px !important;
        background:linear-gradient(180deg,rgba(5,7,13,.98),rgba(8,13,23,.98)) !important;
        border-bottom:1px solid rgba(255,255,255,.10) !important;
        box-shadow:0 22px 60px rgba(0,0,0,.48) !important;
        backdrop-filter:blur(18px) !important;
    }

    .ss-mobile-menu.is-open{
        display:grid !important;
        gap:8px !important;
    }

    .ss-mobile-toggle.is-active,
    .ss-mobile-toggle[aria-expanded="true"]{
        background:linear-gradient(135deg,rgba(133,92,255,.28),rgba(0,212,255,.18)) !important;
        border-color:rgba(158,238,255,.28) !important;
    }
}

/* Desktop/tablet: do not show the in-grid advert inside the game cards.
   Desktop already has the top banner and sidebar banner. */
@media (min-width:761px){
    .ss-home-compact .ss-slot-grid-featured > .ss-grid-ad-card,
    .ss-slot-grid > .ss-grid-ad-card,
    .ss-slot-grid-wide > .ss-grid-ad-card,
    .ss-slot-grid-featured > .ss-grid-ad-card{
        display:none !important;
    }
}

/* Keep the 12th desktop slot visible after changing homepage queries to 12 games. */
.ss-home-compact .ss-slot-grid-featured > .ss-slot-card:nth-child(n+13){
    display:flex !important;
}

/* Mobile: show the in-grid advert as a full-width 370x300 creative,
   spanning both slot columns like the screenshot. */
@media (max-width:760px){
    .ss-home-compact .ss-slot-grid-featured > .ss-grid-ad-card,
    .ss-slot-grid > .ss-grid-ad-card,
    .ss-slot-grid-wide > .ss-grid-ad-card,
    .ss-slot-grid-featured > .ss-grid-ad-card{
        grid-column:1 / -1 !important;
        width:100% !important;
        display:flex !important;
        align-items:stretch !important;
        justify-content:stretch !important;
        height:auto !important;
        min-height:0 !important;
        margin:4px 0 2px !important;
        padding:0 !important;
        border:0 !important;
        background:transparent !important;
        box-shadow:none !important;
        overflow:visible !important;
    }

    .ss-grid-ad-card .ss-ad-unit,
    .ss-grid-ad-card .ss-ad-size-370x300,
    .ss-grid-ad-card .ss-ad-placement-370x300,
    .ss-grid-ad-card .ss-ad-placement-sidebar,
    .ss-grid-ad-card .ss-ad-sidebar,
    .ss-grid-ad-card > a,
    .ss-grid-ad-card > div{
        width:100% !important;
        height:auto !important;
        min-height:0 !important;
        aspect-ratio:370 / 300 !important;
        border-radius:22px !important;
        overflow:hidden !important;
        margin:0 !important;
        box-shadow:0 14px 38px rgba(0,0,0,.30) !important;
    }

    .ss-grid-ad-card img,
    .ss-grid-ad-card .ss-ad-unit img,
    .ss-grid-ad-card .ss-ad-size-370x300 img,
    .ss-grid-ad-card .ss-ad-placement-sidebar img{
        width:100% !important;
        height:100% !important;
        display:block !important;
        object-fit:cover !important;
        border-radius:22px !important;
    }

    .ss-grid-ad-card .ss-ad-shine,
    .ss-grid-ad-card .ss-ad-label,
    .ss-grid-ad-card .ss-ad-bolt{
        display:none !important;
    }
}


/* SEO content blocks */
.ss-seo-copy,
.ss-faq-block{
    margin:28px 0;
    padding:24px;
    border-radius:22px;
    background:linear-gradient(180deg,rgba(18,27,43,.88),rgba(8,12,21,.92));
    border:1px solid rgba(170,189,220,.14);
    color:#d7e4f7;
}
.ss-seo-copy h2,
.ss-faq-block h2{
    margin:0 0 10px;
    color:#fff;
    font-size:clamp(24px,3vw,36px);
    line-height:1.05;
    letter-spacing:-.035em;
    text-transform:uppercase;
}
.ss-seo-copy p,
.ss-faq-block p{
    margin:0;
    max-width:980px;
    color:#c3cfe6;
    line-height:1.7;
}
.ss-seo-copy-spaced{margin-top:42px}
.ss-faq-block details{
    padding:14px 0;
    border-top:1px solid rgba(255,255,255,.08);
}
.ss-faq-block details:first-of-type{border-top:0}
.ss-faq-block summary{
    cursor:pointer;
    color:#fff;
    font-weight:950;
}
.ss-faq-block details p{margin-top:10px}

/* SlotStruck search suggestion layering hotfix v7
   Keep the autocomplete panel above the top banner/header on desktop and mobile. */
.ss-top-strip{
    overflow:visible !important;
    position:relative;
    z-index:80;
}
.ss-top-ad-slot{
    position:relative;
    z-index:1;
}
.ss-top-strip .ss-header-search,
.ss-header-search.ss-js-search{
    position:relative;
    z-index:1200;
}
.ss-search-popover{
    z-index:99999 !important;
}
.ss-search-popover[hidden]{
    display:none !important;
}
@media (max-width:760px){
    .ss-top-strip{overflow:visible !important;}
    .ss-top-strip .ss-header-search{z-index:1200;}
}
