/*
Theme Name: Sacred Custom Theme
Theme URI: https://sacredthemanga.com
Description: A dark, manga-inspired custom WordPress theme for Sacred The Manga.
Version: 2.0.0
Author: Sacred Dev
License: GNU General Public License v2 or later
Text Domain: sacred
*/

/* ===== CSS RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --color-bg:#0d0d12;
  --color-surface:#16161f;
  --color-surface-alt:#1e1e2a;
  --color-border:#2a2a3a;
  --color-primary:#e63946;
  --color-primary-glow:rgba(230,57,70,.25);
  --color-accent:#f4a261;
  --color-text:#e8e8ec;
  --color-text-muted:#8b8b9e;
  --color-link:#f4a261;
  --font-heading:"Bebas Neue",Impact,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
  --max-width:1140px;
  --header-height:56px;
  --sidebar-width:300px;
  --radius:8px;
  --transition:0.2s ease;
}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--color-bg);
  color:var(--color-text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--color-link);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--color-primary)}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-heading);
  font-weight:700;
  line-height:1.2;
  letter-spacing:.02em;
  color:var(--color-text);
}
h1{font-size:2rem}
h2{font-size:1.6rem}
h3{font-size:1.3rem}
p{margin-bottom:1em}

/* ===== SITE HEADER ===== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(13,13,18,.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--color-border);
  height:var(--header-height);
}
.header-inner{
  max-width:var(--max-width);
  margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;height:100%;
}
.site-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.site-brand .logo-text{
  font-family:var(--font-heading);
  font-size:1.35rem;
  color:var(--color-primary);
  letter-spacing:.06em;
  text-transform:uppercase;
}
.site-brand .logo-sub{
  font-size:.7rem;
  color:var(--color-text-muted);
  text-transform:uppercase;
  letter-spacing:.1em;
}

/* Nav */
.main-nav{display:flex;align-items:center;gap:0}
.main-nav a{
  display:block;padding:0 14px;
  font-size:.82rem;font-weight:500;
  color:var(--color-text-muted);
  text-transform:uppercase;letter-spacing:.04em;
  line-height:var(--header-height);
  transition:color var(--transition),box-shadow var(--transition);
  position:relative;
}
.main-nav a:hover,.main-nav a.current{
  color:var(--color-text);
  box-shadow:inset 0 -2px 0 var(--color-primary);
}

/* Mobile menu */
.menu-toggle{
  display:none;background:none;border:none;cursor:pointer;
  width:36px;height:36px;
  position:relative;
}
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{
  display:block;width:22px;height:2px;
  background:var(--color-text);
  position:absolute;left:7px;transition:var(--transition);
}
.menu-toggle span{top:17px}
.menu-toggle span::before{content:"";top:-7px}
.menu-toggle span::after{content:"";top:7px}
.menu-toggle.active span{background:transparent}
.menu-toggle.active span::before{top:0;transform:rotate(45deg)}
.menu-toggle.active span::after{top:0;transform:rotate(-45deg)}

@media(max-width:768px){
  .menu-toggle{display:block}
  .main-nav{
    display:none;
    position:absolute;top:var(--header-height);left:0;right:0;
    background:var(--color-surface);
    flex-direction:column;
    border-bottom:1px solid var(--color-border);
    box-shadow:0 8px 24px rgba(0,0,0,.4);
  }
  .main-nav.open{display:flex}
  .main-nav a{
    line-height:48px;padding:0 20px;
    border-bottom:1px solid var(--color-border);
    width:100%;
  }
}

/* ===== LAYOUT ===== */
.site-content{
  max-width:var(--max-width);
  margin:0 auto;
  padding:30px 20px;
}
.layout-sidebar{
  display:grid;
  grid-template-columns:1fr var(--sidebar-width);
  gap:32px;
}
@media(max-width:900px){
  .layout-sidebar{grid-template-columns:1fr;gap:24px}
}

