/*
Theme Name: Madhouse Premium Magazine
Theme URI: https://www.jasonsuli.com.au
Author: Jason Suli
Author URI: https://www.jasonsuli.com.au
Description: Premium editorial WordPress magazine theme with dynamic homepage, category strips, author blocks, related posts, featured modules, newsletter section, and blog/archive templates.
Version: 2.0
Text Domain: madhouse-premium
*/

:root{
  --bg:#050505;
  --panel:#0f0f12;
  --panel-2:#141418;
  --text:#f6f4ff;
  --muted:#a0a3b1;
  --muted-2:#6d7382;
  --accent:#CCFF00;
  --accent-dark:#a3cc00;
  --border:rgba(255,255,255,.12);
  --border-soft:rgba(255,255,255,.06);
  --light:#faf8ff;
  --dark:#000;
  --shadow:0 18px 60px rgba(0,0,0,.35);
  --container:1280px;
  --radius:0px;
  --trans:220ms ease;
  --font-headline:"Space Grotesk", sans-serif;
  --font-body:"Inter", sans-serif;
}

*,
*::before,
*::after{box-sizing:border-box}

html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--trans), opacity var(--trans), background-color var(--trans), border-color var(--trans), transform var(--trans)}
a:hover{color:var(--accent)}
button,input,textarea,select{font:inherit}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5,h6{
  margin:0 0 .65em;
  font-family:var(--font-headline);
  line-height:1.02;
  letter-spacing:-.03em;
  text-transform:uppercase;
}
p{margin:0 0 1em}
blockquote{
  margin:2rem 0;
  padding:1.5rem 1.75rem;
  border-left:4px solid var(--accent);
  background:#0d0d0f;
  color:#e8e8ef;
}
table{width:100%;border-collapse:collapse}
th,td{padding:.8rem;border-bottom:1px solid var(--border)}

.screen-reader-text{
  position:absolute!important;
  clip:rect(1px,1px,1px,1px);
  clip-path:inset(50%);
  height:1px;width:1px;overflow:hidden;white-space:nowrap
}
.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--accent);color:#000;padding:10px 14px;z-index:10000;font-weight:700
}
.skip-link:focus{left:12px;top:12px}

