/*
Theme Name: Non Gamstop Mobile Casinos
Theme URI: https://nongamstopmobilecasinos.org.uk
Description: Casino affiliate theme for Non Gamstop Mobile Casinos
Author: NGMC Team
Version: 1.0.0
Text Domain: nokyc
*/

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;border-radius:0 !important}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',sans-serif;background:#0B0E18;color:#D8DAE5;line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:#FF4757;text-decoration:none;transition:color .2s}
a:hover{color:#FF6B7A}

/* === VARIABLES === */
:root{
--bg-body:#0B0E18;
--bg-surface:#131724;
--bg-surface-alt:#1A1F30;
--bg-header:#090C14;
--accent:#FF4757;
--accent-hover:#FF6B7A;
--gold:#FFAA00;
--gold-dim:#CC8800;
--green:#00C853;
--red:#FF3D3D;
--text-primary:#E8EAF0;
--text-secondary:#8890A8;
--text-muted:#5A6180;
--border:#1E2438;
--max-w:1280px;
}

/* === TYPOGRAPHY === */
h1,h2,h3,h4,h5,h6{font-family:'Space Grotesk',sans-serif;color:var(--text-primary);line-height:1.2;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}
p{margin-bottom:1rem}

/* === LAYOUT === */
.container{width:92%;max-width:var(--max-w);margin:0 auto}
.section-spacing{padding:60px 0}

/* === HEADER === */
.site-header{position:sticky;top:0;z-index:1000;background:var(--bg-header);border-bottom:2px solid var(--accent);padding:0 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.site-logo{font-family:'Space Grotesk',sans-serif;font-size:1.1rem;font-weight:700;color:var(--gold);letter-spacing:-0.02em;white-space:nowrap}
.site-logo span{color:var(--accent)}
.main-nav{display:flex;gap:28px;align-items:center}
.main-nav a{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;transition:color .2s}
.main-nav a:hover,.main-nav a.active{color:var(--accent)}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--text-primary);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;padding:2rem;flex-direction:column;gap:1.5rem}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:1.1rem;color:var(--text-primary);font-weight:500;padding:12px 0;border-bottom:1px solid var(--border)}

/* === HERO === */
.hero{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--bg-surface);border-bottom:3px solid var(--accent);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,71,87,.03) 60px,rgba(255,71,87,.03) 61px);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:800px;padding:3rem 1rem}
.hero h1{margin-bottom:1rem;text-transform:uppercase;letter-spacing:-.02em}
.hero h1 .highlight{color:var(--accent)}
.hero p{font-size:clamp(1rem,2vw,1.2rem);color:var(--text-secondary);margin-bottom:2rem}
.hero-badge{display:inline-block;background:var(--accent);color:#fff;font-family:'Space Grotesk',sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:6px 16px;margin-bottom:1.5rem}

/* Inner heroes */
.inner-hero{min-height:40vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--bg-surface);border-bottom:3px solid var(--accent);position:relative}
.inner-hero.tall{min-height:45vh}
.inner-hero-content{position:relative;z-index:1;max-width:900px;padding:3rem 1rem}
.badge-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:1.5rem}
.badge-item{background:var(--bg-surface-alt);border:1px solid var(--border);padding:10px 20px;font-family:'Space Grotesk',sans-serif;font-size:.8rem;font-weight:600;color:var(--gold);text-transform:uppercase;letter-spacing:.05em}

