/*
Theme Name: Non Gamstop Slots UK
Theme URI: https://nongamstopslotsuk.org.uk
Author: NonGamstopSlotsUK
Description: Casino affiliate theme for Non Gamstop Slots UK
Version: 1.0.0
Text Domain: nongamstop-slots
*/

/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg-body:#0A0E17;
  --bg-card:#131825;
  --bg-card-hover:#1A2030;
  --bg-header:#080C14;
  --bg-hero:#0D1220;
  --bg-section-alt:#0F1423;
  --color-gold:#F7C948;
  --color-red:#E8363C;
  --color-red-hover:#FF4A50;
  --color-green:#22C55E;
  --color-cons:#EF4444;
  --color-white:#FFFFFF;
  --color-text:#D1D5DE;
  --color-muted:#7A8299;
  --color-border:#1E2536;
  --color-badge:#1C2333;
  --font-heading:'Space Grotesk',sans-serif;
  --font-body:'Inter',sans-serif;
  --max-width:1280px;
  --radius:0px;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg-body);color:var(--color-text);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-gold);text-decoration:none}
a:hover{color:var(--color-white)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-white);line-height:1.2;font-weight:700}
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}

/* ── HEADER ── */
.site-header{position:sticky;top:0;z-index:1000;background:var(--bg-header);border-bottom:1px solid var(--color-border);padding:0 24px}
.header-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}
.site-logo{font-family:var(--font-heading);font-size:1.15rem;font-weight:800;color:var(--color-gold);letter-spacing:-0.5px;white-space:nowrap}
.site-logo span{color:var(--color-white)}
.main-nav{display:flex;gap:32px;align-items:center}
.main-nav a{font-size:0.875rem;font-weight:500;color:var(--color-muted);transition:color .2s}
.main-nav a:hover,.main-nav a.active{color:var(--color-white)}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--color-white);margin:5px 0;transition:all .3s}
.mobile-nav{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;background:var(--bg-header);z-index:999;flex-direction:column;padding:32px 24px;gap:24px}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:1.125rem;color:var(--color-text);font-weight:500}
.mobile-nav a:hover{color:var(--color-gold)}

/* ── HERO ── */
.hero{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--bg-hero);padding:80px 24px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 50% 0%,rgba(247,201,72,0.06) 0%,transparent 70%);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:800px}
.hero h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:20px;letter-spacing:-1px}
.hero h1 .highlight{color:var(--color-gold)}
.hero p{font-size:clamp(1rem,2vw,1.25rem);color:var(--color-muted);margin-bottom:36px;max-width:640px;margin-left:auto;margin-right:auto}
.hero-inner{min-height:40vh}
.hero-inner-tall{min-height:45vh}

