/* ============================================
   PAGE-BONUSES.CSS — Bonusy page
   Reuses bonus-card-h styles from page-index.css
   ============================================ */

/* Container, section-label, count-pill — see shared.css (.rsp-*) */

/* ─── Page wrapper ─── */
.bonuses-page {
    width: 100%;
    align-self: stretch;
}

/* ─── Main section padding ─── */
.bp-main { padding-bottom: 64px; }

/* ─── Secondary sections ─── */
.bp-section {
    padding: 0 0 64px;
    width: 100%;
}

/* If no weekly bonuses, first section just needs a small breathing space
   (navbar clearance is already on .main-content in base.css) */
.bp-main + .bp-section,
.bonuses-page > .bp-section:first-child {
    padding-top: 24px;
}

.bp-main ~ .bp-section {
    padding-top: 0;
}

/* Section label spacing override */
.bp-section-label { margin-bottom: 28px; }

/* Weekly label — brighter cyan-dominant gradient */
.bp-weekly-label h2 span {
    background: linear-gradient(135deg, var(--neon-cyan), #7c3aed, var(--neon-cyan));
    background-size: 200% 100%;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ============================================
   WEEKLY TIMER
   ============================================ */
.bp-weekly-timer {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-left: auto;
    padding: 6px 16px;
    background: var(--alpha-cyan-5);
    border: 1px solid var(--alpha-cyan-25);
    border-radius: 9999px;
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--neon-cyan);
    letter-spacing: 0.06em;
}

.bp-weekly-timer svg {
    color: var(--neon-cyan);
    flex-shrink: 0;
}

.bp-weekly-hint {
    font-size: 0.88rem;
    color: var(--alpha-white-35);
    margin: -16px 0 32px;
    line-height: 1.5;
}

/* ============================================
   WEEKLY LIMITED CARDS — cyan/purple with stronger glow
   ============================================ */
.bp-weekly-grid {
    margin-bottom: 8px;
}

/* ─── Limited card — brighter animated border ─── */
.bonus-card-h.bp-limited {
    border: 1px solid transparent;
    background-clip: padding-box;
    overflow: visible;
}

.bonus-card-h.bp-limited::before {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: calc(var(--radius-xl, 16px) + 1px);
    background: linear-gradient(90deg, var(--alpha-cyan-50), rgba(124,58,237,0.5), var(--alpha-cyan-50));
    background-size: 200% 100%;
    animation: borderSlideLimited 3s linear infinite;
    z-index: -1;
}

@keyframes borderSlideLimited {
    0%   { background-position: 0% 50%; }
    100% { background-position: 200% 50%; }
}

.bonus-card-h.bp-limited::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: var(--radius-xl, 16px);
    background: linear-gradient(160deg, rgba(8, 12, 28, 0.97), rgba(5, 5, 18, 0.98));
    z-index: -1;
}

/* Pulsing cyan glow — stronger than static cards */
.bonus-card-h.bp-limited {
    animation: cardPulseLimited 3s ease-in-out infinite;
}

@keyframes cardPulseLimited {
    0%, 100% { box-shadow: 0 0 18px var(--alpha-cyan-8), 0 0 35px rgba(124,58,237,0.05); }
    50%      { box-shadow: 0 0 28px var(--alpha-cyan-20), 0 0 50px rgba(124,58,237,0.1); }
}

.bonus-card-h.bp-limited:hover {
    animation: none;
    box-shadow: 0 20px 50px var(--alpha-black-40), 0 0 30px var(--alpha-cyan-20);
}

/* ─── Cyan accent on limited card elements ─── */
.bonus-card-h.bp-limited .bonus-casino-name {
    color: var(--neon-cyan);
}