.container{width:min(calc(100% - 40px),var(--container));margin-inline:auto}
.narrow{width:min(calc(100% - 40px),860px);margin-inline:auto}
.section{padding:clamp(3.5rem,7vw,7rem) 0}
.section-light{background:var(--light);color:#111}
.section-border{border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft)}
.grid{display:grid;gap:1.5rem}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.magazine-grid{display:grid;grid-template-columns:2fr 1fr;gap:3rem}
.badge{
  display:inline-flex;align-items:center;gap:.7rem;
  color:var(--accent);font-size:.75rem;font-weight:800;letter-spacing:.28em;text-transform:uppercase
}
.badge::before{content:"";width:18px;height:3px;background:var(--accent);display:block}
.kicker{font-size:.74rem;font-weight:800;letter-spacing:.24em;text-transform:uppercase;color:var(--accent)}
.meta, .entry-meta{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  color:var(--muted);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em
}
.meta-dot{width:6px;height:6px;border-radius:999px;background:var(--accent)}
.btn, .wp-block-button__link, button, input[type=submit]{
  display:inline-flex;align-items:center;justify-content:center;gap:.7rem;
  padding:14px 24px;border:2px solid var(--accent);background:transparent;color:var(--accent);
  font-size:.78rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;cursor:pointer
}
.btn:hover,.wp-block-button__link:hover,button:hover,input[type=submit]:hover{background:var(--accent);color:#000}
.btn-solid{background:var(--accent);color:#000}
.btn-solid:hover{background:var(--accent-dark)}
.rule{height:1px;background:var(--border);margin:1.3rem 0}
.eyebrow{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.26em;font-weight:800}

.site-header{
  position:sticky;top:0;z-index:50;border-bottom:1px solid var(--border);
  background:rgba(0,0,0,.88);backdrop-filter:blur(18px)
}
.header-inner{
  min-height:84px;display:flex;align-items:center;justify-content:space-between;gap:2rem
}
.branding{display:flex;align-items:center;gap:1.5rem;min-width:0}
.site-title{
  font-family:var(--font-headline);font-size:clamp(1.5rem,2vw,2.2rem);font-weight:900;letter-spacing:-.05em;text-transform:uppercase
}
.site-tag{
  color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.24em;font-weight:800;border-left:1px solid var(--border);padding-left:1.2rem
}
.nav-wrap{display:flex;align-items:center;gap:1rem}
.primary-nav ul{display:flex;flex-wrap:wrap;gap:1.2rem}
.primary-nav a{
  display:inline-block;padding:.2rem 0;font-size:.75rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase
}
.primary-nav .current-menu-item > a,
.primary-nav .current_page_item > a{color:var(--accent);border-bottom:2px solid var(--accent)}
.menu-toggle{display:none}

.hero{
  position:relative;min-height:86vh;display:flex;align-items:flex-end;overflow:hidden
}
.hero-media,
.cover-media{position:absolute;inset:0}
.hero-media img,.cover-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);opacity:.58}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(0,0,0,.96), rgba(0,0,0,.48), rgba(0,0,0,.12))}
.hero-content{position:relative;z-index:2;padding:8rem 0 5rem}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(280px,.8fr);gap:3rem;align-items:end}
.hero-title{font-size:clamp(3.3rem,9vw,9rem);font-weight:900;line-height:.84;margin-bottom:.18em}
.hero-title em{font-style:italic;color:var(--accent)}
.hero-standfirst{font-size:clamp(1.12rem,2.1vw,2rem);max-width:800px;color:#ededf4;font-weight:300}
.hero-panel{
  border:1px solid var(--border);background:rgba(255,255,255,.03);padding:1.5rem;box-shadow:var(--shadow)
}
.hero-panel h3{font-size:1rem;margin-bottom:1rem}
.hero-panel .mini-list li+li{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}

.section-head{
  display:flex;align-items:end;justify-content:space-between;gap:1rem;
  margin-bottom:2rem;padding-bottom:1rem;border-bottom:4px solid currentColor
}
.section-head h2{font-size:clamp(2rem,4vw,3.6rem);margin:0}
.section-head p{margin:0;font-size:.72rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase}

.card,
.post-card{
  background:transparent;
}
.thumb{
  position:relative;overflow:hidden;background:#0e0e10
}
.thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease, filter .35s ease}
.thumb:hover img{transform:scale(1.05);filter:grayscale(0)}
.thumb-43{aspect-ratio:4/3}
.thumb-169{aspect-ratio:16/9}
.thumb-tall{aspect-ratio:3/4}
.card-title{font-size:clamp(1.2rem,2vw,1.8rem);margin:.3rem 0}
.card-excerpt{color:var(--muted-2);font-size:.98rem}
.card-number{
  font-family:var(--font-headline);font-size:3rem;font-weight:900;color:rgba(204,255,0,.26);display:block;line-height:1;margin-bottom:.2rem
}

.feature-split{
  display:grid;grid-template-columns:1.3fr .9fr;gap:3rem;align-items:start
}
.feature-main{
  border-right:1px solid var(--border);padding-right:2rem
}
.feature-main h2{font-size:clamp(2.4rem,5vw,4.7rem)}
.briefs h3{font-size:1.1rem;margin-bottom:1.4rem}
.brief-item+.brief-item{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}

.category-strip{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.25rem
}
.category-box{
  border:1px solid var(--border);padding:1.25rem;background:rgba(255,255,255,.02)
}
.category-box h3{font-size:1rem;margin:0 0 .5rem}
.category-box .count{color:var(--accent);font-weight:900;font-size:2rem;font-family:var(--font-headline)}

