/* ========================================
   GIF ARCHIV — CASINO SUBFOLDER STYLES
   Extends: gfb-base.css (load both)
   ======================================== */

/* ========================================
   CASINO HERO
   ======================================== */
.gfb-casino-hero {
    background: linear-gradient(145deg, #1a0800 0%, var(--gfb-gray-900) 50%, var(--gfb-card) 100%);
    border: 1px solid var(--gfb-gray-800);
    border-radius: var(--gfb-radius-2xl);
    padding: var(--gfb-space-12);
    margin-bottom: var(--gfb-space-8);
    position: relative;
    overflow: hidden;
}

.gfb-casino-hero::before {
    content: '';
    position: absolute;
    top: -80px; right: -80px;
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 65%);
    pointer-events: none;
}

.gfb-casino-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px var(--gfb-space-4);
    background: rgba(255,107,53,0.1);
    border: 1px solid rgba(255,107,53,0.3);
    border-radius: var(--gfb-radius-full);
    font-size: var(--gfb-text-sm);
    color: var(--gfb-primary);
    font-weight: 600;
    margin-bottom: var(--gfb-space-5);
}

.gfb-casino-hero-title {
    font-family: var(--gfb-font-heading);
    font-size: var(--gfb-text-5xl);
    font-weight: 800;
    line-height: 1.1;
    margin-bottom: var(--gfb-space-4);
}

.gfb-casino-hero-desc {
    color: var(--gfb-gray-300);
    font-size: var(--gfb-text-lg);
    line-height: 1.7;
    max-width: 720px;
    margin-bottom: var(--gfb-space-6);
}

.gfb-casino-trust-row {
    display: flex;
    align-items: center;
    gap: var(--gfb-space-6);
    flex-wrap: wrap;
    margin-bottom: var(--gfb-space-2);
}

.gfb-casino-trust-item {
    display: flex;
    align-items: center;
    gap: var(--gfb-space-2);
    font-size: var(--gfb-text-sm);
    color: var(--gfb-gray-400);
}

.gfb-casino-trust-item strong {
    color: var(--gfb-success);
}

/* ========================================
   RESPONSIBLE GAMBLING NOTICE
   ======================================== */
.gfb-rg-notice {
    background: rgba(239,68,68,0.05);
    border: 1px solid rgba(239,68,68,0.18);
    border-radius: var(--gfb-radius-md);
    padding: var(--gfb-space-4) var(--gfb-space-5);
    margin: var(--gfb-space-6) 0;
    font-size: var(--gfb-text-sm);
    line-height: 1.6;
    color: var(--gfb-gray-400);
}

.gfb-rg-notice strong { color: var(--gfb-error); }
.gfb-rg-notice a { color: var(--gfb-accent); text-decoration: underline; }

/* ========================================
   QUICK COMPARISON TABLE
   ======================================== */
.gfb-casino-table-wrap {
    overflow-x: auto;
    margin-bottom: var(--gfb-space-8);
    border-radius: var(--gfb-radius-xl);
    border: 1px solid var(--gfb-gray-800);
}

.gfb-casino-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--gfb-text-sm);
}