.bonus-card-h.bp-limited .cta-btn-h {
    background: linear-gradient(135deg, #00d4ff, #7c3aed);
    box-shadow: 0 0 20px var(--alpha-cyan-20);
}

.bonus-card-h.bp-limited .cta-btn-h:hover {
    background: linear-gradient(135deg, var(--neon-cyan), var(--twitch-purple));
    box-shadow: 0 0 30px var(--alpha-cyan-30);
}

.bonus-card-h.bp-limited .bonus-tag {
    background: var(--alpha-cyan-8);
    border-color: var(--alpha-cyan-20);
    color: var(--alpha-cyan-50);
}

/* Steps numbers — cyan */
.bonus-card-h.bp-limited .bonus-steps li::before {
    color: var(--neon-cyan);
}

/* ─── Limited badge — cyan pulsing ─── */
.bp-limited-badge {
    position: absolute;
    top: 14px;
    right: 14px;
    padding: 4px 10px;
    background: var(--alpha-cyan-10);
    border: 1px solid var(--alpha-cyan-30);
    border-radius: 9999px;
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: 0.58rem;
    font-weight: 800;
    color: var(--neon-cyan);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    z-index: 2;
    animation: badgePulseLimited 2s ease-in-out infinite;
}

@keyframes badgePulseLimited {
    0%, 100% { box-shadow: 0 0 6px var(--alpha-cyan-15); }
    50%      { box-shadow: 0 0 16px var(--alpha-cyan-40); }
}

/* ============================================
   FILTER ROW
   ============================================ */
.bp-filter-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 32px;
}

.bp-filter-tabs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.bp-filter-tab {
    display: inline-flex;
    align-items: center;
    padding: 9px 20px;
    background: var(--alpha-white-4);
    border: 1px solid var(--alpha-white-8);
    border-radius: 9999px;
    color: var(--alpha-white-45);
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.2s ease;
}

.bp-filter-tab:hover {
    border-color: var(--alpha-purple-35);
    color: var(--alpha-white-70);
}

.bp-filter-tab.active {
    background: var(--alpha-purple-20);
    border-color: var(--alpha-purple-40);
    color: #fff;
    box-shadow: 0 0 14px var(--alpha-purple-20);
}

.bp-result-count {
    margin-left: auto;
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--alpha-white-30);
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* ============================================
   BONUSES LIST — 3-COLUMN GRID (reuses bonus-card-h from page-index)
   ============================================ */
.bp-bonuses-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

/* ─── No results ─── */
.bp-no-results {
    text-align: center;
    padding: 64px 20px;
    color: var(--alpha-white-30);
}

.bp-no-results-icon {
    font-size: 3rem;
    margin-bottom: 16px;
    opacity: 0.4;
}

/* ============================================
   CS2 SPOLUPRÁCE — distinct CS-skins amber/orange theme
   ============================================ */
.bp-section.bp-cs2-section {
    position: relative;
    padding-top: 56px;
    padding-bottom: 80px;
    isolation: isolate;
}