/* ── BUTTONS ── */
.btn{display:inline-block;padding:14px 32px;font-family:var(--font-heading);font-weight:700;font-size:0.9rem;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px}
.btn-primary{background:var(--color-red);color:var(--color-white)}
.btn-primary:hover{background:var(--color-red-hover);color:var(--color-white)}
.btn-gold{background:var(--color-gold);color:#0A0E17}
.btn-gold:hover{background:#FFD666;color:#0A0E17}
.btn-outline{background:transparent;border:2px solid var(--color-gold);color:var(--color-gold)}
.btn-outline:hover{background:var(--color-gold);color:#0A0E17}
.btn-sm{padding:10px 20px;font-size:0.8rem}

/* ── BADGE ── */
.badge{display:inline-block;background:var(--color-badge);color:var(--color-gold);padding:6px 16px;font-size:0.75rem;font-weight:600;border-radius:var(--radius);border:1px solid var(--color-border);letter-spacing:0.5px;text-transform:uppercase}
.badge-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:24px}

/* ── SECTION SPACING ── */
.section-spacing{padding:80px 0}
.section-heading{font-size:clamp(1.5rem,3vw,2.25rem);margin-bottom:12px}
.section-sub{color:var(--color-muted);font-size:1rem;margin-bottom:48px}

/* ── CASINO GRID ── */
.casino-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.casino-card{background:var(--bg-card);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s;display:flex;flex-direction:column}
.casino-card:hover{border-color:var(--color-gold)}
.casino-card-header{padding:20px 20px 12px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--color-border)}
.casino-card-logo{width:56px;height:56px;object-fit:contain;flex-shrink:0;background:#fff;border-radius:var(--radius)}
.casino-card-info{flex:1;min-width:0}
.casino-card-rank{font-size:0.7rem;color:var(--color-gold);font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.casino-card-name{font-size:1rem;font-weight:700;color:var(--color-white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.casino-card-body{padding:16px 20px;flex:1;display:flex;flex-direction:column;gap:8px}
.casino-card-bonus{font-size:0.9rem;font-weight:600;color:var(--color-gold)}
.casino-card-meta{font-size:0.78rem;color:var(--color-muted);display:flex;flex-wrap:wrap;gap:6px 16px}
.casino-card-meta span{white-space:nowrap}
.casino-card-stars{color:var(--color-gold);font-size:0.85rem;letter-spacing:1px}
.casino-card-badge{font-size:0.7rem;color:var(--color-green);font-weight:600;margin-top:auto;padding-top:4px}
.casino-card-footer{padding:12px 20px 20px}
.casino-card-footer .btn{width:100%;text-align:center}
.casino-card-terms{font-size:0.65rem;color:var(--color-muted);margin-top:8px;text-align:center}

/* ── REVIEW BLOCKS ── */
.review-block{margin-bottom:60px;border-bottom:1px solid var(--color-border);padding-bottom:60px}
.review-block:last-child{border-bottom:none}
.review-topbar{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:32px;padding:24px;background:var(--bg-card);border:1px solid var(--color-border);border-radius:var(--radius)}
.review-topbar-logo{width:64px;height:64px;object-fit:contain;background:#fff;border-radius:var(--radius);flex-shrink:0}
.review-topbar-info{flex:1;min-width:200px}
.review-topbar-info h3{font-size:1.5rem;margin-bottom:4px}
.review-topbar-stars{color:var(--color-gold);font-size:1rem;letter-spacing:1px}
.review-topbar .btn{margin-left:auto}
.review-screenshots{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}
.review-screenshot{cursor:pointer;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius);aspect-ratio:16/9}
.review-screenshot img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.review-screenshot:hover img{transform:scale(1.03)}
.review-body{margin-bottom:32px;font-size:0.95rem;line-height:1.8}
.review-body h2,.review-body h3,.review-body h4{margin:24px 0 12px;color:var(--color-white)}
.review-body p{margin-bottom:16px}
.review-body ul,.review-body ol{margin:0 0 16px 24px}

/* ── PROS/CONS TABLE ── */
.pros-cons-table{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;margin-bottom:24px}
.pros-col,.cons-col{padding:24px}
.pros-col{background:rgba(34,197,94,0.06);border-right:1px solid var(--color-border)}
.cons-col{background:rgba(239,68,68,0.06)}
.pros-col h4{color:var(--color-green);font-size:0.85rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}
.cons-col h4{color:var(--color-cons);font-size:0.85rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}
.pros-col li,.cons-col li{list-style:none;padding:6px 0;font-size:0.875rem;padding-left:20px;position:relative}
.pros-col li::before{content:'✓';position:absolute;left:0;color:var(--color-green);font-weight:700}
.cons-col li::before{content:'✗';position:absolute;left:0;color:var(--color-cons);font-weight:700}

/* ── FAQ ── */
.faq-item{margin-bottom:32px}
.faq-item h3{font-size:1.1rem;margin-bottom:8px;color:var(--color-white)}
.faq-item p{color:var(--color-text);font-size:0.925rem}

/* ── AUTHOR BOX ── */
.author-box{display:flex;gap:24px;align-items:flex-start;padding:32px;background:var(--bg-card);border:1px solid var(--color-border);border-radius:var(--radius)}
.author-box img{width:80px;height:80px;object-fit:cover;border-radius:var(--radius);flex-shrink:0}
.author-box-info h4{font-size:1rem;margin-bottom:4px}
.author-box-info .role{font-size:0.8rem;color:var(--color-gold);margin-bottom:8px}
.author-box-info p{font-size:0.875rem;color:var(--color-muted)}

/* ── CONTENT SECTION ── */
.content-section{background:var(--bg-section-alt);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}
.content-section .container{padding-top:0;padding-bottom:0}
.content-section h2,.content-section h3{color:var(--color-white);margin:24px 0 12px}
.content-section p{margin-bottom:16px}
.content-section ul,.content-section ol{margin:0 0 16px 24px}

/* ── INNER PAGE CONTENT ── */
.page-content{padding:60px 0}
.page-content h2,.page-content h3{margin:28px 0 12px}
.page-content p{margin-bottom:16px}
.page-content ul,.page-content ol{margin:0 0 16px 24px}
.page-content img{margin:16px 0}

/* ── TEAM GRID ── */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin:40px 0}
.team-member{background:var(--bg-card);border:1px solid var(--color-border);padding:24px;text-align:center;border-radius:var(--radius)}
.team-member img{width:100px;height:100px;object-fit:cover;border-radius:var(--radius);margin:0 auto 16px}
.team-member h4{font-size:0.95rem;margin-bottom:4px}
.team-member p{font-size:0.8rem;color:var(--color-muted)}

/* ── CONTACT FORM ── */
.contact-form{background:var(--bg-card);border:1px solid var(--color-border);padding:40px;border-radius:var(--radius);max-width:640px}
.contact-form label{display:block;font-size:0.85rem;font-weight:600;color:var(--color-white);margin-bottom:6px}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;padding:12px 16px;background:var(--bg-body);border:1px solid var(--color-border);color:var(--color-white);font-family:var(--font-body);font-size:0.9rem;border-radius:var(--radius);margin-bottom:20px;transition:border-color .2s}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--color-gold)}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-info-box{background:var(--bg-card);border:1px solid var(--color-border);padding:32px;border-radius:var(--radius);margin-top:32px}
.contact-info-box h4{margin-bottom:16px}
.contact-info-box p{font-size:0.9rem;color:var(--color-muted);margin-bottom:8px}
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}

