/*
Theme Name: Best Non Gamstop Casinos
Theme URI: https://best-nongamstopcasinos.gb.net
Author: Best Non Gamstop Casinos Team
Description: Casino affiliate theme for non-Gamstop casino reviews.
Version: 1.0.0
Text Domain: best-nongamstopcasinos
*/

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --clr-bg:#0f1923;
  --clr-surface:#162330;
  --clr-surface-alt:#1c2e3f;
  --clr-accent:#e8b20e;
  --clr-accent-hover:#f5c518;
  --clr-cta:#e8b20e;
  --clr-cta-hover:#f5c518;
  --clr-cta-text:#0f1923;
  --clr-text:#d1d9e0;
  --clr-heading:#ffffff;
  --clr-muted:#7a8fa0;
  --clr-border:#243447;
  --clr-green:#22c55e;
  --clr-red:#ef4444;
  --clr-star:#e8b20e;
  --clr-badge:#1a5c3a;
  --clr-badge-text:#22c55e;
  --ff-heading:'Space Grotesk',sans-serif;
  --ff-body:'Inter',sans-serif;
  --max-w:1280px;
  --radius:0px;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);background:var(--clr-bg);color:var(--clr-text);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--clr-accent);text-decoration:none}
a:hover{color:var(--clr-accent-hover)}
h1,h2,h3,h4,h5,h6{font-family:var(--ff-heading);color:var(--clr-heading);font-weight:700;line-height:1.2}
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px}

/* ===== HEADER ===== */
.site-header{position:sticky;top:0;z-index:1000;background:var(--clr-surface);border-bottom:2px solid var(--clr-accent);padding:0 24px}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--max-w);margin:0 auto;height:64px}
.site-logo{font-family:var(--ff-heading);font-size:1.15rem;font-weight:700;color:var(--clr-accent);letter-spacing:-0.02em}
.site-logo span{color:var(--clr-heading)}
.main-nav{display:flex;gap:28px;list-style:none}
.main-nav a{color:var(--clr-text);font-size:.875rem;font-weight:500;letter-spacing:.01em;transition:color .2s}
.main-nav a:hover,.main-nav a.active{color:var(--clr-accent)}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--clr-heading);margin:5px 0;transition:all .3s}
.mobile-nav{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;background:var(--clr-surface);z-index:999;padding:32px 24px;flex-direction:column;gap:0}
.mobile-nav.open{display:flex}
.mobile-nav a{color:var(--clr-text);font-size:1.1rem;padding:16px 0;border-bottom:1px solid var(--clr-border);display:block}
.mobile-nav a:hover{color:var(--clr-accent)}

/* ===== HERO ===== */
.hero{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--clr-surface);padding:80px 24px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(255,255,255,.015) 60px,rgba(255,255,255,.015) 61px);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:800px}
.hero h1{font-size:clamp(2rem,5vw,3.2rem);margin-bottom:20px;color:var(--clr-heading)}
.hero h1 .highlight{color:var(--clr-accent)}
.hero p{font-size:clamp(1rem,2vw,1.2rem);color:var(--clr-muted);margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}
.btn-primary{display:inline-block;background:var(--clr-cta);color:var(--clr-cta-text);font-family:var(--ff-heading);font-weight:700;font-size:.95rem;padding:14px 36px;border-radius:var(--radius);border:none;cursor:pointer;transition:background .2s,transform .1s;text-transform:uppercase;letter-spacing:.05em}
.btn-primary:hover{background:var(--clr-cta-hover);color:var(--clr-cta-text);transform:translateY(-1px)}
.btn-sm{padding:10px 20px;font-size:.85rem}

/* Inner hero */
.inner-hero{min-height:40vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--clr-surface);padding:60px 24px;position:relative}
.inner-hero.tall{min-height:45vh}
.inner-hero h1{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:16px}
.inner-hero p{color:var(--clr-muted);font-size:1.05rem;max-width:600px;margin:0 auto 24px}
.badges{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:20px}
.badge-item{background:var(--clr-surface-alt);border:1px solid var(--clr-border);padding:10px 20px;font-size:.85rem;color:var(--clr-accent);font-weight:600;border-radius:var(--radius)}

/* ===== SECTION SPACING ===== */
.section-spacing{padding:64px 0}
.section-heading{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:12px;text-align:left}
.section-subheading{color:var(--clr-muted);margin-bottom:40px;text-align:left;font-size:1rem}

