/*
Theme Name: StatMonkey
Theme URI: https://thestatmonkey.com/
Author: Pete (StatMonkey)
Author URI: https://thestatmonkey.com/
Description: A bold, sidebar-driven theme for StatMonkey: blog + projects + link hub + Codex coming soon.
Version: 1.6
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: statmonkey
Tags: blog, portfolio, dark, two-columns, custom-logo, custom-menu
*/

:root{
  --sm-bg:#0b0b0d;
  --sm-bg2:#101014;
  --sm-panel:#121217;
  --sm-panel2:#17171f;
  --sm-text:#f2f2f2;
  --sm-muted:rgba(242,242,242,.72);
  --sm-border:rgba(242,242,242,.14);
  --sm-red:#d10f16;
  --sm-red2:#ff2a2f;
  --sm-radius:14px;
  --sm-shadow:0 18px 40px rgba(0,0,0,.45);
  --sm-max:1180px;
  --sm-sidebar:320px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: radial-gradient(1200px 700px at 70% 0%, rgba(255,255,255,.06), transparent 55%),
              radial-gradient(1200px 700px at 20% 120%, rgba(209,15,22,.09), transparent 55%),
              linear-gradient(180deg, var(--sm-bg), var(--sm-bg2));
  color:var(--sm-text);
  line-height:1.5;
}
a{color:inherit; text-decoration:none}
a:hover{color:var(--sm-red2)}
img{max-width:100%; height:auto; display:block}
p{color:var(--sm-muted)}
h1,h2,h3,h4{margin:0 0 .6rem}
.container{
  display:grid;
  grid-template-columns: var(--sm-sidebar) 1fr;
  min-height:100vh;
}
.sm-skip{
  position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.sm-skip:focus{left:12px; top:12px; width:auto; height:auto; padding:.6rem .8rem; background:#000; border:1px solid var(--sm-border); border-radius:10px; z-index:9999}

/* Sidebar */
.sm-sidebar{
  position:sticky;
  top:0;
  align-self:start;
  height:100vh;
  padding:28px 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.18));
  border-right:1px solid var(--sm-border);
  overflow:auto;
}
.sm-logo{
  display:flex; justify-content:center;
  margin-bottom:18px;
}
.sm-logo .custom-logo{
  max-width:190px; /* smaller logo */
  width:100%;
  height:auto;
}
.sm-site-title{
  text-align:center;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  margin:6px 0 2px;
}
.sm-site-tagline{ text-align:center; margin:0 0 18px; font-size:.95rem; color:var(--sm-muted)}

.sm-nav ul{list-style:none; padding:0; margin:0}
.sm-nav li{margin:6px 0}
.sm-nav a{
  display:flex; gap:10px; align-items:center;
  padding:10px 12px;
  border-radius:12px;
  color:var(--sm-text);
  border:1px solid transparent;
}
.sm-nav a:hover{
  border-color:var(--sm-border);
  background:rgba(255,255,255,.03);
}
.sm-nav .current-menu-item > a,
.sm-nav .current_page_item > a{
  border-color:rgba(209,15,22,.35);
  background:rgba(209,15,22,.12);
}
.sm-sidebar-footer{
  margin-top:20px;
  padding-top:16px;
  border-top:1px solid var(--sm-border);
}
.sm-contact{
  display:grid; gap:10px;
  font-weight:700;
}
.sm-contact a{color:var(--sm-red)}
.sm-social{
  display:flex; gap:10px; margin-top:14px;
}
.sm-social a{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  padding:0;
  border-radius:12px;
  border:1px solid var(--sm-border);
  background:rgba(255,255,255,.02);
  color:var(--sm-text);
  line-height:1;
}
.sm-social svg{
  width:24px;
  height:24px;
  display:block;
}
.sm-social a:hover{border-color:rgba(209,15,22,.55); background:rgba(209,15,22,.12)}

/* Main */
.sm-main{
  padding:34px 28px 80px;
}
.sm-wrap{max-width:var(--sm-max); margin:0 auto}