.gfb-casino-table th {
    background: var(--gfb-gray-900);
    color: var(--gfb-gray-400);
    font-weight: 600;
    text-align: left;
    padding: var(--gfb-space-3) var(--gfb-space-5);
    white-space: nowrap;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.gfb-casino-table td {
    padding: var(--gfb-space-3) var(--gfb-space-5);
    border-bottom: 1px solid var(--gfb-gray-800);
    vertical-align: middle;
}

.gfb-casino-table tr:last-child td { border-bottom: none; }
.gfb-casino-table tr:hover td { background: rgba(255,107,53,0.03); }

.gfb-casino-table-logo {
    height: 26px;
    width: auto;
    object-fit: contain;
    display: block;
}

.gfb-casino-table-name {
    font-weight: 700;
    color: var(--gfb-white);
    font-size: var(--gfb-text-sm);
}

/* ========================================
   OPERATOR CARDS — FLEX LAYOUT
   ======================================== */
.gfb-casino-cards {
    display: flex;
    flex-direction: column;
    gap: var(--gfb-space-4);
    margin-bottom: var(--gfb-space-10);
}

.gfb-casino-card {
    background: var(--gfb-card);
    border: 1px solid var(--gfb-gray-800);
    border-radius: var(--gfb-radius-xl);
    padding: var(--gfb-space-5) var(--gfb-space-6);
    display: flex;
    align-items: center;
    gap: var(--gfb-space-5);
    transition: border-color var(--gfb-transition-base), box-shadow var(--gfb-transition-base);
}

.gfb-casino-card:hover {
    border-color: rgba(255,107,53,0.35);
}

.gfb-casino-card--top {
    border-color: rgba(255,107,53,0.25);
    box-shadow: 0 0 0 1px rgba(255,107,53,0.1), inset 0 0 60px rgba(255,107,53,0.02);
}

/* Rank badge */
.gfb-casino-card-rank {
    font-family: var(--gfb-font-heading);
    font-size: var(--gfb-text-xl);
    font-weight: 800;
    color: var(--gfb-gray-700);
    min-width: 36px;
    text-align: center;
    flex-shrink: 0;
}

.gfb-casino-card--top .gfb-casino-card-rank {
    color: var(--gfb-primary);
}

/* Logo section */
.gfb-casino-card-logo-wrap {
    flex-shrink: 0;
    width: 130px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gfb-casino-card-logo {
    max-height: 40px;
    max-width: 120px;
    width: auto;
    object-fit: contain;
    display: block;
}

.gfb-casino-card-logo-text {
    font-family: var(--gfb-font-heading);
    font-size: var(--gfb-text-xl);
    font-weight: 800;
    color: var(--gfb-white);
    letter-spacing: -0.02em;
}

/* Meta: name, stars, GGL badge */
.gfb-casino-card-meta {
    flex-shrink: 0;
    width: 170px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.gfb-casino-card-name {
    font-family: var(--gfb-font-heading);
    font-size: var(--gfb-text-base);
    font-weight: 700;
    color: var(--gfb-white);
    margin: 0;
    line-height: 1.2;
}

.gfb-casino-stars {
    display: flex;
    align-items: center;
    gap: 3px;
    color: #F59E0B;
    font-size: var(--gfb-text-sm);
}

.gfb-casino-stars-score {
    color: var(--gfb-gray-400);
    font-size: 12px;
    margin-left: 2px;
}

.gfb-casino-ggl-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    background: rgba(16,185,129,0.1);
    border: 1px solid rgba(16,185,129,0.2);
    border-radius: var(--gfb-radius-sm);
    font-size: 11px;
    font-weight: 600;
    color: var(--gfb-success);
    width: fit-content;
}

/* Bonus block */
.gfb-casino-card-bonus-wrap {
    flex: 1;
    background: rgba(255,107,53,0.06);
    border: 1px solid rgba(255,107,53,0.12);
    border-radius: var(--gfb-radius-md);
    padding: var(--gfb-space-3) var(--gfb-space-4);
    min-width: 0;
}

.gfb-casino-bonus-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--gfb-primary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    display: block;
    margin-bottom: 3px;
}

.gfb-casino-bonus-text {
    font-weight: 700;
    color: var(--gfb-white);
    font-size: var(--gfb-text-base);
    display: block;
    line-height: 1.3;
}

.gfb-casino-bonus-small {
    font-size: 11px;
    color: var(--gfb-gray-600);
    display: block;
    margin-top: 3px;
}

/* Features */
.gfb-casino-card-features {
    list-style: none;
    margin: 0;
    padding: 0;
    flex-shrink: 0;
    width: 190px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.gfb-casino-card-features li {
    font-size: 13px;
    color: var(--gfb-gray-300);
    display: flex;
    align-items: flex-start;
    gap: 6px;
    line-height: 1.4;
}

.gfb-casino-card-features li::before {
    content: '✓';
    color: var(--gfb-success);
    font-weight: 700;
    flex-shrink: 0;
    margin-top: 1px;
}

/* CTA section */
.gfb-casino-card-actions {
    flex-shrink: 0;
    width: 148px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--gfb-space-2);
}

.gfb-casino-card-cta {
    display: block;
    text-align: center;
    white-space: nowrap;
}

.gfb-casino-card-review-link {
    display: block;
    text-align: center;
    font-size: 12px;
    color: var(--gfb-gray-500);
    text-decoration: none;
    padding: 4px;
    border-radius: var(--gfb-radius-sm);
    transition: color var(--gfb-transition-fast);
}

.gfb-casino-card-review-link:hover { color: var(--gfb-accent); }

.gfb-casino-card-mini-rg {
    font-size: 10px;
    color: var(--gfb-gray-700);
    text-align: center;
    margin: 0;
    line-height: 1.4;
}

/* ========================================
   CATEGORY NAVIGATION
   ======================================== */
.gfb-casino-cat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--gfb-space-4);
    margin-bottom: var(--gfb-space-10);
}