/* ===== HERO (front page) ===== */
.hero{
  background:linear-gradient(135deg,#0d0d12 0%,#1a0a12 50%,#0d0d12 100%);
  border-bottom:1px solid var(--color-border);
  padding:48px 20px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;top:-50%;left:-50%;
  width:200%;height:200%;
  background:radial-gradient(circle at 60% 40%,var(--color-primary-glow) 0%,transparent 50%);
  animation:heroGlow 8s ease-in-out infinite alternate;
}
@keyframes heroGlow{
  0%{transform:translate(0,0)}
  100%{transform:translate(-5%,5%)}
}
.hero-inner{position:relative;z-index:1;max-width:680px;margin:0 auto}
.hero h1{
  font-size:2.6rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:10px;
  background:linear-gradient(135deg,var(--color-primary),var(--color-accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero p{color:var(--color-text-muted);font-size:1.05rem;margin-bottom:24px}
.hero .btn{
  display:inline-block;
  padding:10px 28px;
  background:var(--color-primary);
  color:#fff;font-weight:600;
  border-radius:var(--radius);
  text-transform:uppercase;
  font-size:.85rem;letter-spacing:.05em;
  transition:transform var(--transition),box-shadow var(--transition);
}
.hero .btn:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px var(--color-primary-glow);
  color:#fff;
}

/* ===== CARDS / POSTS ===== */
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.post-card{
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform var(--transition),box-shadow var(--transition);
}
.post-card:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(0,0,0,.3);
}
.post-card .card-thumb{
  aspect-ratio:16/9;overflow:hidden;
  background:var(--color-surface-alt);
}
.post-card .card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.post-card:hover .card-thumb img{transform:scale(1.04)}
.post-card .card-body{padding:18px}
.post-card .card-meta{
  font-size:.75rem;color:var(--color-text-muted);
  text-transform:uppercase;letter-spacing:.05em;
  margin-bottom:8px;
}
.post-card h3{font-size:1.15rem;margin-bottom:8px}
.post-card h3 a{color:var(--color-text)}
.post-card h3 a:hover{color:var(--color-primary)}
.post-card .card-excerpt{font-size:.9rem;color:var(--color-text-muted);line-height:1.5}

/* ===== SINGLE / PAGE ===== */
.entry-header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}
.entry-header h1{font-size:2rem;margin-bottom:8px}
.entry-meta{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}
.entry-thumbnail{margin-bottom:24px;border-radius:var(--radius);overflow:hidden}
.entry-content{font-size:1rem;line-height:1.7}
.entry-content p{margin-bottom:1.2em}
.entry-content img{border-radius:var(--radius);margin:16px 0}
.entry-content blockquote{
  border-left:3px solid var(--color-primary);
  padding:12px 20px;margin:20px 0;
  background:var(--color-surface);
  border-radius:0 var(--radius) var(--radius) 0;
  color:var(--color-text-muted);font-style:italic;
}

/* ===== SIDEBAR ===== */
.sidebar .widget{
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius);
  padding:20px;margin-bottom:20px;
}
.sidebar .widget-title{
  font-family:var(--font-heading);
  font-size:1rem;text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--color-primary);
  margin-bottom:14px;padding-bottom:10px;
  border-bottom:1px solid var(--color-border);
}
.sidebar .widget ul{list-style:none}
.sidebar .widget li{
  padding:6px 0;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.sidebar .widget li:last-child{border-bottom:none}
.sidebar .widget li a{color:var(--color-text-muted);font-size:.88rem}
.sidebar .widget li a:hover{color:var(--color-text)}

/* ===== PAGINATION ===== */
.pagination{
  display:flex;justify-content:center;gap:6px;
  margin:32px 0;
}
.pagination a,.pagination span{
  display:inline-block;
  padding:8px 14px;
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius);
  font-size:.85rem;color:var(--color-text-muted);
  transition:all var(--transition);
}
.pagination a:hover{background:var(--color-surface-alt);color:var(--color-text)}
.pagination .current{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}

/* ===== FOOTER ===== */
.site-footer{
  background:var(--color-surface);
  border-top:1px solid var(--color-border);
  padding:24px 20px;
  text-align:center;
  font-size:.8rem;color:var(--color-text-muted);
}
.site-footer a{color:var(--color-accent)}
.site-footer a:hover{color:var(--color-primary)}
.footer-inner{max-width:var(--max-width);margin:0 auto}

/* ===== UTILITY ===== */
.screen-reader-text{
  clip:rect(1px,1px,1px,1px);position:absolute!important;
  height:1px;width:1px;overflow:hidden;
}
.wp-block-image img{border-radius:var(--radius)}
.alignleft{float:left;margin:0 20px 20px 0}
.alignright{float:right;margin:0 0 20px 20px}
.aligncenter{display:block;margin:0 auto 20px}