/* Hero */
.sm-hero{
  position:relative;
  border:1px solid var(--sm-border);
  border-radius:22px;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(0,0,0,.12));
  box-shadow:var(--sm-shadow);
  overflow:hidden;
}
.sm-hero::after{
  content:"";
  position:absolute;
  inset:0; /* cover the hero container */
  /* Decorative burst image (replace assets/img/hero-burst.png to change).
     Image is the primary layer and set to cover so swapping the file replaces the visual fully. */
  background:
    url('assets/img/hero-burst.png') no-repeat right center / cover,
    radial-gradient(circle at 40% 40%, rgba(209,15,22,.18), transparent 60%),
    repeating-conic-gradient(from 0deg, rgba(255,255,255,.06) 0 10deg, transparent 10deg 20deg);
  filter:blur(0px);
  opacity:.55;
  transform:rotate(8deg);
  pointer-events:none;
  border-radius:22px; /* match hero container rounding */
}
 
.sm-eyebrow{
  color:var(--sm-text);
  text-transform:uppercase;
  letter-spacing:.02em;
  font-weight:950;
  font-size:clamp(2.2rem, 3vw, 3.2rem);
}
.sm-hero-title{
  font-size:clamp(2.2rem, 3vw, 3.2rem);
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.sm-hero-title span{color:var(--sm-red)}
.sm-btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 16px;
  border-radius:14px;
  background:linear-gradient(180deg, rgba(209,15,22,1), rgba(160,0,8,1));
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  width:fit-content;
}
.sm-btn:hover{filter:brightness(1.05); color:#fff}

/* Sections */
.sm-section{margin-top:26px}
.sm-section-title{
  font-size:1.8rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  font-weight:950;
  margin:0 0 14px;
}
/* Red page title variant used on Blog and Projects pages */
.sm-section-title--red{ color: var(--sm-red); }
.sm-campaign-header{margin-bottom:18px}
.sm-campaign-intro{margin-top:8px; color:var(--sm-muted); max-width:720px}
.sm-campaign-list{display:grid; gap:18px}
.sm-campaign-frame{
  border:1px solid var(--sm-border);
  border-radius:22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.22));
  box-shadow:var(--sm-shadow);
  padding:20px;
}
.sm-campaign-frame-inner{
  display:grid;
  grid-template-columns: 1fr;
  gap:18px;
  align-items:start;
}
.sm-campaign-frame--has-media .sm-campaign-frame-inner{
  grid-template-columns: minmax(0, 1.3fr) minmax(0, .7fr);
}
.sm-campaign-frame-content{min-width:0}
.sm-campaign-media{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--sm-border);
  background:rgba(0,0,0,.22);
}
.sm-campaign-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.sm-campaign-frame-header{display:grid; gap:6px}
.sm-campaign-designation{
  font-size:.95rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--sm-red);
}
.sm-campaign-title{
  font-size:1.5rem;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.04em;
  margin:0;
}
.sm-campaign-excerpt{margin:0; color:var(--sm-muted)}
.sm-campaign-content p{margin:0 0 1em; color:var(--sm-muted)}
.sm-campaign-content p:last-child{margin-bottom:0}
.sm-campaign-buttons{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:16px;
}
.sm-campaign-btn{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--sm-border);
  background:rgba(255,255,255,.04);
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.sm-campaign-btn-title{
  display:flex;
  align-items:center;
  gap:10px;
}
.sm-campaign-btn-icon{
  display:inline-flex;
  width:22px;
  height:22px;
  align-items:center;
  justify-content:center;
  flex:0 0 22px;
}
.sm-campaign-btn-icon svg{width:100%; height:100%; display:block}
.sm-campaign-btn-icon--twitch{color:#a970ff}
.sm-campaign-btn-icon--youtube{color:#ff2a2f}
.sm-campaign-btn--primary .sm-campaign-btn-icon--twitch,
.sm-campaign-btn--primary .sm-campaign-btn-icon--youtube{color:#fff}
.sm-campaign-btn:hover{filter:brightness(1.06); color:#fff}
.sm-campaign-btn--primary{
  background:linear-gradient(180deg, rgba(209,15,22,1), rgba(160,0,8,1));
  border-color:rgba(255,255,255,.12);
  color:#fff;
}
.sm-campaign-btn--dark{background:rgba(10,10,12,.6)}
.sm-campaign-btn-label{display:inline-block}
.sm-campaign-btn-system{color:var(--sm-red)}
.sm-campaign-btn--youtube_playlist_enabled{grid-column:1 / -1}
.sm-campaign-btn--game_enabled{order:4}
.sm-campaign-btn--quickstart_enabled{order:5}
.sm-campaign-btn-datetime{
  font-size:.78rem;
  text-transform:none;
  letter-spacing:0;
  color:var(--sm-muted);
  align-self:flex-end;
  text-align:right;
}
.sm-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:14px;
}
.sm-card{
  border:1px solid var(--sm-border);
  border-radius:10px;
  overflow:hidden;
  background:rgba(255,255,255,.03);
}
.sm-card-media{aspect-ratio: 16/9; background:rgba(0,0,0,.12); border-radius:10px; overflow:hidden; max-width:50%; margin:12px auto}
.sm-card .sm-card-media, .sm-grid .sm-card .sm-card-media{width:50% !important; display:block}
.sm-card-media img{width:100%; height:100%; object-fit:cover; display:block}
.sm-card-media img{width:100%; height:100%; object-fit:cover; display:block}
.sm-card-body{padding:10px 12px}
.sm-card-title{font-weight:950; text-transform:uppercase; letter-spacing:.03em}
.sm-card-meta{margin-top:8px; display:flex; gap:10px; flex-wrap:wrap; color:var(--sm-muted); font-size:.9rem}
.sm-pill{
  display:inline-block;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid var(--sm-border);
  background:rgba(0,0,0,.18);
  font-weight:800;
  font-size:.78rem;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.sm-pill--red{border-color:rgba(209,15,22,.55); background:rgba(209,15,22,.14)}

/* Blog list (alternating) */
.sm-post-list{margin-top:18px; border:1px solid var(--sm-border); border-radius:22px; overflow:hidden; background:rgba(255,255,255,.02)}
.sm-post-row{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  padding:22px;
  align-items:center;
}
.sm-post-row:nth-child(even){
  grid-template-columns: .9fr 1.1fr;
}
.sm-post-row + .sm-post-row{
  border-top:1px solid var(--sm-border);
}
.sm-post-thumb{
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.22);
}

/* Archive/blog thumbnails should span their column (full width of the
   post-row). This overrides the smaller front-page card media sizing. */
.sm-post-list .sm-post-thumb,
.sm-post-row .sm-post-thumb{width:100%; max-width:100%; margin:0}


/* Projects archive: match blog list layout */
body.post-type-archive-sm_project .sm-post-list{ width:100%; }
body.post-type-archive-sm_project .sm-post-row{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  padding:22px;
  align-items:center;
}
body.post-type-archive-sm_project .sm-post-row:nth-child(even){
  grid-template-columns: .9fr 1.1fr;
}
body.post-type-archive-sm_project .sm-post-row + .sm-post-row{
  border-top:1px solid var(--sm-border);
}
body.post-type-archive-sm_project .sm-post-thumb{
  width:100%;
  max-width:100%;
  margin:0;
}

.sm-post-content h2{
  font-size:1.6rem;
  font-weight:950;
  margin:8px 0 10px;
}
.sm-post-content .sm-post-meta{
  display:flex; gap:12px; flex-wrap:wrap; align-items:center;
  color:var(--sm-muted);
  font-size:.92rem;
  margin-top:10px;
}
.sm-readmore{margin-top:12px}
.sm-readmore .sm-btn{padding:10px 14px; border-radius:12px; font-size:.85rem}


/* Single post */
.sm-hero-inner{
  position:relative;
  z-index:2; /* ensure content sits above the decorative layers */
  padding:48px 44px;
  display:grid;
  gap:9px; /* reduced from 18px to bring eyebrow and title 50% closer */
}

/* Hero decorative layers:
   - ::after: full-cover burst image (replace assets/img/hero-burst.png to change)
   - ::before: subtle dark overlay to preserve text readability
   Both are positioned under the .sm-hero-inner content. */
.sm-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: url('assets/img/hero-burst.png') no-repeat right center / cover;
  filter: none;
  opacity: 1;
  transform: none; /* remove rotation so image aligns with hero rect */
  pointer-events: none;
  z-index: 0;
  border-radius: 22px;
}
.sm-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.36));
  z-index: 1;
  pointer-events: none;
  border-radius: 22px;
}
.sm-pagination .current{background:rgba(209,15,22,.18); border-color:rgba(209,15,22,.55)}

