/*
Theme Name: Independent Slot Sites
Theme URI: https://independentslotsites.it.com
Author: Independent Slot Sites
Author URI: https://independentslotsites.it.com
Description: A professional casino affiliate theme for Independent Slot Sites.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: independent-slot-sites
*/

/* ─── RESET & BASE ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',sans-serif;font-size:16px;line-height:1.7;color:#111827;background:#FFFFFF;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:'Space Grotesk',sans-serif;font-weight:700;line-height:1.2;color:#111827}
h1{font-size:2.75rem}
h2{font-size:2rem}
h3{font-size:1.5rem}
h4{font-size:1.25rem}
p{margin-bottom:1rem}
button,input,select,textarea{font-family:inherit;font-size:inherit;border:none;outline:none}

/* ─── UTILITIES ─── */
.container{max-width:1280px;margin:0 auto;padding:0 24px;width:100%}
.section-spacing{padding:64px 0}
.text-left{text-align:left}
.text-center{text-align:center}

/* ─── HEADER ─── */
.site-header{position:sticky;top:0;z-index:1000;background:#FFFFFF;border-bottom:1px solid #E5E7EB;transition:box-shadow .2s}
.site-header.scrolled{box-shadow:0 2px 8px rgba(0,0,0,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.site-logo{font-family:'Space Grotesk',sans-serif;font-size:1.25rem;font-weight:700;color:#111827;white-space:nowrap}
.main-nav{display:flex;gap:32px;align-items:center}
.main-nav a{font-size:.9rem;font-weight:500;color:#374151;transition:color .2s;position:relative}
.main-nav a:hover,.main-nav a.active{color:#111827}
.main-nav a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:#1F2937;transition:width .2s}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:#111827;transition:.2s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-nav{display:none;position:absolute;top:64px;left:0;right:0;background:#FFFFFF;border-bottom:1px solid #E5E7EB;padding:16px 24px;flex-direction:column;gap:16px;z-index:999}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:1rem;font-weight:500;color:#374151;padding:8px 0}

/* ─── HERO ─── */
.hero{background:#F3F4F6;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 24px}
.hero.hero-home{min-height:60vh}
.hero.hero-inner{min-height:40vh}
.hero.hero-howwerate{min-height:45vh}
.hero-content{max-width:800px;width:100%}
.hero h1{margin-bottom:16px;font-size:2.75rem}
.hero p{font-size:1.15rem;color:#6B7280;margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}
.hero-badges{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#FFFFFF;border:1px solid #E5E7EB;font-size:.85rem;font-weight:600;color:#374151;border-radius:0}
.btn-cta{display:inline-block;padding:14px 36px;background:#1F2937;color:#FFFFFF;font-weight:600;font-size:.95rem;border:none;cursor:pointer;transition:background .2s;border-radius:0}
.btn-cta:hover{background:#374151}

/* ─── CASINO GRID ─── */
.casino-grid-section{background:#FFFFFF}
.casino-grid-section h2{margin-bottom:40px}
.casino-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.casino-card{background:#F9FAFB;border:1px solid #E5E7EB;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s;border-radius:0}
.casino-card:hover{border-color:#6B7280}
.casino-card-rank{position:absolute;top:12px;left:12px;background:#1F2937;color:#FFFFFF;font-size:.75rem;font-weight:700;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:0}
.casino-card-header{position:relative;padding:24px 20px 16px;display:flex;flex-direction:column;align-items:center;text-align:center;background:#FFFFFF}
.casino-card-logo{width:100px;height:60px;object-fit:contain;margin-bottom:12px}
.casino-card-logo-placeholder{width:100px;height:60px;border:2px dashed #E5E7EB;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#6B7280;margin-bottom:12px}
.casino-card-name{font-size:1rem;font-weight:700;margin-bottom:6px}
.casino-card-stars{color:#F59E0B;font-size:.85rem;letter-spacing:1px;margin-bottom:4px}
.casino-card-badge{font-size:.7rem;font-weight:600;color:#059669;background:#ECFDF5;padding:3px 8px;display:inline-block;border-radius:0}
.casino-card-body{padding:16px 20px;flex:1}
.casino-card-bonus{font-size:.95rem;font-weight:700;color:#111827;margin-bottom:12px}
.casino-card-meta{display:flex;flex-direction:column;gap:6px}
.casino-card-meta-row{display:flex;justify-content:space-between;font-size:.8rem;color:#6B7280}
.casino-card-meta-row span:last-child{font-weight:600;color:#374151}
.casino-card-footer{padding:16px 20px;border-top:1px solid #E5E7EB}
.casino-card-footer .btn-cta{width:100%;text-align:center;display:block;padding:12px;font-size:.9rem}
.casino-card-terms{font-size:.65rem;color:#9CA3AF;margin-top:8px;text-align:center;line-height:1.4}

/* ─── REVIEW BLOCKS ─── */
.reviews-section{background:#F9FAFB}
.reviews-section h2{margin-bottom:48px}
.review-block{margin-bottom:64px;padding-bottom:48px;border-bottom:1px solid #E5E7EB}
.review-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.review-topbar{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:32px;padding:20px;background:#FFFFFF;border:1px solid #E5E7EB;border-radius:0}
.review-topbar-logo{width:80px;height:48px;object-fit:contain;flex-shrink:0}
.review-topbar-info{flex:1;min-width:200px}
.review-topbar-info h3{font-size:1.35rem;margin-bottom:4px}
.review-topbar-stars{color:#F59E0B;font-size:.85rem}
.review-topbar-cta{margin-left:auto}
.review-topbar-cta .btn-cta{padding:10px 24px;font-size:.85rem}
.review-screenshots{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px}
.review-screenshot{cursor:pointer;overflow:hidden;border:1px solid #E5E7EB;border-radius:0;aspect-ratio:16/9}
.review-screenshot img{width:100%;height:100%;object-fit:cover;transition:transform .2s}
.review-screenshot:hover img{transform:scale(1.02)}
.review-screenshot-placeholder{border:2px dashed #E5E7EB;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:.85rem;color:#6B7280}
.review-body{margin-bottom:28px;font-size:.95rem;color:#374151;line-height:1.8}
.review-body h4{margin:20px 0 10px;color:#111827}
.review-body p{margin-bottom:12px}
.review-pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid #E5E7EB;margin-bottom:16px;border-radius:0;overflow:hidden}
.review-pros,.review-cons{padding:20px}
.review-pros{background:#F0FDF4;border-right:1px solid #E5E7EB}
.review-cons{background:#FEF2F2}
.review-pros h4,.review-cons h4{font-size:.9rem;margin-bottom:12px;font-weight:700}
.review-pros h4{color:#059669}
.review-cons h4{color:#DC2626}
.review-pros li,.review-cons li{font-size:.85rem;padding:4px 0;position:relative;padding-left:20px}
.review-pros li::before{content:'✓';position:absolute;left:0;color:#059669;font-weight:700}
.review-cons li::before{content:'✗';position:absolute;left:0;color:#DC2626;font-weight:700}

/* ─── CONTENT SECTIONS (plugin injected) ─── */
.content-section{background:#FFFFFF}
.content-section .container{width:100%}
.content-section h2,.content-section h3,.content-section h4{margin-bottom:16px}
.content-section p{margin-bottom:12px}

/* ─── FAQ ─── */
.faq-section{background:#FFFFFF}
.faq-section h2{margin-bottom:40px}
.faq-item{margin-bottom:32px}
.faq-item h4{font-size:1.05rem;margin-bottom:8px;color:#111827}
.faq-item p{color:#374151;font-size:.95rem}

/* ─── AUTHOR BOX ─── */
.author-box{background:#F3F4F6;border:1px solid #E5E7EB;padding:32px;display:flex;gap:24px;align-items:flex-start;border-radius:0}
.author-box-img{width:80px;height:80px;object-fit:cover;flex-shrink:0;border-radius:0}
.author-box-img-placeholder{width:80px;height:80px;border:2px dashed #E5E7EB;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#6B7280;flex-shrink:0}
.author-box-content h4{font-size:1.05rem;margin-bottom:6px}
.author-box-content p{font-size:.9rem;color:#6B7280;margin-bottom:0}

/* ─── ABOUT PAGE ─── */
.about-team{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:32px;margin-top:40px}
.team-member{text-align:center}
.team-member img{width:160px;height:160px;object-fit:cover;margin:0 auto 16px;border-radius:0}
.team-member h4{margin-bottom:4px}
.team-member p{font-size:.85rem;color:#6B7280}

/* ─── CONTACT PAGE ─── */
.contact-layout{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:start}
.contact-form{background:#F9FAFB;border:1px solid #E5E7EB;padding:32px;border-radius:0}
.contact-form label{display:block;font-size:.85rem;font-weight:600;color:#374151;margin-bottom:6px}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;padding:12px;border:1px solid #E5E7EB;background:#FFFFFF;margin-bottom:20px;font-size:.9rem;border-radius:0;color:#111827}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form .btn-cta{width:100%;text-align:center;border:none;cursor:pointer}
.contact-info-box{background:#F3F4F6;border:1px solid #E5E7EB;padding:28px;border-radius:0}
.contact-info-box h4{margin-bottom:16px}
.contact-info-item{margin-bottom:16px;font-size:.9rem;color:#374151}
.contact-info-item strong{display:block;font-size:.8rem;color:#6B7280;margin-bottom:2px}
.toast{position:fixed;bottom:24px;right:24px;background:#059669;color:#FFFFFF;padding:14px 24px;font-size:.9rem;font-weight:600;z-index:9999;opacity:0;transform:translateY(20px);transition:.3s;border-radius:0}
.toast.show{opacity:1;transform:translateY(0)}

/* ─── HOW WE RATE ─── */
.criteria-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.criteria-badge{background:#FFFFFF;border:1px solid #E5E7EB;padding:20px;text-align:center;border-radius:0}
.criteria-badge-icon{font-size:1.5rem;margin-bottom:8px}
.criteria-badge h4{font-size:.9rem;margin-bottom:4px}
.criteria-badge p{font-size:.8rem;color:#6B7280;margin-bottom:0}

/* ─── FOOTER ─── */
.site-footer{background:#F3F4F6;border-top:1px solid #E5E7EB;padding:32px 0;text-align:center}
.footer-name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1rem;color:#111827;margin-bottom:8px}
.footer-copy{font-size:.8rem;color:#6B7280;margin-bottom:12px}
.footer-disclaimer{font-size:.7rem;color:#9CA3AF;max-width:800px;margin:0 auto;line-height:1.6}

/* ─── LIGHTBOX ─── */
.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.85);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}
.lightbox-overlay.active{opacity:1;pointer-events:auto}
.lightbox-overlay img{max-width:90vw;max-height:90vh;object-fit:contain}
.lightbox-close{position:absolute;top:20px;right:24px;color:#FFFFFF;font-size:2rem;cursor:pointer;background:none;border:none;line-height:1}

/* ─── PAGE CONTENT ─── */
.page-content{width:100%}
.page-content h2,.page-content h3,.page-content h4{margin-bottom:12px;margin-top:24px}
.page-content p{margin-bottom:12px}
.page-content ul,.page-content ol{margin-bottom:12px;padding-left:20px}
.page-content li{margin-bottom:4px}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .casino-grid{grid-template-columns:repeat(2,1fr)}
  .criteria-badges{grid-template-columns:repeat(2,1fr)}
  h1{font-size:2.1rem}
}
@media(max-width:768px){
  .main-nav{display:none}
  .hamburger{display:flex}
  .hero h1{font-size:1.75rem}
  .hero.hero-home{min-height:50vh}
  .hero.hero-inner{min-height:30vh}
  .hero.hero-howwerate{min-height:35vh}
  .review-topbar{flex-direction:column;text-align:left}
  .review-topbar-cta{margin-left:0;width:100%}
  .review-topbar-cta .btn-cta{width:100%;text-align:center;display:block}
  .review-pros-cons{grid-template-columns:1fr}
  .review-pros{border-right:none;border-bottom:1px solid #E5E7EB}
  .contact-layout{grid-template-columns:1fr}
  .author-box{flex-direction:column;align-items:center;text-align:center}
  .criteria-badges{grid-template-columns:1fr}
  .section-spacing{padding:40px 0}
  .casino-grid{grid-template-columns:repeat(2,1fr);gap:16px}
}
@media(max-width:480px){
  h1{font-size:1.5rem}
  .hero-badge{font-size:.75rem;padding:6px 10px}
  .container{padding:0 16px}
}