/* ===== CASINO GRID ===== */
.casino-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.casino-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s}
.casino-card:hover{border-color:var(--clr-accent)}
.card-rank{position:absolute;top:12px;left:12px;background:var(--clr-accent);color:var(--clr-cta-text);font-family:var(--ff-heading);font-weight:700;font-size:.75rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);z-index:2}
.card-top{position:relative;padding:24px 20px 16px;display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--clr-surface-alt)}
.card-logo{width:100px;height:60px;object-fit:contain;margin-bottom:12px}
.card-name{font-size:1rem;font-weight:700;color:var(--clr-heading);margin-bottom:6px}
.card-stars{color:var(--clr-star);font-size:.9rem;letter-spacing:1px;margin-bottom:4px}
.card-rating{font-size:.8rem;color:var(--clr-muted)}
.card-badge{display:inline-block;background:var(--clr-badge);color:var(--clr-badge-text);font-size:.7rem;font-weight:600;padding:3px 10px;margin-top:8px;border-radius:var(--radius)}
.card-body{padding:16px 20px;flex:1;display:flex;flex-direction:column;gap:8px}
.card-meta{font-size:.8rem;color:var(--clr-muted);display:flex;justify-content:space-between}
.card-meta span{display:block}
.card-bonus{font-size:.95rem;font-weight:700;color:var(--clr-accent);margin-bottom:4px}
.card-footer{padding:0 20px 20px;margin-top:auto}
.card-cta{display:block;text-align:center;background:var(--clr-cta);color:var(--clr-cta-text);font-family:var(--ff-heading);font-weight:700;font-size:.85rem;padding:12px;border-radius:var(--radius);text-transform:uppercase;letter-spacing:.04em;transition:background .2s}
.card-cta:hover{background:var(--clr-cta-hover);color:var(--clr-cta-text)}
.card-terms{font-size:.65rem;color:var(--clr-muted);text-align:center;margin-top:8px}

/* ===== REVIEW BLOCKS ===== */
.review-block{margin-bottom:56px;padding-bottom:56px;border-bottom:1px solid var(--clr-border)}
.review-block:last-child{border-bottom:none}
.review-topbar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:24px;padding:20px;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius)}
.review-topbar .card-logo{width:80px;height:48px;margin-bottom:0}
.review-topbar-info{flex:1}
.review-topbar-info h3{font-size:1.3rem;margin-bottom:4px}
.review-topbar-info .card-stars{margin-bottom:0}
.review-topbar .btn-primary{margin-left:auto;white-space:nowrap}
.review-screenshots{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.review-screenshots img{width:100%;height:220px;object-fit:cover;border:1px solid var(--clr-border);border-radius:var(--radius);cursor:pointer;transition:opacity .2s}
.review-screenshots img:hover{opacity:.85}
.review-body{margin-bottom:24px;line-height:1.8;font-size:.95rem;color:var(--clr-text)}
.review-body h2,.review-body h3,.review-body h4{margin:20px 0 12px;color:var(--clr-heading)}
.review-body p{margin-bottom:14px}
.review-body ul,.review-body ol{margin:0 0 14px 20px}

/* Pros/Cons Table */
.pros-cons-table{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--clr-border);border-radius:var(--radius);overflow:hidden}
.pros-col,.cons-col{padding:20px}
.pros-col{background:rgba(34,197,94,.06)}
.cons-col{background:rgba(239,68,68,.06);border-left:1px solid var(--clr-border)}
.pros-col h4,.cons-col h4{font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;display:flex;align-items:center;gap:6px}
.pros-col h4{color:var(--clr-green)}
.cons-col h4{color:var(--clr-red)}
.pros-col ul,.cons-col ul{list-style:none;padding:0}
.pros-col li,.cons-col li{font-size:.85rem;padding:6px 0;position:relative;padding-left:20px}
.pros-col li::before{content:'✓';position:absolute;left:0;color:var(--clr-green);font-weight:700}
.cons-col li::before{content:'✗';position:absolute;left:0;color:var(--clr-red);font-weight:700}

/* ===== FAQ ===== */
.faq-item{margin-bottom:28px}
.faq-item h3{font-size:1.05rem;color:var(--clr-heading);margin-bottom:8px}
.faq-item p{color:var(--clr-text);font-size:.92rem;line-height:1.7}

/* ===== AUTHOR BOX ===== */
.author-box{display:flex;gap:20px;padding:28px;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius)}
.author-avatar{width:72px;height:72px;object-fit:cover;border-radius:var(--radius);flex-shrink:0}
.author-info h4{font-size:1rem;color:var(--clr-heading);margin-bottom:4px}
.author-info .author-role{font-size:.8rem;color:var(--clr-accent);margin-bottom:8px}
.author-info p{font-size:.85rem;color:var(--clr-muted);line-height:1.6}