.gfb-casino-cat-card {
    background: var(--gfb-card);
    border: 1px solid var(--gfb-gray-800);
    border-radius: var(--gfb-radius-xl);
    padding: var(--gfb-space-6);
    text-decoration: none;
    color: var(--gfb-white);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--gfb-space-3);
    text-align: center;
    transition: all var(--gfb-transition-base);
}

.gfb-casino-cat-card:hover {
    border-color: var(--gfb-primary);
    transform: translateY(-3px);
    box-shadow: var(--gfb-shadow-lg);
}

.gfb-casino-cat-icon {
    font-size: 2.5rem;
    line-height: 1;
}

.gfb-casino-cat-name {
    font-family: var(--gfb-font-heading);
    font-weight: 700;
    font-size: var(--gfb-text-base);
}

.gfb-casino-cat-desc {
    font-size: var(--gfb-text-sm);
    color: var(--gfb-gray-400);
    line-height: 1.5;
}

/* ========================================
   REVIEW PAGE LAYOUT
   ======================================== */
.gfb-casino-review-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: var(--gfb-space-8);
    align-items: start;
}

.gfb-casino-review-sidebar {
    position: sticky;
    top: 80px;
}

.gfb-casino-op-box {
    background: var(--gfb-card);
    border: 1px solid rgba(255,107,53,0.25);
    border-radius: var(--gfb-radius-xl);
    padding: var(--gfb-space-6);
    display: flex;
    flex-direction: column;
    gap: var(--gfb-space-4);
    align-items: center;
    text-align: center;
}

.gfb-casino-op-box-logo {
    max-height: 52px;
    width: auto;
    max-width: 180px;
    object-fit: contain;
}

.gfb-casino-op-box-score {
    font-family: var(--gfb-font-heading);
    font-size: var(--gfb-text-4xl);
    font-weight: 800;
    color: var(--gfb-primary);
    line-height: 1;
}

.gfb-casino-op-box-stars {
    color: #F59E0B;
    font-size: var(--gfb-text-xl);
    letter-spacing: 2px;
}

.gfb-casino-op-box-bonus {
    background: rgba(255,107,53,0.07);
    border-radius: var(--gfb-radius-md);
    padding: var(--gfb-space-3) var(--gfb-space-4);
    width: 100%;
}

.gfb-casino-op-box-table {
    width: 100%;
    font-size: var(--gfb-text-sm);
    border-collapse: collapse;
}

.gfb-casino-op-box-table td {
    padding: 5px 0;
    border-bottom: 1px solid var(--gfb-gray-800);
}

.gfb-casino-op-box-table tr:last-child td { border-bottom: none; }
.gfb-casino-op-box-table td:first-child { color: var(--gfb-gray-500); }
.gfb-casino-op-box-table td:last-child { text-align: right; font-weight: 600; }

/* ========================================
   PROS / CONS
   ======================================== */
.gfb-casino-pros-cons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gfb-space-4);
    margin: var(--gfb-space-6) 0;
}

.gfb-casino-pros { border-left: 3px solid var(--gfb-success); background: var(--gfb-card); border-radius: var(--gfb-radius-md); padding: var(--gfb-space-5); }
.gfb-casino-cons { border-left: 3px solid var(--gfb-error); background: var(--gfb-card); border-radius: var(--gfb-radius-md); padding: var(--gfb-space-5); }

.gfb-casino-pros-title { font-weight: 700; font-size: var(--gfb-text-sm); text-transform: uppercase; letter-spacing: 0.05em; color: var(--gfb-success); margin-bottom: var(--gfb-space-3); }
.gfb-casino-cons-title { font-weight: 700; font-size: var(--gfb-text-sm); text-transform: uppercase; letter-spacing: 0.05em; color: var(--gfb-error); margin-bottom: var(--gfb-space-3); }

.gfb-casino-pros ul, .gfb-casino-cons ul {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: var(--gfb-space-2);
}

.gfb-casino-pros li, .gfb-casino-cons li {
    font-size: var(--gfb-text-sm); color: var(--gfb-gray-300);
    display: flex; gap: var(--gfb-space-2); line-height: 1.5;
}