/* Comments */
.sm-comments{
  margin-top:26px;
  border-top:1px solid var(--sm-border);
  padding-top:22px;
}
.comment-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:16px;
}
.comment-list .children{
  list-style:none;
  margin:12px 0 0 18px;
  padding:0;
  display:grid;
  gap:12px;
}
.comment-body{
  border:1px solid var(--sm-border);
  border-radius:14px;
  background:rgba(255,255,255,.03);
  padding:14px;
}
.comment-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  color:var(--sm-muted);
  font-size:.9rem;
  margin-bottom:8px;
}
.comment-author{
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.comment-author .avatar{
  border-radius:50%;
  margin-right:8px;
}
.comment-content p{color:var(--sm-muted)}
.comment-reply-link,
.comment-edit-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:8px;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid var(--sm-border);
  background:rgba(0,0,0,.18);
  font-weight:800;
  font-size:.72rem;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.sm-comment-notes{
  color:var(--sm-muted);
  font-size:.9rem;
  margin:0 0 10px;
}
.sm-comment-form{
  display:grid;
  gap:12px;
}
.sm-comment-form label{
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:.72rem;
  color:var(--sm-muted);
  display:block;
  margin-bottom:6px;
}
.sm-comment-form input[type="text"],
.sm-comment-form input[type="email"],
.sm-comment-form input[type="url"],
.sm-comment-form textarea{
  width:100%;
  border-radius:12px;
  border:1px solid var(--sm-border);
  background:rgba(0,0,0,.22);
  color:var(--sm-text);
  padding:10px 12px;
  font:inherit;
}
.sm-comment-form textarea{
  min-height:150px;
  resize:vertical;
}
.sm-comment-form .comment-form-cookies-consent{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--sm-muted);
  font-size:.85rem;
}
.sm-comment-form .comment-form-cookies-consent label{
  text-transform:none;
  letter-spacing:0;
  margin:0;
  font-size:inherit;
}
.sm-comment-form .required{color:var(--sm-red2)}
.sm-comment-form .form-submit{margin:0}
.sm-comment-form .submit{cursor:pointer}