/* ===== CONTENT SECTION (plugin injected) ===== */
.content-section{background:var(--clr-surface-alt)}
.content-section .container{max-width:var(--max-w)}
.content-section h2,.content-section h3{color:var(--clr-heading);margin:20px 0 12px}
.content-section p{margin-bottom:14px;line-height:1.8}
.content-section ul,.content-section ol{margin:0 0 14px 20px}

/* ===== ABOUT PAGE ===== */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:32px}
.team-card{background:var(--clr-surface);border:1px solid var(--clr-border);padding:24px;text-align:center;border-radius:var(--radius)}
.team-card img{width:100px;height:100px;object-fit:cover;border-radius:var(--radius);margin:0 auto 16px}
.team-card h3{font-size:1rem;margin-bottom:4px}
.team-card p{font-size:.85rem;color:var(--clr-muted)}

/* ===== CONTACT PAGE ===== */
.contact-form-wrap{max-width:640px}
.contact-form .form-group{margin-bottom:20px}
.contact-form label{display:block;font-size:.85rem;color:var(--clr-heading);margin-bottom:6px;font-weight:500}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;background:var(--clr-surface-alt);border:1px solid var(--clr-border);color:var(--clr-text);font-family:var(--ff-body);font-size:.9rem;padding:12px 14px;border-radius:var(--radius);transition:border-color .2s}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--clr-accent)}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-info-box{background:var(--clr-surface);border:1px solid var(--clr-border);padding:28px;border-radius:var(--radius);margin-top:32px}
.contact-info-box h3{font-size:1.1rem;margin-bottom:12px}
.contact-info-box p{font-size:.85rem;color:var(--clr-muted);margin-bottom:8px}
.toast{position:fixed;bottom:32px;right:32px;background:var(--clr-green);color:#fff;padding:14px 24px;border-radius:var(--radius);font-size:.9rem;font-weight:600;z-index:9999;opacity:0;transform:translateY(20px);transition:all .3s}
.toast.show{opacity:1;transform:translateY(0)}

/* ===== PAGE CONTENT ===== */
.page-content{line-height:1.8;font-size:.95rem}
.page-content h2{font-size:1.5rem;margin:28px 0 14px}
.page-content h3{font-size:1.2rem;margin:24px 0 12px}
.page-content p{margin-bottom:14px}
.page-content ul,.page-content ol{margin:0 0 14px 24px}
.page-content table{width:100%;border-collapse:collapse;margin:20px 0}
.page-content table th,.page-content table td{padding:10px 14px;border:1px solid var(--clr-border);text-align:left;font-size:.85rem}
.page-content table th{background:var(--clr-surface-alt);color:var(--clr-heading);font-weight:600}

/* ===== LIGHTBOX ===== */
.lightbox-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);z-index:9999;align-items:center;justify-content:center;cursor:pointer}
.lightbox-overlay.active{display:flex}
.lightbox-overlay img{max-width:90vw;max-height:90vh;object-fit:contain}

/* ===== FOOTER ===== */
.site-footer{background:var(--clr-surface);border-top:1px solid var(--clr-border);padding:32px 24px;text-align:center}
.footer-name{font-family:var(--ff-heading);font-weight:700;color:var(--clr-accent);font-size:1rem;margin-bottom:8px}
.footer-copy{font-size:.75rem;color:var(--clr-muted);margin-bottom:12px}
.footer-disclaimer{font-size:.7rem;color:var(--clr-muted);max-width:800px;margin:0 auto;line-height:1.5}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .casino-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .hamburger{display:block}
  .main-nav{display:none}
  .hero{min-height:50vh;padding:60px 24px}
  .review-topbar{flex-direction:column;text-align:center}
  .review-topbar .btn-primary{margin-left:0;width:100%}
  .review-screenshots img{height:160px}
  .pros-cons-table{grid-template-columns:1fr}
  .cons-col{border-left:none;border-top:1px solid var(--clr-border)}
  .author-box{flex-direction:column;text-align:center;align-items:center}
  .inner-hero{min-height:30vh}
  .inner-hero.tall{min-height:35vh}
}
@media(max-width:480px){
  .casino-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .card-top{padding:16px 12px 12px}
  .card-logo{width:72px;height:44px}
  .card-name{font-size:.85rem}
  .card-body{padding:12px}
  .card-bonus{font-size:.85rem}
  .card-meta{flex-direction:column;gap:4px}
  .card-footer{padding:0 12px 12px}
  .section-spacing{padding:40px 0}
}