.case-grid{display:grid;gap:3rem}
.case-row{display:grid;grid-template-columns:1.2fr .9fr;gap:2.5rem;align-items:center}
.case-row:nth-child(even){grid-template-columns:.9fr 1.2fr}
.case-row:nth-child(even) .case-copy{order:1}
.case-row:nth-child(even) .case-media{order:2}
.case-media .thumb{height:100%;min-height:420px}
.case-copy h3{font-size:clamp(2rem,3vw,3.2rem)}

.author-block{
  display:grid;grid-template-columns:110px 1fr;gap:1.25rem;padding:1.5rem;border:1px solid var(--border);background:#0b0b0d
}
.author-avatar{
  width:110px;height:110px;border-radius:999px;overflow:hidden;background:#1b1b20
}
.author-avatar img{width:100%;height:100%;object-fit:cover}
.author-name{font-size:1.2rem;margin:0 0 .4rem}
.author-bio{color:var(--muted);margin:0}
.author-link{margin-top:.8rem;display:inline-block;font-size:.75rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}

.related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem}
.related-item{border-top:1px solid var(--border);padding-top:1rem}

.newsletter{
  background:linear-gradient(180deg, #0b0b0d, #050505);
  border:1px solid var(--border);padding:2rem
}
.newsletter-form{display:flex;gap:.8rem;flex-wrap:wrap}
.newsletter-form input{
  flex:1 1 260px;padding:1rem 1rem;border:1px solid var(--border);background:#0d0d11;color:#fff
}
.newsletter-form input::placeholder{color:#818699;text-transform:uppercase;letter-spacing:.15em;font-size:.78rem}

.logo-row{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;opacity:.32}
.logo-row span{font-family:var(--font-headline);font-size:clamp(1.6rem,2vw,2.2rem);font-weight:900}

.content-wrap{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:3rem}
.entry-content{font-size:1.08rem;color:#ececf2}
.entry-content h2{font-size:2.2rem;margin-top:2.6rem}
.entry-content h3{font-size:1.5rem;margin-top:2rem}
.entry-content a{color:var(--accent)}
.entry-content .wp-block-image,.entry-content figure{margin:1.6rem 0}
.entry-content ul,.entry-content ol{margin:0 0 1rem 1.2rem}
.entry-content li{margin:.3rem 0}
.entry-header{margin-bottom:2rem}
.entry-title{font-size:clamp(2.6rem,5.5vw,5rem)}
.archive-title{font-size:clamp(2.4rem,5vw,4.6rem)}
.archive-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem}
.pagination,.posts-navigation,.post-navigation{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.pagination .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links{display:flex;justify-content:space-between;gap:1rem}
.widget{
  border:1px solid var(--border);padding:1.2rem;background:#0b0b0d
}
.widget + .widget{margin-top:1rem}
.widget-title{
  font-size:1rem;margin:0 0 1rem;padding-bottom:.7rem;border-bottom:1px solid var(--border)
}
.widget ul li+li{margin-top:.6rem}
.search-form{display:flex;gap:.6rem}
.search-field{
  flex:1;padding:.9rem;border:1px solid var(--border);background:#0d0d11;color:#fff
}

.site-footer{border-top:1px solid var(--border);padding-top:5rem;padding-bottom:2rem}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:3rem}
.footer-title{font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:#fff;margin-bottom:1rem}
.footer-copy,.footer-menu a{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.footer-menu li+li{margin-top:.7rem}
.footer-bottom{
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.2rem;border-top:1px solid var(--border-soft)
}
.subtle{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.18em}

.comment-respond,.comments-area{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}
.comment-list{display:grid;gap:1rem}
.comment-body{padding:1rem;border:1px solid var(--border)}
.comment-meta{font-size:.8rem;color:var(--muted)}

.not-found{padding:6rem 0;text-align:center}
.not-found h1{font-size:clamp(3rem,7vw,6rem)}

@media (max-width: 1100px){
  .hero-grid,.feature-split,.case-row,.case-row:nth-child(even),.content-wrap,.footer-grid,.magazine-grid,.category-strip,.archive-grid,.related-grid,.grid-4{grid-template-columns:1fr}
  .feature-main{border-right:0;padding-right:0}
  .case-row:nth-child(even) .case-copy,.case-row:nth-child(even) .case-media{order:initial}
}
@media (max-width: 820px){
  .header-inner{min-height:72px}
  .site-tag{display:none}
  .menu-toggle{
    display:inline-flex;align-items:center;justify-content:center;padding:12px 14px;border:1px solid var(--border);background:transparent;color:#fff
  }
  .nav-wrap{position:relative}
  .primary-nav{
    display:none;position:absolute;right:0;top:calc(100% + 10px);min-width:260px;background:#08080a;border:1px solid var(--border);padding:1rem
  }
  .primary-nav.open{display:block}
  .primary-nav ul{flex-direction:column;gap:.7rem}
  .hero-content{padding:6.5rem 0 3.2rem}
  .container{width:min(calc(100% - 28px),var(--container))}
  .section{padding:3rem 0}
  .author-block{grid-template-columns:1fr}
}


/* Commercial polish additions */
:root{
  --ad-bg:#0b0b0e;
}
body.theme-light{
  --bg:#f5f3fb;
  --panel:#ffffff;
  --panel-2:#f0eef7;
  --text:#111318;
  --muted:#5c6270;
  --muted-2:#6c7280;
  --border:rgba(0,0,0,.12);
  --border-soft:rgba(0,0,0,.06);
  --light:#ffffff;
  --dark:#000;
  --shadow:0 18px 50px rgba(0,0,0,.08);
  --ad-bg:#f2f0f7;
}
.topbar{
  border-bottom:1px solid var(--border);
  background:linear-gradient(90deg, rgba(204,255,0,.12), rgba(204,255,0,.03));
}
.topbar-inner{
  min-height:42px;display:flex;align-items:center;justify-content:space-between;gap:1rem
}
.ticker{
  display:flex;align-items:center;gap:1rem;min-width:0;overflow:hidden
}
.ticker-label{
  color:var(--accent);font-size:.68rem;font-weight:900;letter-spacing:.22em;text-transform:uppercase;white-space:nowrap
}
.ticker-track{
  display:flex;gap:2rem;white-space:nowrap;will-change:transform;
  animation:madhouseTicker 28s linear infinite
}
.ticker-track a{font-size:.8rem;color:var(--muted)}
@keyframes madhouseTicker{
  0%{transform:translateX(0)}
  100%{transform:translateX(-35%)}
}
.topbar-actions{display:flex;align-items:center;gap:.8rem}
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer
}
.header-utilities{
  display:flex;align-items:center;gap:.7rem
}
.featured-tabs{
  display:grid;grid-template-columns:240px 1fr;gap:1.5rem;margin-top:1.8rem
}
.tabs-nav{
  border:1px solid var(--border);background:rgba(255,255,255,.02)
}
.tab-btn{
  width:100%;display:flex;justify-content:space-between;gap:.8rem;padding:1rem 1.1rem;
  border:0;border-bottom:1px solid var(--border);background:transparent;color:var(--text);font-weight:800;
  text-transform:uppercase;letter-spacing:.12em;cursor:pointer;text-align:left
}
.tab-btn:last-child{border-bottom:0}
.tab-btn.active{background:rgba(204,255,0,.08);color:var(--accent)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.tab-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:1.25rem}
.ad-slot{
  border:1px dashed var(--border);background:var(--ad-bg);
  display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);
  min-height:140px;padding:1rem;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:800
}
.ad-slot.tall{min-height:300px;position:sticky;top:100px}
.home-layout{
  display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:2rem
}
.editors-picks{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem
}
.split-banner{
  display:grid;grid-template-columns:1fr 1fr;gap:1.25rem
}
.promo-panel{
  border:1px solid var(--border);padding:1.5rem;background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01))
}
.promo-panel h3{font-size:1.5rem}
.floating-meta{
  display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1rem
}
.pill{
  display:inline-flex;padding:.42rem .7rem;border:1px solid var(--border);font-size:.7rem;
  font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)
}
.sticky-sidebar > * + *{margin-top:1rem}
.widget .thumb{margin-bottom:.8rem}
@media (max-width: 1100px){
  .home-layout,.featured-tabs,.tab-grid,.editors-picks,.split-banner{grid-template-columns:1fr}
  .ad-slot.tall{position:static}
}
@media (max-width: 820px){
  .topbar-inner{min-height:38px}
  .ticker-label{display:none}
  .topbar-actions .subtle{display:none}
}