.gfb-casino-pros li::before { content: '+'; color: var(--gfb-success); font-weight: 700; flex-shrink: 0; }
.gfb-casino-cons li::before { content: '−'; color: var(--gfb-error); font-weight: 700; flex-shrink: 0; }

/* ========================================
   COMPLIANCE SECTION
   ======================================== */
.gfb-casino-compliance {
    background: var(--gfb-card);
    border: 1px solid var(--gfb-gray-800);
    border-radius: var(--gfb-radius-xl);
    padding: var(--gfb-space-8);
    margin-top: var(--gfb-space-10);
}

.gfb-casino-compliance-title {
    font-family: var(--gfb-font-heading);
    font-size: var(--gfb-text-xl);
    font-weight: 700;
    margin-bottom: var(--gfb-space-4);
    color: var(--gfb-gray-300);
}

.gfb-casino-compliance p {
    font-size: var(--gfb-text-sm);
    color: var(--gfb-gray-500);
    line-height: 1.7;
    margin-bottom: var(--gfb-space-3);
}

.gfb-casino-compliance p:last-child { margin-bottom: 0; }
.gfb-casino-compliance a { color: var(--gfb-accent); text-decoration: underline; }

/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 1100px) {
    .gfb-casino-card {
        flex-wrap: wrap;
    }

    .gfb-casino-card-features {
        width: auto;
        flex: 1;
        min-width: 150px;
    }

    .gfb-casino-card-actions {
        width: 140px;
    }
}

@media (max-width: 900px) {
    .gfb-casino-card {
        display: grid;
        grid-template-columns: 36px 100px 1fr;
        grid-template-rows: auto auto auto;
        gap: var(--gfb-space-3);
    }

    .gfb-casino-card-meta { width: auto; }

    .gfb-casino-card-bonus-wrap {
        grid-column: 2 / 4;
    }

    .gfb-casino-card-features {
        grid-column: 2 / 4;
        width: auto;
        flex-direction: row;
        flex-wrap: wrap;
        gap: var(--gfb-space-2);
    }

    .gfb-casino-card-features li { width: auto; }

    .gfb-casino-card-actions {
        grid-column: 1 / 4;
        flex-direction: row;
        align-items: center;
        width: auto;
    }

    .gfb-casino-cat-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .gfb-casino-hero { padding: var(--gfb-space-8); }
    .gfb-casino-hero-title { font-size: var(--gfb-text-3xl); }

    .gfb-casino-card {
        grid-template-columns: 1fr;
        gap: var(--gfb-space-3);
    }

    .gfb-casino-card-rank { display: none; }

    .gfb-casino-card-logo-wrap { width: auto; justify-content: flex-start; }

    .gfb-casino-card-bonus-wrap,
    .gfb-casino-card-features,
    .gfb-casino-card-actions {
        grid-column: 1;
        width: auto;
    }

    .gfb-casino-review-layout {
        grid-template-columns: 1fr;
    }

    .gfb-casino-review-sidebar {
        position: static;
        order: -1;
    }

    .gfb-casino-pros-cons { grid-template-columns: 1fr; }
    .gfb-casino-cat-grid { grid-template-columns: repeat(2, 1fr); }

    /* Vergleichstabelle auf Mobile ausblenden — Casino-Cards darunter zeigen dieselben Infos */
    .gfb-casino-table-wrap { display: none; }

    /* Actions: zurück auf column, CTA full-width */
    .gfb-casino-card-actions {
        flex-direction: column;
        align-items: stretch;
    }
    .gfb-casino-card-cta { width: 100%; box-sizing: border-box; }
}

/* FAQ */
.gfb-faq { display:flex; flex-direction:column; gap:var(--gfb-space-3); }
.gfb-faq-item { background:var(--gfb-gray-900); border:1px solid var(--gfb-gray-700); border-radius:var(--gfb-radius-md); padding:var(--gfb-space-5) var(--gfb-space-6); }
.gfb-faq-question { font-family:var(--gfb-font-heading); font-size:var(--gfb-text-base); font-weight:700; color:var(--gfb-gray-100); margin-bottom:var(--gfb-space-3); line-height:1.4; }
.gfb-faq-answer p { color:var(--gfb-gray-400); line-height:1.7; font-size:var(--gfb-text-sm); margin:0; }
