/* =============================================================================
   NO DEPOSIT BONUS CODES — MAIN STYLESHEET v1.0.0
   Colors: Primary #16213E | Secondary #0F3460 | Accent #E94560 | Gold #F5A623
   BG #F7FAFC | Text #2D3748 | Cards #FFFFFF | Border #E2E8F0
   ============================================================================= */

/* 1. CSS CUSTOM PROPERTIES */
:root {
    --color-primary:   #16213E;
    --color-secondary: #0F3460;
    --color-accent:    #E94560;
    --color-gold:      #F5A623;
    --color-bg:        #F7FAFC;
    --color-text:      #2D3748;
    --color-text-muted:#718096;
    --color-card:      #FFFFFF;
    --color-border:    #E2E8F0;
    --color-success:   #38A169;
    --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
    --font-heading: 'Montserrat', 'Inter', system-ui, sans-serif;
    --shadow-sm: 0 1px 3px rgba(0,0,0,.08);
    --shadow-md: 0 4px 12px rgba(0,0,0,.1);
    --shadow-lg: 0 8px 30px rgba(0,0,0,.15);
    --shadow-accent: 0 4px 15px rgba(233,69,96,.35);
    --radius-sm: 4px; --radius-md: 8px; --radius-lg: 12px; --radius-xl: 16px; --radius-full: 9999px;
    --container-max: 1200px;
    --container-pad: clamp(16px, 4vw, 32px);
    --header-height: 70px;
    --nav-height: 52px;
    --transition: .2s ease;
    --transition-slow: .35s ease;
}

/* 2. RESET & BASE */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body { font-family: var(--font-sans); font-size: 1rem; line-height: 1.7; color: var(--color-text); background-color: var(--color-bg); -webkit-font-smoothing: antialiased; }
img, video, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--color-secondary); text-decoration: underline; text-underline-offset: 2px; transition: color var(--transition); }
a:hover, a:focus { color: var(--color-accent); }
ul, ol { list-style: none; }
h1,h2,h3,h4,h5,h6 { font-family: var(--font-heading); font-weight: 700; line-height: 1.25; color: var(--color-primary); }
h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); }
h2 { font-size: clamp(1.4rem, 3vw, 2rem); }
h3 { font-size: clamp(1.15rem, 2.5vw, 1.5rem); }
h4 { font-size: 1.2rem; } h5 { font-size: 1.05rem; } h6 { font-size: 1rem; }
p { margin-bottom: 1.25rem; } p:last-child { margin-bottom: 0; }
strong, b { font-weight: 700; }