.bp-cs2-label h2 span {
    background: linear-gradient(135deg, #ff9900, #ff5a00, #ffb347);
    background-size: 200% 100%;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.bp-cs2-pill {
    margin-left: 12px;
    padding: 6px 14px;
    background: rgba(255, 153, 0, 0.08);
    border: 1px solid rgba(255, 153, 0, 0.3);
    border-radius: 9999px;
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #ffb347;
    text-transform: uppercase;
}

.bp-cs2-intro {
    font-size: 0.9rem;
    color: var(--alpha-white-45);
    margin: -12px 0 28px;
    line-height: 1.5;
}

/* ─── Explainer block (3 columns on desktop) ─── */
.bp-cs2-explainer {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    padding: 28px;
    margin-bottom: 40px;
    background: linear-gradient(135deg, rgba(20, 12, 8, 0.85), rgba(12, 10, 18, 0.92));
    border: 1px solid rgba(255, 153, 0, 0.18);
    border-radius: var(--radius-xl, 16px);
    box-shadow: 0 0 30px rgba(255, 153, 0, 0.05);
}

.bp-cs2-explainer-block {
    display: flex;
    flex-direction: column;
}

.bp-cs2-explainer-icon {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    background: rgba(255, 153, 0, 0.1);
    border: 1px solid rgba(255, 153, 0, 0.25);
    border-radius: 10px;
    color: #ffb347;
}

.bp-cs2-explainer-block h3 {
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: 0.82rem;
    font-weight: 800;
    color: #ffb347;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin: 0 0 8px;
}

.bp-cs2-explainer-block p {
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--alpha-white-65);
    margin: 0;
}

.bp-cs2-disclaimer {
    grid-column: 1 / -1;
    margin: 8px 0 0;
    padding: 12px 16px;
    background: rgba(255, 153, 0, 0.05);
    border-left: 3px solid rgba(255, 153, 0, 0.5);
    border-radius: 6px;
    font-size: 0.82rem;
    line-height: 1.5;
    color: var(--alpha-white-50);
}

.bp-cs2-disclaimer strong {
    color: #ffb347;
    letter-spacing: 0.05em;
}

/* ─── Card grid — centered horizontally so CSGO.NET sits in the middle ─── */
.bp-cs2-grid {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 24px;
}

.bp-cs2-grid .bonus-card-h {
    flex: 0 1 360px;
    max-width: 380px;
}

/* ─── Amber accent overrides on CS2 cards ─── */
.bp-cs2-grid .bonus-card-h .bonus-tag {
    background: rgba(255, 153, 0, 0.08);
    border-color: rgba(255, 153, 0, 0.25);
    color: rgba(255, 179, 71, 0.85);
}

.bp-cs2-grid .bonus-card-h .cta-btn-h {
    background: linear-gradient(135deg, #ff9900, #ff5a00);
    box-shadow: 0 0 20px rgba(255, 153, 0, 0.2);
}

.bp-cs2-grid .bonus-card-h .cta-btn-h:hover {
    background: linear-gradient(135deg, #ffb347, #ff7a00);
    box-shadow: 0 0 30px rgba(255, 153, 0, 0.35);
}

.bp-cs2-grid .bonus-card-h .bonus-steps li::before {
    color: #ffb347;
}

/* CSGO.NET (featured) — amber dot instead of cyan */
.bp-cs2-grid .bonus-card-h .featured-dot {
    background: #ff9900;
    box-shadow: 0 0 16px rgba(255, 153, 0, 0.6);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1400px) {
    .bp-container { padding: 0 36px; }
}

@media (max-width: 1200px) {
    .bp-bonuses-list,
    .bp-weekly-grid { grid-template-columns: repeat(2, 1fr); }
    .bp-cs2-explainer { grid-template-columns: repeat(2, 1fr); }
    .bp-cs2-explainer .bp-cs2-explainer-block:nth-child(3) { grid-column: 1 / -1; }
    .bp-ed-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 1100px) {
    .bp-container { padding: 0 24px; }
}

@media (max-width: 768px) {
    .bp-container { padding: 0 20px; }
    .bp-cs2-explainer { grid-template-columns: 1fr; padding: 22px; }
    .bp-cs2-explainer .bp-cs2-explainer-block:nth-child(3) { grid-column: auto; }
    .bp-ed-grid { grid-template-columns: 1fr; padding: 22px; gap: 16px; }
}

@media (max-width: 640px) {
    .bp-container { padding: 0 16px; }
    .bp-bonuses-list,
    .bp-weekly-grid { grid-template-columns: 1fr; }
    .bp-filter-tab { font-size: 0.65rem; padding: 8px 14px; }
    .bp-section-label { flex-wrap: wrap; }
    .bp-weekly-timer { margin-left: 0; }
    .bp-cs2-pill { margin-left: 0; margin-top: 8px; }
    .bp-cs2-grid .bonus-card-h { flex: 1 1 100%; max-width: 100%; }
}


/* ============================================
   CS2 PROMO STRIP — proklik na /cs2 (dedikovaná stránka)
   ============================================ */
.bp-cs2-promo { padding-top: 8px; padding-bottom: 8px; }
.bp-cs2-promo-banner {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 18px 24px;
    background: linear-gradient(135deg, rgba(0, 245, 255, 0.07), rgba(168, 85, 247, 0.05));
    border: 1px solid rgba(0, 245, 255, 0.3);
    border-radius: 14px;
    text-decoration: none;
    transition: border-color .2s, transform .2s, box-shadow .2s;
}
.bp-cs2-promo-banner:hover {
    border-color: rgba(168, 85, 247, 0.55);
    transform: translateY(-2px);
    box-shadow: 0 8px 36px rgba(0, 245, 255, 0.18);
}
.bp-cs2-promo-icon {
    font-size: 2rem;
    width: 56px; height: 56px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(0, 245, 255, 0.1);
    border: 1px solid rgba(0, 245, 255, 0.3);
    border-radius: 12px;
    flex-shrink: 0;
}
.bp-cs2-promo-body { flex: 1; min-width: 0; }
.bp-cs2-promo-body strong {
    display: block;
    font-family: 'Exo 2', sans-serif;
    font-size: 1.05rem;
    font-weight: 800;
    color: #5cf2ff;
    margin-bottom: 4px;
}
.bp-cs2-promo-body span {
    display: block;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.62);
    line-height: 1.5;
}
.bp-cs2-promo-arrow {
    font-size: 1.5rem;
    color: #5cf2ff;
    flex-shrink: 0;
    transition: transform .2s, color .2s;
}
.bp-cs2-promo-banner:hover .bp-cs2-promo-arrow { transform: translateX(4px); color: #d4a8ff; }
@media (max-width: 640px) {
    .bp-cs2-promo-banner { padding: 14px 18px; gap: 12px; }
    .bp-cs2-promo-icon { width: 44px; height: 44px; font-size: 1.5rem; }
    .bp-cs2-promo-body strong { font-size: .95rem; }
    .bp-cs2-promo-body span { font-size: .78rem; }
}


/* ─── Comparison table (editorial section) ─── */
.bp-comparison-table-wrap {
    overflow-x: auto;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, .1);
    margin: 20px 0;
}

.bp-comparison-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
    min-width: 480px;
}

.bp-comparison-table th {
    background: rgba(0, 212, 255, .1);
    color: var(--neon-cyan);
    font-weight: 700;
    padding: .75rem 1rem;
    text-align: left;
    white-space: nowrap;
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .05em;
}

.bp-comparison-table td {
    padding: .65rem 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, .06);
    vertical-align: middle;
    color: var(--text-secondary);
}