/* Footer */
.sm-footer{
  margin-top:28px;
  color:var(--sm-muted);
  font-size:.95rem;
  text-align:center;
}

/* Mobile */
.sm-mobilebar{
  display:none;
  position:sticky; top:0;
  z-index:999;
  background:rgba(10,10,12,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--sm-border);
  padding:10px 12px;
}
.sm-nav-scrim{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(6,6,8,.6);
  backdrop-filter: blur(2px);
  z-index:900;
}
body.sm-nav-open{overflow:hidden}
body.sm-nav-open .sm-nav-scrim{display:block}
.sm-mobilebar .sm-mobile-inner{
  display:flex; justify-content:space-between; align-items:center; gap:10px;
}
.sm-mobilebar button{
  appearance:none;
  background:rgba(255,255,255,.04);
  color:var(--sm-text);
  border:1px solid var(--sm-border);
  border-radius:12px;
  padding:10px 12px;
  font-weight:900;
}
.sm-sidebar-mobilebar{
  display:none;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:6px 0 12px;
  border-bottom:1px solid var(--sm-border);
  margin-bottom:12px;
}
.sm-sidebar-mobile-title{
  font-weight:950;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.sm-sidebar-close{
  appearance:none;
  background:rgba(255,255,255,.04);
  color:var(--sm-text);
  border:1px solid var(--sm-border);
  border-radius:12px;
  padding:8px 10px;
  font-weight:900;
}
@media (max-width: 980px){
  .container{grid-template-columns:1fr}
  .sm-sidebar{
    position:fixed;
    inset:0 auto 0 0;
    width:min(92vw, 360px);
    transform:translateX(-105%);
    transition:transform .2s ease;
    z-index:1000;
    height:100dvh;
  }
  body.sm-nav-open .sm-sidebar{transform:translateX(0)}
  .sm-main{padding:18px 14px 70px}
  .sm-mobilebar{display:block}
  .sm-sidebar-mobilebar{display:flex}
  .sm-logo{margin-bottom:10px}
  .sm-logo .custom-logo{max-width:150px}
  .sm-grid{grid-template-columns:1fr}
  .sm-post-row{grid-template-columns:1fr; gap:14px}
  .sm-post-row:nth-child(even){grid-template-columns:1fr}
  .sm-campaign-buttons{grid-template-columns:1fr}
  .sm-campaign-frame-inner{grid-template-columns:1fr}
  /* Make media full width on small screens */
  .sm-card .sm-card-media, .sm-post-thumb{width:100% !important; max-width:100%; margin:0}
}
@media (max-width: 640px){
  .sm-sidebar{
    width:100vw;
  }
}