/* Blog page layout */
.blog-hero{
  padding:4.5rem 0 2.25rem;
  border-bottom:1px solid var(--border);
  background:
    radial-gradient(circle at top right, rgba(204,255,0,.08), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 70%);
}
.blog-hero-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:2rem;
  align-items:end;
}
.blog-hero-copy h1{
  font-size:clamp(3rem,7vw,6rem);
  margin-bottom:.3em;
}
.blog-hero-copy p{
  color:var(--muted);
  font-size:1.05rem;
  max-width:760px;
}
.blog-featured{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:1.5rem;
  margin-top:2rem;
}
.blog-featured-main{
  border:1px solid var(--border);
  background:rgba(255,255,255,.02);
  overflow:hidden;
}
.blog-featured-main .thumb{aspect-ratio:16/9}
.blog-featured-copy{padding:1.4rem}
.blog-featured-copy h2{font-size:clamp(2rem,4vw,3.3rem)}
.blog-featured-list{
  display:grid;
  gap:1rem;
}
.blog-featured-mini{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:1rem;
  border:1px solid var(--border);
  background:rgba(255,255,255,.02);
  overflow:hidden;
}
.blog-featured-mini .thumb{height:100%}
.blog-featured-mini .thumb img{height:100%}
.blog-featured-mini-copy{padding:1rem}
.blog-filter-bar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
  margin:2rem 0 1.5rem;
  padding-bottom:1rem;
  border-bottom:1px solid var(--border);
}
.blog-filter-links{
  display:flex;
  gap:.65rem;
  flex-wrap:wrap;
}
.blog-chip{
  display:inline-flex;
  align-items:center;
  padding:.55rem .85rem;
  border:1px solid var(--border);
  font-size:.72rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--muted);
}
.blog-chip:hover,
.blog-chip.is-active{
  color:var(--accent);
  border-color:rgba(204,255,0,.35);
  background:rgba(204,255,0,.06);
}
.blog-main-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:2rem;
}
.blog-posts{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1.5rem;
}
.blog-card{
  border:1px solid var(--border);
  background:rgba(255,255,255,.02);
  overflow:hidden;
}
.blog-card .thumb{aspect-ratio:16/10}
.blog-card-copy{padding:1.2rem}
.blog-card-copy h2{
  font-size:1.55rem;
  margin-bottom:.45rem;
}
.blog-card-copy .entry-meta{
  margin:.7rem 0 .8rem;
}
.blog-sidebar-stack > * + *{margin-top:1rem}
.trending-list{
  display:grid;
  gap:1rem;
}
.trending-item{
  display:grid;
  grid-template-columns:48px 1fr;
  gap:.9rem;
  align-items:start;
}
.trending-item-number{
  font-family:var(--font-headline);
  color:rgba(204,255,0,.35);
  font-size:2rem;
  font-weight:900;
  line-height:1;
}
.blog-newsletter-compact{
  padding:1.3rem;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.blog-newsletter-compact h3{
  font-size:1.4rem;
}
.blog-newsletter-compact input{
  width:100%;
  margin:.8rem 0;
  padding:.9rem;
  border:1px solid var(--border);
  background:#0d0d11;
  color:#fff;
}
@media (max-width:1100px){
  .blog-hero-grid,.blog-featured,.blog-main-grid{grid-template-columns:1fr}
}
@media (max-width:820px){
  .blog-posts{grid-template-columns:1fr}
  .blog-featured-mini{grid-template-columns:1fr}
}
