/*
Theme Name: Illuminati FM – Premium Urban Edition
Theme URI: https://illuminati.fm
Author: Illuminati FM (Bristol, UK)
Author URI: https://www.facebook.com/IlluminatiFM
Description: Street/urban commercial theme with YouTube hero video, texture overlay toggle, mobile hero image, WooCommerce shop grid, live player, Spotify, and Sea Shepherd ticker.
Version: 2.2.0
Requires at least: 6.2
Tested up to: 6.5
Requires PHP: 8.0
Text Domain: illuminati-fm
License: GPL-2.0-or-later
*/
:root{--bg:#0b0b0b;--ink:#f1f1f1;--muted:#a1a1a1;--accent:#ff007f;--accent-2:#00f0ff;--card:#141414;--line:#222;--font-head:'Anton',Impact,sans-serif}
body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
a{color:var(--ink);text-decoration:none}
img{max-width:100%;height:auto;border-radius:12px}
.container{max-width:1200px;margin:0 auto;padding:24px}
.header,.footer{border-bottom:1px solid var(--line)}
.footer{border-top:1px solid var(--line)}
.nav{display:flex;gap:18px;color:var(--muted);flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#ffffff14;border:1px solid #ffffff22;color:#fff;font-size:12px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:12px;font-weight:700;letter-spacing:.2px;background:var(--accent);color:#000}
.btn.secondary{background:transparent;border:1px solid var(--accent-2);color:#fff}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:20px}
/* HERO */ 
.hero{position:relative;min-height:60vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-media{position:absolute;inset:0;overflow:hidden}
.hero-media img{width:100%;height:100%;object-fit:cover;filter:contrast(1.08) saturate(1.05)}
.hero-media .yt-bg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-width:177.78vh;min-height:100vh;border:0;pointer-events:none}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(1200px 600px at 80% -10%, rgba(80,80,255,.28), transparent),radial-gradient(1200px 600px at 20% 110%, rgba(255,70,70,.28), transparent)}
.hero-texture{position:absolute;inset:0;background-size:300px 300px;background-repeat:repeat;mix-blend-mode:overlay;opacity:.25;pointer-events:none}
.hero-inner{position:relative;z-index:2;padding:80px 24px;width:100%;display:flex;flex-direction:column;gap:12px}
.hero h1{font-family:var(--font-head);font-size:clamp(40px,8vw,92px);margin:0;line-height:.95;letter-spacing:.5px;text-transform:uppercase}
.hero p{color:var(--muted);font-size:clamp(16px,2.2vw,22px);max-width:780px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
.hero.align-left .hero-inner{align-items:flex-start;text-align:left}
.hero.align-center .hero-inner{align-items:center;text-align:center}
.hero.align-right .hero-inner{align-items:flex-end;text-align:right}
/* Variants / Fonts */ 
.theme-neon .badge{box-shadow:0 0 20px var(--accent)}
.theme-asphalt .hero-overlay{background:linear-gradient(180deg,#00000066,#000000cc)}
.theme-lime{--accent:#b5ff00}
.theme-violet{--accent:#9b87f5}
.font-anton{--font-head:'Anton',Impact,sans-serif}
.font-oswald{--font-head:'Oswald','Helvetica Neue',Arial,sans-serif}
.font-bebas{--font-head:'Bebas Neue',Impact,sans-serif}

/* Wrapper provides positioning and spacing */
.after-hero-with-banners{
  position: relative;
  isolation: isolate;
  padding: 32px 0;
}

/* Keep the real content above the banners */
.after-hero-with-banners > section{
  position: relative;
  z-index: 1;
}

/* Two side banners using pseudo-elements (easiest to maintain) */
.after-hero-with-banners::before,
.after-hero-with-banners::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width: max(160px, calc((100vw - var(--content-max, 1200px)) / 2));
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  opacity: 1;          /* tweak if you want them more subtle */
  pointer-events: none;
  z-index: 0;
}

.after-hero-with-banners::before{
  left:0;
  background-image: var(--left);
}

.after-hero-with-banners::after{
  right:0;
  background-image: var(--right);
}

/* Optional: hide on small screens */
@media (max-width: 1024px){
  .after-hero-with-banners::before,
  .after-hero-with-banners::after{ display:none; }
}
/* Wrapper provides positioning and spacing */
.after-hero-with-banners{
  position: relative;
  isolation: isolate;
  padding: 32px 0;
}

/* Keep the real content above the banners */
.after-hero-with-banners > section{
  position: relative;
  z-index: 1;
}

/* Two side banners using pseudo-elements (easiest to maintain) */
.after-hero-with-banners::before,
.after-hero-with-banners::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width: max(160px, calc((100vw - var(--content-max, 1200px)) / 2));
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  opacity: 1;          /* tweak if you want them more subtle */
  pointer-events: none;
  z-index: 0;
}

.after-hero-with-banners::before{
  left:0;
  background-image: var(--left);
}

.after-hero-with-banners::after{
  right:0;
  background-image: var(--right);
}

/* Optional: hide on small screens */
@media (max-width: 1024px){
  .after-hero-with-banners::before,
  .after-hero-with-banners::after{ display:none; }
}

/* WooCommerce basics */ 
.woocommerce .products{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.woocommerce .products{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.woocommerce .products{grid-template-columns:1fr}}
.product-card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px}
.product-card .price{color:var(--accent);font-weight:800}