/* === BUTTONS === */
.btn{display:inline-block;padding:12px 28px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:all .2s;border:none;text-align:center}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);color:#fff}
.btn-gold{background:var(--gold);color:#0B0E18}
.btn-gold:hover{background:var(--gold-dim);color:#0B0E18}
.btn-outline{background:transparent;border:2px solid var(--accent);color:var(--accent)}
.btn-outline:hover{background:var(--accent);color:#fff}
.btn-sm{padding:8px 18px;font-size:.8rem}

/* === CASINO GRID === */
.casino-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.casino-card{background:var(--bg-surface);border:1px solid var(--border);overflow:hidden;transition:border-color .2s;display:flex;flex-direction:column}
.casino-card:hover{border-color:var(--accent)}
.card-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border);background:var(--bg-surface-alt)}
.card-rank{font-family:'Space Grotesk',sans-serif;font-size:1.4rem;font-weight:700;color:var(--gold);min-width:32px}
.card-logo{width:48px;height:48px;object-fit:contain;flex-shrink:0}
.card-logo-placeholder{width:48px;height:48px;border:2px dashed var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--text-muted);flex-shrink:0}
.card-name{font-family:'Space Grotesk',sans-serif;font-size:1rem;font-weight:700;color:var(--text-primary)}
.card-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:10px}
.card-stars{color:var(--gold);font-size:.9rem;letter-spacing:2px}
.card-bonus{font-size:.95rem;font-weight:600;color:var(--text-primary)}
.card-meta{font-size:.8rem;color:var(--text-secondary);line-height:1.6}
.card-meta span{display:block}
.card-badge{display:inline-block;background:var(--green);color:#000;font-size:.7rem;font-weight:700;text-transform:uppercase;padding:3px 10px;letter-spacing:.05em;margin-top:auto;align-self:flex-start}
.card-footer{padding:16px;border-top:1px solid var(--border)}
.card-footer .btn{width:100%;display:block;text-align:center}
.card-terms{font-size:.7rem;color:var(--text-muted);margin-top:6px;text-align:center}

/* === REVIEWS === */
.reviews-section{background:var(--bg-body)}
.review-block{margin-bottom:48px;border-bottom:2px solid var(--border);padding-bottom:48px}
.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(--bg-surface);border-left:4px solid var(--accent)}
.review-topbar .card-logo,.review-topbar .card-logo-placeholder{width:56px;height:56px}
.review-topbar h3{flex:1;min-width:150px}
.review-topbar .card-stars{margin-right:auto}
.review-screenshots{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.review-screenshots img{width:100%;height:220px;object-fit:cover;cursor:pointer;border:1px solid var(--border);transition:border-color .2s}
.review-screenshots img:hover{border-color:var(--accent)}
.screenshot-placeholder{width:100%;height:220px;border:2px dashed var(--text-muted);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.8rem}
.review-body{margin-bottom:24px;font-size:.95rem;line-height:1.8;color:var(--text-secondary)}
.review-body h2,.review-body h3,.review-body h4{color:var(--text-primary);margin:1.5rem 0 .75rem}
.review-body p{margin-bottom:1rem}
.review-body ul,.review-body ol{margin:0 0 1rem 1.5rem}
.review-body li{margin-bottom:.4rem}
.pros-cons-table{width:100%;border-collapse:collapse;margin-bottom:16px}
.pros-cons-table th{padding:12px 16px;text-align:left;font-family:'Space Grotesk',sans-serif;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}
.pros-cons-table th.pros-head{background:var(--green);color:#000}
.pros-cons-table th.cons-head{background:var(--red);color:#fff}
.pros-cons-table td{padding:12px 16px;vertical-align:top;width:50%;background:var(--bg-surface);border:1px solid var(--border)}
.pros-cons-table ul{list-style:none;padding:0;margin:0}
.pros-cons-table li{padding:6px 0;border-bottom:1px solid var(--border);font-size:.875rem;color:var(--text-secondary)}
.pros-cons-table li:last-child{border-bottom:none}
.pros-cons-table .pros-col li::before{content:'✓ ';color:var(--green);font-weight:700}
.pros-cons-table .cons-col li::before{content:'✗ ';color:var(--red);font-weight:700}

/* === FAQ === */
.faq-section{background:var(--bg-surface);border-top:2px solid var(--border)}
.faq-item{padding:24px 0;border-bottom:1px solid var(--border)}
.faq-item:last-child{border-bottom:none}
.faq-item h3{color:var(--gold);margin-bottom:8px;font-size:1.1rem}
.faq-item p{color:var(--text-secondary);margin:0}

/* === AUTHOR BOX === */
.author-box{background:var(--bg-surface);border:1px solid var(--border);border-left:4px solid var(--gold);padding:28px;display:flex;gap:20px;align-items:flex-start}
.author-box img{width:72px;height:72px;object-fit:cover;flex-shrink:0}
.author-box .author-name{font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--gold);margin-bottom:4px}
.author-box .author-role{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.author-box p{font-size:.9rem;color:var(--text-secondary);margin:0}

/* === CONTENT SECTIONS (plugin injected) === */
.content-section{background:var(--bg-body)}
.content-section .container{font-size:.95rem;line-height:1.8;color:var(--text-secondary)}
.content-section h2,.content-section h3,.content-section h4{color:var(--text-primary);margin:1.5rem 0 .75rem}
.content-section p{margin-bottom:1rem}
.content-section ul,.content-section ol{margin:0 0 1rem 1.5rem}
.content-section li{margin-bottom:.4rem}
.content-section table{width:100%;border-collapse:collapse;table-layout:auto;margin-bottom:1.5rem}
.content-section th,.content-section td{padding:8px 12px;text-align:left;border:1px solid var(--border)}
.content-section th{background:var(--bg-surface-alt);font-weight:600;color:var(--text-primary)}

/* === PAGE CONTENT (secondary pages) === */
.page-content{background:var(--bg-body)}
.page-content .container{font-size:.95rem;line-height:1.8;color:var(--text-secondary)}
.page-content h2,.page-content h3,.page-content h4{color:var(--text-primary);margin:1.5rem 0 .75rem}
.page-content p{margin-bottom:1rem}
.page-content ul,.page-content ol{margin:0 0 1rem 1.5rem}
.page-content li{margin-bottom:.4rem}
.page-content table{width:100%;border-collapse:collapse;table-layout:auto;margin-bottom:1.5rem}
.page-content th,.page-content td{padding:8px 12px;text-align:left;border:1px solid var(--border)}
.page-content th{background:var(--bg-surface-alt);font-weight:600;color:var(--text-primary)}

/* === TEAM GRID (About) === */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-top:2rem}
.team-member{text-align:center}
.team-member img{width:120px;height:120px;object-fit:cover;margin:0 auto 12px}
.team-member h4{font-size:1rem;margin-bottom:4px}
.team-member p{font-size:.8rem;color:var(--text-muted)}

/* === CONTACT FORM === */
.contact-form{background:var(--bg-surface);border:1px solid var(--border);padding:32px;margin-bottom:2rem}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-family:'Space Grotesk',sans-serif;font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;background:var(--bg-surface-alt);border:1px solid var(--border);color:var(--text-primary);font-family:'Inter',sans-serif;font-size:.9rem;transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}
.form-group textarea{min-height:150px;resize:vertical}
.contact-info-box{background:var(--bg-surface);border:1px solid var(--border);border-left:4px solid var(--gold);padding:24px}
.contact-info-box h3{margin-bottom:12px}
.contact-info-box p{font-size:.9rem;color:var(--text-secondary);margin-bottom:8px}
.toast{position:fixed;top:80px;right:20px;background:var(--green);color:#000;padding:16px 24px;font-weight:600;z-index:9999;transform:translateX(120%);transition:transform .3s}
.toast.show{transform:translateX(0)}

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

/* === FOOTER === */
.site-footer{background:var(--bg-header);border-top:2px solid var(--accent);padding:28px 0}
.footer-inner{text-align:center}
.footer-logo{font-family:'Space Grotesk',sans-serif;font-size:1rem;font-weight:700;color:var(--gold);margin-bottom:8px}
.footer-logo span{color:var(--accent)}
.footer-copy{font-size:.75rem;color:var(--text-muted);margin-bottom:12px}
.footer-disclaimer{font-size:.7rem;color:var(--text-muted);max-width:700px;margin:0 auto;line-height:1.6}

/* === RESPONSIVE === */
@media(max-width:1024px){
.casino-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
.main-nav{display:none}
.hamburger{display:block}
.casino-grid{grid-template-columns:repeat(2,1fr);gap:12px}
.hero{min-height:50vh}
.review-topbar{flex-direction:column;align-items:flex-start}
.review-screenshots img{height:160px}
.author-box{flex-direction:column;align-items:center;text-align:center}
.pros-cons-table th,.pros-cons-table td{padding:8px;font-size:.8rem}
}
@media(max-width:480px){
.casino-grid{grid-template-columns:repeat(2,1fr);gap:8px}
.card-header{padding:10px;gap:8px}
.card-rank{font-size:1.1rem}
.card-logo,.card-logo-placeholder{width:36px;height:36px}
.card-name{font-size:.85rem}
.card-body{padding:10px;gap:6px}
.card-bonus{font-size:.85rem}
.card-meta{font-size:.7rem}
.card-footer{padding:10px}
.btn{padding:10px 16px;font-size:.75rem}
}