.bp-comparison-table tr:last-child td { border-bottom: none; }

.bp-comparison-table .bct-highlight td {
    background: rgba(0, 212, 255, .04);
    color: var(--text-primary);
}

.bp-comparison-table tr:hover td { background: rgba(255, 255, 255, .03); }

.bp-table-note {
    font-size: .8rem;
    color: rgba(255, 255, 255, .4);
    margin: 8px 0 0;
}

.bp-table-note a {
    color: rgba(0, 245, 255, .7);
    text-decoration: none;
    border-bottom: 1px dashed rgba(0, 245, 255, .35);
}

.bp-table-note a:hover {
    color: var(--neon-cyan);
    border-bottom-color: var(--neon-cyan);
}

.bp-rating {
    display: inline-block;
    font-weight: 700;
    font-size: .82rem;
    padding: 2px 8px;
    border-radius: 6px;
    background: rgba(0, 245, 255, .08);
    color: var(--neon-cyan, #00d4ff);
    border: 1px solid rgba(0, 245, 255, .22);
    white-space: nowrap;
}

/* ─── Criteria list ─── */
.bp-criteria-list {
    list-style: none;
    padding: 0;
    margin: 14px 0 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.bp-criteria-list li {
    padding: 12px 16px;
    background: rgba(255, 255, 255, .03);
    border: 1px solid rgba(255, 255, 255, .07);
    border-radius: 10px;
    font-size: .9rem;
    color: var(--text-secondary);
    line-height: 1.6;
    padding-left: 16px;
    border-left: 3px solid rgba(0, 245, 255, .3);
}

.bp-criteria-list li strong { color: var(--text-primary); }

/* ─── NCB CTA block ─── */
.bp-ncb-cta {
    background: rgba(0, 245, 255, .04);
    border: 1px solid rgba(0, 245, 255, .15);
    border-radius: 12px;
    padding: 24px;
    margin: 32px 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.bp-ncb-cta p {
    margin: 0;
    font-size: .95rem;
    color: var(--text-secondary);
}

/* ============================================
   EDITORIAL / SEO SECTION — mirrors bp-cs2 pattern with cyan accent
   ============================================ */
.bp-ed-section {
    padding-top: 56px;
    padding-bottom: 80px;
    border-top: 1px solid rgba(255,255,255,.07);
}

/* 4-column icon+text grid — mirrors bp-cs2-explainer */
.bp-ed-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    padding: 28px;
    margin-bottom: 32px;
    background: linear-gradient(135deg, rgba(8,12,28,.95), rgba(5,5,18,.98));
    border: 1px solid rgba(0,212,255,.18);
    border-radius: var(--radius-xl, 16px);
    box-shadow: 0 0 30px rgba(0,212,255,.04);
}

.bp-ed-block {
    display: flex;
    flex-direction: column;
}

.bp-ed-icon {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    background: rgba(0,212,255,.1);
    border: 1px solid rgba(0,212,255,.25);
    border-radius: 10px;
    color: var(--neon-cyan);
    flex-shrink: 0;
}

.bp-ed-block h3 {
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: .82rem;
    font-weight: 800;
    color: var(--neon-cyan);
    letter-spacing: .08em;
    text-transform: uppercase;
    margin: 0 0 8px;
}

.bp-ed-block p {
    font-size: .88rem;
    line-height: 1.65;
    color: var(--alpha-white-65);
    margin: 0;
}

/* Sub-section headings between grids and table */
.bp-ed-heading {
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: .75rem;
    font-weight: 800;
    color: var(--alpha-white-35);
    text-transform: uppercase;
    letter-spacing: .12em;
    margin: 36px 0 14px;
}

/* Legal note — matches bp-cs2-disclaimer style */
.bp-ed-legal {
    margin: 4px 0 28px;
    padding: 14px 18px;
    background: rgba(0,212,255,.04);
    border-left: 3px solid rgba(0,212,255,.35);
    border-radius: 0 8px 8px 0;
    font-size: .86rem;
    line-height: 1.65;
    color: var(--alpha-white-50);
}

.bp-ed-legal strong { color: var(--text-primary); }

/* Exclusive tag in comparison table */
.bp-excl-tag {
    display: inline-block;
    background: rgba(0,212,255,.1);
    color: var(--neon-cyan);
    border: 1px solid rgba(0,212,255,.28);
    border-radius: 999px;
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .06em;
    padding: .1rem .45rem;
    margin-left: .3rem;
    vertical-align: middle;
    text-transform: uppercase;
}

/* CTA — centered */
.bp-ncb-cta {
    text-align: center;
    align-items: center;
}

/* FAQ */
.bp-editorial-faq { margin-top: 36px; }

.bp-editorial-faq > h3 {
    font-family: var(--font-accent, 'Exo 2', sans-serif);
    font-size: .75rem;
    font-weight: 800;
    color: var(--alpha-white-35);
    text-transform: uppercase;
    letter-spacing: .12em;
    margin: 0 0 16px;
}

.bp-editorial-faq details {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 10px;
    margin-bottom: 8px;
    overflow: hidden;
}

.bp-editorial-faq details[open] { border-color: rgba(0,212,255,.25); }

.bp-editorial-faq summary {
    padding: 14px 18px;
    cursor: pointer;
    font-weight: 600;
    font-size: .9rem;
    color: var(--text-primary);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    user-select: none;
}

.bp-editorial-faq summary::-webkit-details-marker,
.bp-editorial-faq summary::marker { display: none; }

.bp-editorial-faq summary::after {
    content: '+';
    color: var(--neon-cyan);
    font-size: 1.1rem;
    flex-shrink: 0;
}

.bp-editorial-faq details[open] summary::after { content: '−'; }

.bp-editorial-faq details p {
    padding: 0 18px 14px;
    margin: 0;
    font-size: .88rem;
    line-height: 1.75;
    color: var(--alpha-white-65);
}

.bp-editorial-faq details p a {
    color: var(--neon-cyan);
    text-decoration: underline;
    text-underline-offset: 3px;
}