/* ── CRITERIA BADGES ── */
.criteria-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.criteria-badge{background:var(--bg-card);border:1px solid var(--color-border);padding:20px;text-align:center;border-radius:var(--radius)}
.criteria-badge .icon{font-size:1.8rem;margin-bottom:8px}
.criteria-badge h4{font-size:0.85rem;color:var(--color-white);margin-bottom:4px}
.criteria-badge p{font-size:0.75rem;color:var(--color-muted)}

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

/* ── TOAST ── */
.toast{position:fixed;bottom:32px;right:32px;background:var(--color-green);color:#fff;padding:16px 28px;font-weight:600;font-size:0.9rem;border-radius:var(--radius);z-index:10000;transform:translateY(100px);opacity:0;transition:all .3s}
.toast.show{transform:translateY(0);opacity:1}

/* ── FOOTER ── */
.site-footer{background:var(--bg-header);border-top:1px solid var(--color-border);padding:40px 24px;text-align:center}
.footer-name{font-family:var(--font-heading);font-weight:700;color:var(--color-gold);font-size:1rem;margin-bottom:8px}
.footer-copy{font-size:0.78rem;color:var(--color-muted);margin-bottom:12px}
.footer-disclaimer{font-size:0.7rem;color:var(--color-muted);max-width:800px;margin:0 auto;line-height:1.6;opacity:0.7}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .casino-grid{grid-template-columns:repeat(2,1fr)}
  .criteria-grid{grid-template-columns:repeat(2,1fr)}
  .contact-layout{grid-template-columns:1fr}
}
@media(max-width:768px){
  .main-nav{display:none}
  .hamburger{display:block}
  .hero{min-height:50vh;padding:60px 24px}
  .hero h1{font-size:1.75rem}
  .casino-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .casino-card-header{padding:14px 14px 10px;gap:10px}
  .casino-card-logo{width:40px;height:40px}
  .casino-card-name{font-size:0.85rem}
  .casino-card-body{padding:12px 14px}
  .casino-card-bonus{font-size:0.8rem}
  .casino-card-meta{font-size:0.7rem}
  .casino-card-footer{padding:10px 14px 14px}
  .review-topbar{flex-direction:column;text-align:left}
  .review-topbar .btn{margin-left:0;width:100%;text-align:center}
  .pros-cons-table{grid-template-columns:1fr}
  .pros-col{border-right:none;border-bottom:1px solid var(--color-border)}
  .author-box{flex-direction:column}
  .criteria-grid{grid-template-columns:1fr 1fr}
  .section-spacing{padding:48px 0}
  .review-screenshots{grid-template-columns:1fr}
}
@media(max-width:480px){
  .casino-grid{gap:10px}
  .casino-card-body{gap:6px}
  .btn{padding:12px 20px;font-size:0.8rem}
}