/* 3. UTILITIES */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.container { max-width: var(--container-max); margin-inline: auto; padding-inline: var(--container-pad); }
.skip-to-content { position: absolute; top: -100%; left: 16px; z-index: 9999; padding: 10px 20px; background: var(--color-accent); color: #fff; border-radius: 0 0 var(--radius-md) var(--radius-md); text-decoration: none; font-weight: 700; transition: top var(--transition); }
.skip-to-content:focus { top: 0; }

/* 4. HEADER */
.site-header { position: sticky; top: 0; z-index: 900; background: var(--color-primary); box-shadow: var(--shadow-md); }
.header-inner { display: flex; align-items: center; justify-content: space-between; height: var(--header-height); gap: 16px; }
.site-branding { flex-shrink: 0; }
.site-logo-link { text-decoration: none; display: inline-flex; align-items: center; }
.site-logo-link img { max-height: 50px; width: auto; }
.site-logo-text { display: flex; flex-direction: column; line-height: 1.1; }
.site-logo-text__main { font-family: var(--font-heading); font-size: clamp(1rem, 2.5vw, 1.4rem); font-weight: 800; color: #fff; letter-spacing: -.02em; }
.site-logo-text__accent { font-family: var(--font-heading); font-size: clamp(.75rem, 2vw, 1rem); font-weight: 700; color: var(--color-gold); }
.header-right { display: flex; align-items: center; gap: 12px; }
.header-cta-btn { display: inline-flex; align-items: center; padding: 9px 20px; background: var(--color-accent); color: #fff !important; border-radius: var(--radius-full); text-decoration: none; font-size: .875rem; font-weight: 700; transition: background var(--transition), transform var(--transition), box-shadow var(--transition); box-shadow: var(--shadow-accent); white-space: nowrap; }
.header-cta-btn:hover { background: #d63251; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(233,69,96,.5); }
.search-toggle { background: none; border: none; cursor: pointer; color: rgba(255,255,255,.7); padding: 6px; border-radius: var(--radius-sm); transition: color var(--transition), background var(--transition); display: flex; align-items: center; }
.search-toggle:hover { color: #fff; background: rgba(255,255,255,.1); }
.search-form-drawer { background: var(--color-secondary); padding: 0; border-top: 1px solid rgba(255,255,255,.1); max-height: 0; overflow: hidden; transition: max-height var(--transition-slow), padding var(--transition-slow); }
.search-form-drawer.is-open { max-height: 80px; padding: 12px 0; }
.search-form { display: flex; gap: 8px; align-items: center; }
.search-field { flex: 1; padding: 10px 16px; border: 1px solid rgba(255,255,255,.2); border-radius: var(--radius-full); background: rgba(255,255,255,.1); color: #fff; font-size: .9rem; outline: none; }
.search-field::placeholder { color: rgba(255,255,255,.5); }
.search-field:focus { border-color: var(--color-gold); }
.search-submit { background: var(--color-gold); border: none; border-radius: var(--radius-full); padding: 10px 18px; cursor: pointer; color: var(--color-primary); display: flex; align-items: center; gap: 4px; font-weight: 700; font-size: .875rem; }
.search-submit:hover { background: #e0950f; }
.search-close { background: none; border: none; color: rgba(255,255,255,.7); font-size: 1.5rem; cursor: pointer; padding: 4px 8px; line-height: 1; }

/* 5. NAVIGATION */
.site-nav { background: var(--color-secondary); border-top: 1px solid rgba(255,255,255,.08); }
.nav-menu { display: flex; align-items: stretch; }
.nav-menu > li { position: relative; }
.nav-menu > li > a { display: flex; align-items: center; gap: 4px; padding: 0 18px; height: var(--nav-height); color: rgba(255,255,255,.85); text-decoration: none; font-size: .9rem; font-weight: 600; transition: color var(--transition), background var(--transition); white-space: nowrap; }
.nav-menu > li > a:hover, .nav-menu > li:hover > a, .nav-menu > li.current-menu-item > a, .nav-menu > li.current-menu-parent > a { color: #fff; background: rgba(255,255,255,.1); }
.nav-arrow { font-size: .6rem; transition: transform var(--transition); }
.nav-menu > li:hover .nav-arrow { transform: rotate(180deg); }
.sub-menu { position: absolute; top: 100%; left: 0; min-width: 240px; background: var(--color-primary); border: 1px solid rgba(255,255,255,.1); border-top: 3px solid var(--color-accent); border-radius: 0 0 var(--radius-md) var(--radius-md); box-shadow: var(--shadow-lg); opacity: 0; visibility: hidden; transform: translateY(-8px); transition: opacity var(--transition), visibility var(--transition), transform var(--transition); z-index: 200; }
.nav-menu > li:hover > .sub-menu, .nav-menu > li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.sub-menu li a { display: block; padding: 10px 18px; color: rgba(255,255,255,.8); text-decoration: none; font-size: .875rem; transition: color var(--transition), background var(--transition), padding-left var(--transition); border-bottom: 1px solid rgba(255,255,255,.05); }
.sub-menu li:last-child a { border-bottom: none; }
.sub-menu li a:hover { color: var(--color-gold); background: rgba(255,255,255,.05); padding-left: 24px; }
.hamburger { display: none; flex-direction: column; justify-content: center; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px; border-radius: var(--radius-sm); }
.hamburger__line { display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: transform var(--transition), opacity var(--transition); }
.hamburger[aria-expanded="true"] .hamburger__line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger[aria-expanded="true"] .hamburger__line:nth-child(2) { opacity: 0; }
.hamburger[aria-expanded="true"] .hamburger__line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* 6. MOBILE MENU */
.mobile-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 950; opacity: 0; visibility: hidden; transition: opacity var(--transition-slow), visibility var(--transition-slow); }
.mobile-overlay.is-active { opacity: 1; visibility: visible; }
.mobile-menu { position: fixed; top: 0; right: -320px; width: min(320px, 100vw); height: 100vh; background: var(--color-primary); z-index: 1000; transition: right var(--transition-slow); display: flex; flex-direction: column; overflow-y: auto; }
.mobile-menu.is-open { right: 0; }
.mobile-menu__header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,.1); flex-shrink: 0; }
.mobile-menu__brand { display: flex; flex-direction: column; line-height: 1.2; }
.mobile-menu__brand-main { font-family: var(--font-heading); font-weight: 800; font-size: 1.1rem; color: #fff; }
.mobile-menu__brand-accent { font-family: var(--font-heading); font-size: .85rem; font-weight: 700; color: var(--color-gold); }
.mobile-menu__close { background: none; border: none; color: rgba(255,255,255,.7); cursor: pointer; padding: 4px; display: flex; align-items: center; border-radius: var(--radius-sm); }
.mobile-menu__close:hover { color: #fff; background: rgba(255,255,255,.1); }
.mobile-menu__body { flex: 1; padding: 8px 0; }
.mobile-nav-menu > li > a { display: block; padding: 13px 20px; color: rgba(255,255,255,.85); text-decoration: none; font-size: .95rem; font-weight: 600; border-bottom: 1px solid rgba(255,255,255,.05); transition: color var(--transition), background var(--transition); }
.mobile-nav-menu > li > a:hover { color: var(--color-gold); background: rgba(255,255,255,.05); }
.mobile-sub-menu, .mobile-nav-menu .sub-menu { background: rgba(0,0,0,.2); }
.mobile-sub-menu li a, .mobile-nav-menu .sub-menu li a { display: block; padding: 10px 20px 10px 36px; color: rgba(255,255,255,.65); text-decoration: none; font-size: .875rem; border-bottom: 1px solid rgba(255,255,255,.04); transition: color var(--transition); }
.mobile-sub-menu li a:hover, .mobile-nav-menu .sub-menu li a:hover { color: var(--color-gold); }
/* CRITICAL: Reset desktop sub-menu positioning inside mobile drawer so JS display:block/none works */
.mobile-nav-menu .sub-menu {
    display: none;
    position: static !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    box-shadow: none !important;
    border: none !important;
    border-radius: 0 !important;
    min-width: 0 !important;
    z-index: auto !important;
}
.mobile-menu__footer { padding: 20px; border-top: 1px solid rgba(255,255,255,.1); flex-shrink: 0; }
.mobile-menu__cta { display: block; padding: 14px; background: var(--color-accent); color: #fff !important; text-align: center; text-decoration: none; font-weight: 700; font-size: .95rem; border-radius: var(--radius-full); box-shadow: var(--shadow-accent); margin-bottom: 12px; }
.mobile-menu__disclaimer { font-size: .75rem; color: rgba(255,255,255,.4); text-align: center; }

/* 7. MAIN */
.site-main { min-height: 60vh; padding-block: 32px 48px; }

/* 8. BREADCRUMBS */
.breadcrumbs { margin-bottom: 24px; padding: 10px 0; border-bottom: 1px solid var(--color-border); }
.breadcrumb-list { display: flex; flex-wrap: wrap; align-items: center; gap: 4px; font-size: .8rem; color: var(--color-text-muted); }
.breadcrumb-item a { color: var(--color-secondary); text-decoration: none; transition: color var(--transition); }
.breadcrumb-item a:hover { color: var(--color-accent); text-decoration: underline; }
.breadcrumb-sep { color: var(--color-border); font-size: .7rem; padding-inline: 2px; }
.breadcrumb-item [aria-current="page"] { color: var(--color-text-muted); font-weight: 500; }

/* 9. HOMEPAGE CASINO TABLE (simple responsive table) */
.casino-table { width: 100%; border-collapse: collapse; margin-block: 24px; background: var(--color-card); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); }
.casino-table th { background: var(--color-primary); color: rgba(255,255,255,.9); padding: 12px 16px; text-align: left; font-size: .8rem; text-transform: uppercase; letter-spacing: .06em; }
.casino-table td { padding: 14px 16px; border-bottom: 1px solid var(--color-border); font-size: .9rem; vertical-align: middle; }
.casino-table tr:last-child td { border-bottom: none; }
.casino-table tr:hover td { background: #f8faff; }
.casino-table .bt-link { display: inline-flex; align-items: center; padding: 9px 18px; background: var(--color-accent); color: #fff !important; text-decoration: none; font-weight: 700; font-size: .85rem; border-radius: var(--radius-full); white-space: nowrap; }
.casino-table .bt-link:hover { background: #d63251; }
@media (max-width: 600px) {
    .casino-table thead { display: none; }
    .casino-table tr { display: block; border-bottom: 2px solid var(--color-border); padding: 12px 0; }
    .casino-table td { display: flex; justify-content: space-between; align-items: center; padding: 6px 14px; border: none; }
    .casino-table td::before { content: attr(data-label); font-weight: 700; font-size: .78rem; text-transform: uppercase; color: var(--color-text-muted); flex-shrink: 0; margin-right: 12px; }
}

/* 9b. BRANDS TABLE */
.brands-table { background: var(--color-card); border-radius: var(--radius-lg); border: 1px solid var(--color-border); overflow: hidden; box-shadow: var(--shadow-md); margin-block: 32px; }
.bt-header { display: grid; grid-template-columns: 48px 1fr 1fr 160px; padding: 12px 20px; background: var(--color-primary); color: rgba(255,255,255,.8); font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; gap: 16px; align-items: center; }
.bt-item { display: grid; grid-template-columns: 48px 1fr 1fr 160px; padding: 16px 20px; gap: 16px; align-items: center; border-bottom: 1px solid var(--color-border); transition: background var(--transition); }
.bt-item:last-child { border-bottom: none; }
.bt-item:hover { background: #f8faff; }
.bt-item__rank { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: var(--color-primary); color: var(--color-gold); font-size: .9rem; font-weight: 800; border-radius: var(--radius-sm); flex-shrink: 0; }
.bt-item__info { display: flex; flex-direction: column; gap: 4px; }
.bt-item__logo { max-height: 40px; width: auto; max-width: 140px; object-fit: contain; }
.bt-item__name { font-weight: 700; font-size: .95rem; color: var(--color-primary); }
.star-rating { display: inline-flex; align-items: center; gap: 6px; }
.star-rating__stars { position: relative; display: inline-block; font-size: 1rem; line-height: 1; color: var(--color-border); }
.star-rating__filled { position: absolute; top: 0; left: 0; overflow: hidden; width: var(--rating, 100%); color: var(--color-gold); white-space: nowrap; }
.bt-item__stars { font-size: .85rem; }
.bt-item__rating { font-size: .8rem; color: var(--color-text-muted); font-weight: 600; }
.bt-item__bonus { display: flex; flex-direction: column; gap: 2px; }
.bt-bonus__type { font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; color: var(--color-text-muted); font-weight: 600; }
.bt-bonus__value { font-size: 1.1rem; font-weight: 800; color: var(--color-accent); }
.bt-bonus__code { font-size: .8rem; color: var(--color-text-muted); background: #f0f4ff; display: inline-block; padding: 2px 8px; border-radius: var(--radius-sm); border: 1px dashed var(--color-border); margin-top: 2px; }
.bt-bonus__code strong { color: var(--color-primary); }
.bt-item__link { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.bt-link { display: inline-flex; align-items: center; justify-content: center; gap: 4px; padding: 11px 20px; background: var(--color-accent); color: #fff !important; text-decoration: none; font-weight: 700; font-size: .875rem; border-radius: var(--radius-full); transition: background var(--transition), transform var(--transition), box-shadow var(--transition); box-shadow: var(--shadow-accent); white-space: nowrap; width: 100%; text-align: center; }
.bt-link:hover { background: #d63251; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(233,69,96,.5); }
.bt-link__arrow { transition: transform var(--transition); }
.bt-link:hover .bt-link__arrow { transform: translateX(3px); }
.bt-item__tc { font-size: .7rem; color: var(--color-text-muted); text-align: center; }

/* 10. AUTHOR BOX */
.author-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-block: 32px; }
.author-box, .factchecker-box { display: flex; gap: 16px; padding: 20px; border-radius: var(--radius-lg); border: 1px solid var(--color-border); background: var(--color-card); box-shadow: var(--shadow-sm); }
.author-box { border-left: 4px solid var(--color-secondary); }
.factchecker-box { border-left: 4px solid var(--color-gold); background: #fffdf4; }
.author-avatar img, .fc-avatar img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 3px solid var(--color-border); }
.author-info, .fc-info { flex: 1; min-width: 0; }
.author-label, .fc-label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--color-text-muted); margin-bottom: 2px; }
.author-name { display: block; font-weight: 800; font-size: 1rem; color: var(--color-primary) !important; text-decoration: none; margin-bottom: 2px; }
.author-name:hover { color: var(--color-accent) !important; }
.fc-name { font-weight: 800; font-size: 1rem; color: var(--color-primary); margin-bottom: 2px; }
.author-role, .fc-role { font-size: .8rem; font-weight: 600; color: var(--color-secondary); margin-bottom: 6px; }
.author-bio, .fc-note { font-size: .82rem; color: var(--color-text-muted); line-height: 1.5; margin-bottom: 8px; }
.author-social { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.author-social__link { display: inline-flex; align-items: center; gap: 4px; font-size: .78rem; font-weight: 600; text-decoration: none; padding: 4px 10px; border-radius: var(--radius-full); transition: background var(--transition), color var(--transition); }
.author-social__link--linkedin { color: #0077b5; border: 1px solid #0077b5; }
.author-social__link--linkedin:hover { background: #0077b5; color: #fff; }
.author-social__link--posts { color: var(--color-secondary); border: 1px solid var(--color-secondary); }
.author-social__link--posts:hover { background: var(--color-secondary); color: #fff; }
.fc-date { display: flex; align-items: center; gap: 4px; font-size: .78rem; color: var(--color-text-muted); margin-bottom: 6px; }
.fc-date svg { color: var(--color-success); }
.fc-badge { display: inline-flex; align-items: center; gap: 4px; font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--color-success); background: #f0fff4; border: 1px solid #c6f6d5; padding: 3px 10px; border-radius: var(--radius-full); margin-top: 4px; }

/* 11. CTA BANNER */
.cta-banner { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%); border-radius: var(--radius-xl); padding: 32px 40px; text-align: center; margin-block: 36px; }
.cta-banner__label { display: inline-block; background: var(--color-gold); color: var(--color-primary); font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; padding: 4px 14px; border-radius: var(--radius-full); margin-bottom: 12px; }
.cta-banner__title { font-family: var(--font-heading); font-size: clamp(1.3rem, 3vw, 1.9rem); font-weight: 900; color: #fff; margin-bottom: 8px; }
.cta-banner__sub { font-size: .82rem; color: rgba(255,255,255,.65); margin-bottom: 20px; }
.cta-banner__btn { display: inline-flex; align-items: center; gap: 6px; padding: 14px 36px; background: var(--color-accent); color: #fff !important; text-decoration: none; font-weight: 800; font-size: 1rem; border-radius: var(--radius-full); box-shadow: var(--shadow-accent); transition: background var(--transition), transform var(--transition); }
.cta-banner__btn:hover { background: #d63251; transform: translateY(-2px); }

/* 12. INLINE CTA */
.inline-cta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; padding: 16px 20px; background: linear-gradient(135deg, #fff8f8 0%, #fff 100%); border: 1px solid #ffc9d3; border-left: 4px solid var(--color-accent); border-radius: var(--radius-md); margin-block: 24px; }
.inline-cta__rating { font-size: .85rem; }
.inline-cta__title { flex: 1; font-weight: 700; font-size: .95rem; color: var(--color-primary); }
.inline-cta__btn { display: inline-flex; align-items: center; padding: 10px 22px; background: var(--color-accent); color: #fff !important; text-decoration: none; font-weight: 700; font-size: .875rem; border-radius: var(--radius-full); box-shadow: var(--shadow-accent); white-space: nowrap; transition: background var(--transition), transform var(--transition); }
.inline-cta__btn:hover { background: #d63251; transform: translateY(-1px); }

/* 13. RELATED TABLE */
.related-table { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; margin-block: 28px; }
.related-table table { width: 100%; border-collapse: collapse; }
.related-table th { background: var(--color-primary); color: #fff; text-align: left; padding: 10px 16px; font-size: .82rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.related-table td { padding: 10px 16px; font-size: .875rem; border-bottom: 1px solid var(--color-border); vertical-align: middle; }
.related-table tr:last-child td { border-bottom: none; }
.related-table tr:hover td { background: #f8faff; }
.related-table a { color: var(--color-secondary); font-weight: 600; text-decoration: none; }
.related-table a:hover { color: var(--color-accent); text-decoration: underline; }

/* 14. FAQ */
.faq-section { margin-block: 36px; }
.faq-section > h2 { font-size: clamp(1.3rem, 3vw, 1.75rem); color: var(--color-primary); margin-bottom: 20px; padding-bottom: 12px; border-bottom: 2px solid var(--color-border); }
.faq-item { border: 1px solid var(--color-border); border-radius: var(--radius-md); margin-bottom: 10px; overflow: hidden; transition: box-shadow var(--transition); }
.faq-item.is-open { box-shadow: var(--shadow-md); border-color: var(--color-secondary); }
.faq-q { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 20px; background: var(--color-card); cursor: pointer; font-weight: 700; font-size: .95rem; color: var(--color-primary); transition: background var(--transition); user-select: none; }
.faq-q:hover { background: #f0f4ff; }
.faq-q::after { content: '+'; font-size: 1.4rem; font-weight: 300; color: var(--color-secondary); flex-shrink: 0; transition: transform var(--transition); }
.faq-item.is-open .faq-q::after { transform: rotate(45deg); color: var(--color-accent); }
.faq-item.is-open .faq-q { background: #f0f4ff; }
.faq-a { padding: 0 20px; max-height: 0; overflow: hidden; transition: max-height var(--transition-slow), padding var(--transition-slow); background: var(--color-card); font-size: .9rem; line-height: 1.7; }
.faq-item.is-open .faq-a { max-height: 1000px; padding: 16px 20px 20px; }

/* 15. HIGHLIGHTS LIST */
.highlights-list { list-style: none; margin-block: 20px; display: flex; flex-direction: column; gap: 8px; }
.highlights-list li { display: flex; align-items: flex-start; gap: 10px; font-size: .95rem; }
.highlights-list li::before { content: '✓'; display: flex; align-items: center; justify-content: center; width: 22px; height: 22px; background: var(--color-success); color: #fff; border-radius: 50%; font-size: .7rem; font-weight: 900; flex-shrink: 0; margin-top: 1px; }

/* 16. RELATED POSTS */
.related-posts { margin-block: 48px; padding-top: 40px; border-top: 2px solid var(--color-border); }
.related-posts__title { font-size: clamp(1.2rem, 2.5vw, 1.6rem); color: var(--color-primary); margin-bottom: 24px; }
.related-posts__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.related-post-card { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: box-shadow var(--transition), transform var(--transition); }
.related-post-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.rpc-thumbnail-link { display: block; overflow: hidden; aspect-ratio: 16/9; }
.rpc-thumbnail { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.related-post-card:hover .rpc-thumbnail { transform: scale(1.04); }
.rpc-body { padding: 16px; display: flex; flex-direction: column; flex: 1; }
.rpc-category { margin-bottom: 6px; }
.rpc-cat-link { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--color-secondary); text-decoration: none; background: #eef2ff; padding: 2px 8px; border-radius: var(--radius-full); }
.rpc-cat-link:hover { background: var(--color-secondary); color: #fff; }
.rpc-title { font-size: .95rem; font-weight: 700; line-height: 1.35; margin-bottom: 8px; flex: 1; }
.rpc-title-link { color: var(--color-primary) !important; text-decoration: none; }
.rpc-title-link:hover { color: var(--color-accent) !important; }
.rpc-excerpt { font-size: .82rem; color: var(--color-text-muted); line-height: 1.5; margin-bottom: 12px; flex: 1; }
.rpc-footer { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; margin-top: auto; }
.rpc-date { font-size: .75rem; color: var(--color-text-muted); }
.rpc-link { display: inline-flex; align-items: center; gap: 4px; font-size: .8rem; font-weight: 700; color: var(--color-accent) !important; text-decoration: none; transition: gap var(--transition); }
.rpc-link:hover { gap: 8px; }
.rpc-link__arrow { transition: transform var(--transition); }
.rpc-link:hover .rpc-link__arrow { transform: translateX(3px); }

/* 17. SINGLE POST */
.single-post-layout { max-width: 860px; margin-inline: auto; }
.entry-header { margin-bottom: 28px; }
.entry-category { margin-bottom: 10px; }
.entry-category__link { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--color-secondary); text-decoration: none; background: #eef2ff; padding: 4px 12px; border-radius: var(--radius-full); }
.entry-category__link:hover { background: var(--color-secondary); color: #fff; }
.entry-title { font-size: clamp(1.6rem, 4vw, 2.4rem); font-weight: 900; line-height: 1.2; color: var(--color-primary); margin-bottom: 16px; }
.entry-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; padding: 12px 0; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.entry-meta__item { display: flex; align-items: center; gap: 6px; font-size: .82rem; color: var(--color-text-muted); }
.entry-meta__avatar { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; border: 2px solid var(--color-border); }
.entry-meta__author-link { color: var(--color-secondary) !important; text-decoration: none; font-weight: 700; }
.entry-meta__author-link:hover { color: var(--color-accent) !important; }
.entry-featured-image { margin-block: 24px; border-radius: var(--radius-lg); overflow: hidden; }
.entry-featured-img { width: 100%; height: auto; display: block; }
.entry-content { font-size: 1rem; line-height: 1.8; color: var(--color-text); }
.entry-content h2 { margin-top: 2.5rem; margin-bottom: .75rem; font-size: 1.6rem; padding-bottom: 8px; border-bottom: 2px solid var(--color-border); }
.entry-content h3 { margin-top: 2rem; margin-bottom: .6rem; font-size: 1.3rem; }
.entry-content h4 { margin-top: 1.5rem; margin-bottom: .5rem; }
.entry-content p { margin-bottom: 1.25rem; }
.entry-content ul, .entry-content ol { margin-bottom: 1.25rem; padding-left: 24px; }
.entry-content ul { list-style: disc; }
.entry-content ol { list-style: decimal; }
.entry-content li { margin-bottom: .4rem; }
.entry-content a { color: var(--color-secondary); font-weight: 500; }
.entry-content a:hover { color: var(--color-accent); }
.entry-content img { max-width: 100%; height: auto; border-radius: var(--radius-md); margin-block: 16px; }
.entry-content blockquote { margin-block: 24px; padding: 16px 20px 16px 24px; border-left: 4px solid var(--color-accent); background: #fff5f7; border-radius: 0 var(--radius-md) var(--radius-md) 0; font-style: italic; color: var(--color-text-muted); }
.entry-content table { width: 100%; border-collapse: collapse; margin-block: 20px; font-size: .9rem; }
.entry-content table th { background: var(--color-primary); color: #fff; padding: 10px 14px; text-align: left; font-weight: 700; }
.entry-content table td { padding: 10px 14px; border-bottom: 1px solid var(--color-border); }
.entry-content table tr:hover td { background: #f8faff; }
.entry-content code { font-family: monospace; background: #f0f4ff; padding: 2px 6px; border-radius: 3px; font-size: .88em; color: var(--color-secondary); }
.entry-tags { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-block: 28px; padding-block: 20px; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.entry-tags__label { display: flex; align-items: center; gap: 4px; font-size: .8rem; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .07em; }
.entry-tag { padding: 4px 12px; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-full); font-size: .78rem; font-weight: 600; color: var(--color-secondary); text-decoration: none; transition: background var(--transition), color var(--transition); }
.entry-tag:hover { background: var(--color-secondary); color: #fff; border-color: var(--color-secondary); }
.entry-footer { margin-top: 28px; }
.entry-footer__share { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.entry-footer__share-label { font-size: .82rem; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .07em; }
.share-btn { display: inline-flex; align-items: center; gap: 6px; padding: 7px 16px; border-radius: var(--radius-full); font-size: .82rem; font-weight: 700; text-decoration: none; transition: opacity var(--transition), transform var(--transition); }
.share-btn:hover { opacity: .85; transform: translateY(-1px); }
.share-btn--twitter { background: #000; color: #fff !important; }
.share-btn--facebook { background: #1877f2; color: #fff !important; }

/* 18. ARCHIVE GRID */
.archive-header { margin-bottom: 32px; }
.archive-title { font-size: clamp(1.5rem, 4vw, 2.2rem); color: var(--color-primary); margin-bottom: 10px; }
.archive-description { font-size: .95rem; color: var(--color-text-muted); max-width: 700px; line-height: 1.65; margin-top: 10px; }
.archive-page-indicator { font-size: .85rem; color: var(--color-text-muted); background: var(--color-bg); display: inline-block; padding: 3px 12px; border-radius: var(--radius-full); border: 1px solid var(--color-border); margin-bottom: 8px; }
.archive-subcats { margin-top: 16px; }
.archive-subcats__list { display: flex; flex-wrap: wrap; gap: 8px; }
.archive-subcat-link { display: inline-flex; align-items: center; gap: 4px; padding: 5px 14px; background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-full); font-size: .8rem; font-weight: 600; color: var(--color-secondary); text-decoration: none; transition: background var(--transition), color var(--transition); }
.archive-subcat-link:hover { background: var(--color-secondary); color: #fff; border-color: var(--color-secondary); }
.archive-subcat-count { font-size: .72rem; opacity: .7; }
.archive-posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 40px; }
.archive-card { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: box-shadow var(--transition), transform var(--transition); }
.archive-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.archive-card__thumb-link { display: block; overflow: hidden; aspect-ratio: 3/2; background: var(--color-bg); }
.archive-card__thumb { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.archive-card:hover .archive-card__thumb { transform: scale(1.04); }
.archive-card__body { padding: 18px; display: flex; flex-direction: column; flex: 1; }
.archive-card__category { margin-bottom: 8px; }
.archive-card__cat-link { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--color-secondary); text-decoration: none; background: #eef2ff; padding: 3px 10px; border-radius: var(--radius-full); }
.archive-card__cat-link:hover { background: var(--color-secondary); color: #fff; }
.archive-card__title { font-size: 1rem; font-weight: 700; line-height: 1.35; margin-bottom: 10px; flex: 1; }
.archive-card__title-link { color: var(--color-primary) !important; text-decoration: none; }
.archive-card__title-link:hover { color: var(--color-accent) !important; }
.archive-card__excerpt { font-size: .85rem; color: var(--color-text-muted); line-height: 1.55; margin-bottom: 14px; flex: 1; }
.archive-card__footer { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 6px; margin-top: auto; padding-top: 12px; border-top: 1px solid var(--color-border); }
.archive-card__meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.archive-card__date { font-size: .75rem; color: var(--color-text-muted); }
.archive-card__reading-time { font-size: .72rem; color: var(--color-text-muted); background: var(--color-bg); padding: 2px 7px; border-radius: var(--radius-full); border: 1px solid var(--color-border); }
.archive-card__read-more { display: inline-flex; align-items: center; gap: 4px; font-size: .8rem; font-weight: 700; color: var(--color-accent) !important; text-decoration: none; transition: gap var(--transition); }
.archive-card__read-more:hover { gap: 8px; }
.archive-card__arrow { transition: transform var(--transition); }
.archive-card__read-more:hover .archive-card__arrow { transform: translateX(3px); }

/* 19. PAGINATION */
.pagination { display: flex; justify-content: center; margin-block: 40px; }
.pagination__list { display: flex; align-items: center; flex-wrap: wrap; gap: 4px; }
.pagination__list a, .pagination__list .current { display: flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; padding-inline: 8px; border-radius: var(--radius-md); font-size: .875rem; font-weight: 600; text-decoration: none; transition: background var(--transition), color var(--transition); }
.pagination__list a { background: var(--color-card); color: var(--color-secondary); border: 1px solid var(--color-border); }
.pagination__list a:hover { background: var(--color-secondary); color: #fff; border-color: var(--color-secondary); }
.pagination__list .current, .pagination__item--current a { background: var(--color-accent); color: #fff; border: 1px solid var(--color-accent); }

/* 20. AUTHOR PROFILE */
.author-profile { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%); border-radius: var(--radius-xl); padding: 40px; margin-bottom: 40px; }
.author-profile__inner { display: flex; gap: 32px; align-items: flex-start; }
.author-profile__avatar-wrap { flex-shrink: 0; }
.author-profile__avatar { width: 120px; height: 120px; border-radius: 50%; object-fit: cover; border: 4px solid rgba(255,255,255,.3); box-shadow: var(--shadow-lg); }
.author-profile__info { flex: 1; }
.author-profile__role { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--color-gold); margin-bottom: 4px; }
.author-profile__name { font-size: clamp(1.5rem, 3vw, 2.2rem); font-weight: 900; color: #fff; margin-bottom: 12px; }
.author-profile__bio { font-size: .9rem; color: rgba(255,255,255,.8); line-height: 1.7; margin-bottom: 20px; }
.author-profile__bio p { margin-bottom: .75rem; }
.author-profile__stats { display: flex; flex-wrap: wrap; align-items: center; gap: 20px; margin-bottom: 16px; }
.author-profile__stat { display: flex; flex-direction: column; align-items: center; }
.author-profile__stat-num { font-size: 1.4rem; font-weight: 900; color: var(--color-gold); line-height: 1; }
.author-profile__stat-label { font-size: .75rem; color: rgba(255,255,255,.6); text-transform: uppercase; letter-spacing: .07em; }
.author-profile__specialties { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.author-profile__spec-label { font-size: .78rem; color: rgba(255,255,255,.6); font-weight: 600; }
.author-profile__specialty-tag { background: rgba(255,255,255,.1); color: #fff; padding: 3px 10px; border-radius: var(--radius-full); font-size: .75rem; font-weight: 600; border: 1px solid rgba(255,255,255,.2); }
.author-profile__social { display: flex; flex-wrap: wrap; gap: 8px; }
.author-social-link { display: inline-flex; align-items: center; gap: 6px; padding: 7px 16px; border-radius: var(--radius-full); font-size: .82rem; font-weight: 700; text-decoration: none; border: 1px solid rgba(255,255,255,.3); color: rgba(255,255,255,.85) !important; transition: background var(--transition); }
.author-social-link:hover { background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.6); color: #fff !important; }
.author-posts__header { display: flex; align-items: baseline; gap: 12px; margin-bottom: 24px; padding-bottom: 12px; border-bottom: 2px solid var(--color-border); }
.author-posts__title { font-size: 1.4rem; }
.author-posts__count { font-size: .82rem; color: var(--color-text-muted); background: var(--color-bg); padding: 3px 10px; border-radius: var(--radius-full); border: 1px solid var(--color-border); }

/* 21. NO POSTS STATE */
.no-posts-found { padding: 60px 20px; text-align: center; }
.no-posts-found__icon { margin-inline: auto; color: var(--color-border); margin-bottom: 20px; }
.no-posts-found__title { font-size: 1.5rem; color: var(--color-primary); margin-bottom: 12px; }
.no-posts-found__text { color: var(--color-text-muted); margin-bottom: 24px; }
.no-posts-found__links { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }

/* 22. BUTTONS */
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 11px 24px; border-radius: var(--radius-full); font-size: .9rem; font-weight: 700; text-decoration: none; cursor: pointer; border: 2px solid transparent; transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition), box-shadow var(--transition); }
.btn--primary { background: var(--color-accent); color: #fff; border-color: var(--color-accent); box-shadow: var(--shadow-accent); }
.btn--primary:hover { background: #d63251; border-color: #d63251; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(233,69,96,.5); color: #fff; }
.btn--outline { background: transparent; color: var(--color-secondary); border-color: var(--color-secondary); }
.btn--outline:hover { background: var(--color-secondary); color: #fff; }

/* 23. 404 PAGE */
.error-404-page { padding-block: 20px; }
.error-404-hero { text-align: center; padding: 48px 20px; background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%); border-radius: var(--radius-xl); margin-bottom: 48px; color: #fff; }
.error-404-hero__number { font-family: var(--font-heading); font-size: clamp(5rem, 15vw, 10rem); font-weight: 900; color: rgba(255,255,255,.1); line-height: 1; margin-bottom: -20px; }
.error-404-hero__title { font-size: clamp(1.4rem, 4vw, 2.2rem); font-weight: 900; color: #fff; margin-bottom: 12px; }
.error-404-hero__text { color: rgba(255,255,255,.75); font-size: .95rem; max-width: 520px; margin-inline: auto; margin-bottom: 28px; }
.error-search-wrap { display: flex; max-width: 480px; margin-inline: auto; margin-bottom: 20px; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); border-radius: var(--radius-full); overflow: hidden; }
.error-search-input { flex: 1; background: none; border: none; padding: 12px 20px; color: #fff; font-size: .9rem; outline: none; }
.error-search-input::placeholder { color: rgba(255,255,255,.5); }
.error-search-btn { background: var(--color-gold); border: none; padding: 12px 20px; color: var(--color-primary); cursor: pointer; font-weight: 700; font-size: .85rem; display: flex; align-items: center; gap: 6px; transition: background var(--transition); }
.error-search-btn:hover { background: #e0950f; }
.error-404-section-title { font-size: clamp(1.2rem, 3vw, 1.6rem); color: var(--color-primary); margin-bottom: 24px; padding-bottom: 12px; border-bottom: 2px solid var(--color-border); }
.error-404-cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-bottom: 48px; }
.error-404-cat-card { background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 24px; }
.error-404-cat-card__icon { color: var(--color-secondary); margin-bottom: 12px; }
.error-404-cat-card__title { font-size: 1.05rem; color: var(--color-primary); margin-bottom: 12px; }
.error-404-cat-card__links { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.error-404-cat-card__links li a { font-size: .82rem; color: var(--color-secondary); text-decoration: none; }
.error-404-cat-card__links li a:hover { color: var(--color-accent); text-decoration: underline; }
.error-404-cat-card__all { font-size: .82rem; font-weight: 700; color: var(--color-accent) !important; text-decoration: none; }
.error-404-cat-card__all:hover { text-decoration: underline; }
.error-404-casinos { margin-bottom: 40px; }

/* 24. FOOTER */
.site-footer { background: var(--color-primary); color: rgba(255,255,255,.75); margin-top: auto; }
.footer-cta-strip { background: linear-gradient(135deg, var(--color-accent) 0%, #c02040 100%); padding: 20px 0; }
.footer-cta-strip__inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.footer-cta-strip__text strong { display: block; font-size: 1rem; font-weight: 800; color: #fff; margin-bottom: 2px; }
.footer-cta-strip__sub { font-size: .8rem; color: rgba(255,255,255,.8); }
.footer-cta-strip__buttons { display: flex; gap: 10px; flex-wrap: wrap; }
.footer-cta-btn { padding: 9px 20px; background: rgba(255,255,255,.2); color: #fff !important; text-decoration: none; font-size: .85rem; font-weight: 700; border-radius: var(--radius-full); border: 1px solid rgba(255,255,255,.3); transition: background var(--transition); white-space: nowrap; }
.footer-cta-btn:hover { background: rgba(255,255,255,.35); }
.footer-cta-btn--secondary { background: transparent; }
.footer-main { padding: 48px 0 32px; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; }
.footer-logo-link { display: inline-block; text-decoration: none; margin-bottom: 12px; }
.footer-logo-text { display: flex; flex-direction: column; line-height: 1.2; }
.footer-logo-text__main { font-family: var(--font-heading); font-weight: 800; font-size: 1.2rem; color: #fff; }
.footer-logo-text__accent { font-family: var(--font-heading); font-size: .9rem; font-weight: 700; color: var(--color-gold); }
.footer-tagline { font-size: .82rem; color: rgba(255,255,255,.55); margin-bottom: 20px; line-height: 1.55; }
.footer-contact { font-style: normal; margin-top: 16px; }
.footer-contact__item { display: flex; align-items: flex-start; gap: 8px; font-size: .82rem; color: rgba(255,255,255,.6); margin-bottom: 10px; line-height: 1.45; }
.footer-contact__icon { flex-shrink: 0; color: rgba(255,255,255,.4); margin-top: 1px; }
.footer-contact__item a { color: rgba(255,255,255,.7); text-decoration: none; }
.footer-contact__item a:hover { color: var(--color-gold); }
.footer-col__title { font-size: .8rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; color: #fff; margin-bottom: 14px; padding-bottom: 8px; border-bottom: 1px solid rgba(255,255,255,.1); }
.footer-col__title--mt { margin-top: 24px; }
.footer-links { display: flex; flex-direction: column; gap: 8px; }
.footer-links li a { font-size: .85rem; color: rgba(255,255,255,.6); text-decoration: none; transition: color var(--transition), padding-left var(--transition); }
.footer-links li a:hover { color: var(--color-gold); padding-left: 4px; }
.footer-disclaimer { background: rgba(0,0,0,.2); padding: 16px 0; border-top: 1px solid rgba(255,255,255,.08); }
.footer-disclaimer__inner { display: flex; gap: 12px; align-items: flex-start; }
.footer-disclaimer__icon { flex-shrink: 0; color: rgba(255,255,255,.35); margin-top: 2px; }
.footer-disclaimer__text { font-size: .78rem; color: rgba(255,255,255,.45); line-height: 1.6; }
.footer-bottom { padding: 16px 0; border-top: 1px solid rgba(255,255,255,.08); }
.footer-bottom__inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.footer-copyright p { font-size: .8rem; color: rgba(255,255,255,.4); margin: 0; }
.footer-copyright a { color: rgba(255,255,255,.6); text-decoration: none; }
.footer-copyright a:hover { color: var(--color-gold); }
.footer-legal-links { display: flex; flex-wrap: wrap; gap: 4px 16px; }
.footer-legal-links li a { font-size: .75rem; color: rgba(255,255,255,.45); text-decoration: none; }
.footer-legal-links li a:hover { color: rgba(255,255,255,.8); }
.footer-badges { display: flex; gap: 8px; }
.footer-badge { font-size: .65rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; padding: 4px 10px; border-radius: var(--radius-full); border: 1px solid rgba(255,255,255,.2); color: rgba(255,255,255,.5); }

/* 25. HERO & FRONT PAGE */
.hero-section { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%); border-radius: var(--radius-xl); padding: 60px 40px; text-align: center; margin-bottom: 40px; color: #fff; }
.hero-section__title { font-size: clamp(1.8rem, 5vw, 3rem); font-weight: 900; color: #fff; line-height: 1.2; }

/* 26. COMMENTS */
.comments-section { margin-top: 48px; padding-top: 40px; border-top: 2px solid var(--color-border); }
.comment-list { list-style: none; margin-bottom: 32px; }
.comment { padding: 20px; background: var(--color-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); margin-bottom: 16px; }
.comment-author .fn { font-weight: 700; }
.comment-meta { font-size: .78rem; color: var(--color-text-muted); margin-bottom: 10px; }
.comment-content { font-size: .9rem; }
.comment-form label { display: block; font-weight: 600; font-size: .875rem; margin-bottom: 4px; }
.comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"], .comment-form textarea { width: 100%; padding: 10px 14px; border: 1px solid var(--color-border); border-radius: var(--radius-md); font-size: .9rem; font-family: var(--font-sans); color: var(--color-text); background: var(--color-card); transition: border-color var(--transition); }
.comment-form input:focus, .comment-form textarea:focus { outline: none; border-color: var(--color-secondary); box-shadow: 0 0 0 3px rgba(15,52,96,.1); }
.comment-form textarea { min-height: 140px; resize: vertical; }
.comment-form .submit { padding: 11px 28px; background: var(--color-accent); color: #fff; border: none; border-radius: var(--radius-full); font-size: .9rem; font-weight: 700; cursor: pointer; transition: background var(--transition), transform var(--transition); }
.comment-form .submit:hover { background: #d63251; transform: translateY(-1px); }

/* 27. PAGE META */
.page-header { margin-bottom: 28px; }
.page-title { font-size: clamp(1.6rem, 4vw, 2.4rem); font-weight: 900; line-height: 1.2; color: var(--color-primary); margin-bottom: 12px; }
.page-meta { font-size: .82rem; color: var(--color-text-muted); margin-bottom: 16px; }

/* 28. RESPONSIVE */
@media (max-width: 1100px) {
    .bt-header, .bt-item { grid-template-columns: 40px 1fr 1fr 130px; padding-inline: 14px; }
    .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
    .related-posts__grid { grid-template-columns: repeat(2, 1fr); }
    .error-404-cat-grid { grid-template-columns: repeat(2, 1fr); }
}
/* Suppress WP-generated site description */
.site-description { display: none !important; }

/* ============================================================
   MOBILE — ≤900px
   Key decisions:
   • Header scrolls away (not sticky) — no more floating logo
   • Hamburger is position:fixed top-right — always reachable
   • Brands table uses div elements — no table-layout interference
   ============================================================ */
@media (max-width: 900px) {

    /* ── HEADER: not sticky, scrolls away with page ── */
    .site-header { position: relative !important; box-shadow: none; }
    .site-nav { display: none !important; }
    .header-cta-btn { display: none; }
    .search-toggle { display: none; }
    :root { --header-height: 60px; }
    .site-logo-text__main { font-size: 1.1rem; }
    .site-logo-text__accent { font-size: .8rem; }

    /* ── HAMBURGER: fixed top-right corner, always accessible ── */
    .hamburger {
        display: flex !important;
        position: fixed;
        top: 14px;
        right: 14px;
        z-index: 910;
        background: var(--color-primary);
        border-radius: var(--radius-md);
        padding: 10px 12px;
        min-width: 44px;
        min-height: 44px;
        align-items: center;
        justify-content: center;
        box-shadow: 0 3px 14px rgba(0,0,0,.35);
    }
    .hamburger__line { background: #fff; }

    /* ── BRANDS TABLE: div-based, no table-layout conflicts ── */
    .bt-header { display: none !important; }

    /* Each row = full-width card */
    .brands-table .bt-item {
        display: block;
        width: 100%;
        box-sizing: border-box;
        position: relative;
        padding: 16px;
        border-bottom: 8px solid #f0f4f8;
        background: #fff;
        text-align: center;
    }

    /* Rank badge: top-center above name */
    .brands-table .bt-item__rank {
        display: block;
        width: auto;
        height: auto;
        margin: 0 auto 8px;
        font-size: .8rem;
        font-weight: 800;
        color: var(--color-text-muted);
        background: none;
        border-radius: 0;
        box-shadow: none;
    }

    /* Casino info block */
    .brands-table .bt-item__info { display: block; margin-bottom: 8px; text-align: center; }
    .bt-item__badge { display: none; }
    .bt-item__name { font-size: 1.1rem; font-weight: 800; margin-bottom: 4px; }
    .bt-item__stars { font-size: .9rem; }
    .bt-item__rating { font-size: .78rem; color: var(--color-text-muted); }

    /* Bonus block centered with accent strip */
    .brands-table .bt-item__bonus {
        display: block;
        padding: 10px 16px;
        background: rgba(233,69,96,.06);
        border-left: 3px solid var(--color-accent);
        border-radius: 0 6px 6px 0;
        margin-bottom: 12px;
        text-align: center;
        box-sizing: border-box;
    }
    .bt-bonus__type { font-size: .7rem; text-transform: uppercase; letter-spacing: .05em; color: var(--color-text-muted); }
    .bt-bonus__value { font-size: 1.2rem; font-weight: 800; color: var(--color-accent); }
    .bt-bonus__promo { display: none; }

    /* Full-width Play Now button */
    .brands-table .bt-item__link { display: block; }
    .brands-table .bt-link {
        display: flex !important;
        width: 100%;
        min-height: 48px;
        font-size: 1rem;
        justify-content: center;
        padding: 12px 16px;
        box-sizing: border-box;
    }

    /* ── LAYOUT ── */
    .author-grid { grid-template-columns: 1fr; }
    .archive-posts-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .author-profile__inner { flex-direction: column; align-items: center; text-align: center; }
    .author-profile__social { justify-content: center; }
    .footer-cta-strip__inner { flex-direction: column; text-align: center; gap: 16px; }
    .footer-cta-strip__buttons { justify-content: center; flex-wrap: wrap; gap: 10px; }
    .footer-cta-btn { min-height: 44px; }

    /* ── MOBILE SUBMENU: reset desktop absolute positioning ── */
    .mobile-nav-menu .sub-menu {
        display: none;
        position: static !important;
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        box-shadow: none !important;
        border: none !important;
        border-radius: 0 !important;
        min-width: 0 !important;
        z-index: auto !important;
    }
}

/* ============================================================
   MOBILE — ≤640px  (phones)
   ============================================================ */
@media (max-width: 640px) {
    :root { --container-pad: 16px; --header-height: 56px; }
    .site-main { padding-block: 20px 36px; }

    /* Typography */
    body { font-size: .95rem; }
    h1 { font-size: clamp(1.4rem, 6vw, 1.9rem); }
    h2 { font-size: clamp(1.2rem, 5vw, 1.5rem); }
    h3 { font-size: clamp(1rem, 4vw, 1.25rem); }

    /* Layout */
    .archive-posts-grid { grid-template-columns: 1fr; }
    .related-posts__grid { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr; gap: 28px; }
    .footer-bottom__inner { flex-direction: column; align-items: flex-start; gap: 10px; }
    .error-404-cat-grid { grid-template-columns: 1fr; }

    /* Inline CTA */
    .inline-cta { flex-direction: column; align-items: stretch; gap: 10px; padding: 14px 16px; }
    .inline-cta__btn { width: 100%; justify-content: center; min-height: 48px; font-size: 1rem; }

    /* Author boxes stack */
    .author-box { flex-direction: column; gap: 12px; }
    .factchecker-box { flex-direction: column; gap: 12px; }

    /* Entry meta */
    .entry-meta { gap: 8px; flex-wrap: wrap; }

    /* CTA banner */
    .cta-banner { padding: 24px 16px; }
    .cta-banner__title { font-size: clamp(1rem, 4vw, 1.3rem); }
    .cta-banner__btn { width: 100%; justify-content: center; min-height: 48px; }

    /* Casino simple table */
    .casino-table { font-size: .85rem; }

    /* Related posts */
    .related-post-card { flex-direction: column; }

    /* Footer */
    .footer-badges { display: none; }
    .footer-legal-links { flex-wrap: wrap; gap: 8px; }
    .hero-section { padding: 28px 16px; }
    .footer-links li a { padding: 6px 0; display: inline-block; min-height: 36px; line-height: 36px; }

    /* Tables scroll horizontally — exclude brands-table (gets card layout below) */
    .entry-content table:not(.brands-table) { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }

    /* brands-table inside post content (stored as <table> HTML) — card layout */
    .entry-content .brands-table,
    .entry-content .brands-table thead,
    .entry-content .brands-table tbody,
    .entry-content .brands-table tfoot,
    .entry-content .brands-table tr,
    .entry-content .brands-table th,
    .entry-content .brands-table td {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        overflow: visible !important;
    }
    .entry-content .brands-table thead { display: none !important; }
    .entry-content .brands-table tr.bt-item {
        position: relative;
        padding: 16px;
        border-bottom: 8px solid #f0f4f8;
        background: #fff;
        text-align: center;
    }
    .entry-content .brands-table td.bt-item__rank {
        position: static !important;
        display: block !important;
        width: auto !important;
        height: auto !important;
        margin: 0 auto 8px;
        font-weight: 800;
        color: var(--color-text-muted);
        background: none;
        box-shadow: none;
        border-radius: 0;
    }
    .entry-content .brands-table td.bt-item__info { display: block !important; text-align: center; margin-bottom: 8px; }
    .entry-content .brands-table td.bt-item__bonus {
        display: block !important;
        padding: 10px 16px;
        background: rgba(233,69,96,.06);
        border-left: 3px solid var(--color-accent);
        border-radius: 0 6px 6px 0;
        margin-bottom: 12px;
        text-align: center;
    }
    .entry-content .brands-table td.bt-item__link { display: block !important; padding: 0; }
    .entry-content .brands-table .bt-link {
        display: flex !important;
        width: 100% !important;
        min-height: 48px;
        justify-content: center;
        padding: 12px 16px;
        box-sizing: border-box;
        font-size: 1rem;
    }
}

/* 29. PRINT */
@media print {
    .site-header, .site-nav, .site-footer, .cta-banner, .inline-cta, .related-posts, .comments-section, .share-btn, .breadcrumbs, .mobile-menu, .mobile-overlay { display: none !important; }
    body { font-size: 12pt; color: #000; background: #fff; }
    a { color: #000; text-decoration: underline; }
}

/* 30. ACCESSIBILITY & ANIMATION */
:focus-visible { outline: 3px solid var(--color-gold); outline-offset: 3px; border-radius: 2px; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.archive-card, .related-post-card, .bt-item { animation: fadeIn .3s ease both; }
.archive-posts-grid .archive-card:nth-child(1) { animation-delay: .05s; }
.archive-posts-grid .archive-card:nth-child(2) { animation-delay: .1s; }
.archive-posts-grid .archive-card:nth-child(3) { animation-delay: .15s; }
.archive-posts-grid .archive-card:nth-child(4) { animation-delay: .2s; }
.archive-posts-grid .archive-card:nth-child(5) { animation-delay: .25s; }
.archive-posts-grid .archive-card:nth-child(6) { animation-delay: .3s; }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; } }
