/*
Theme Name:   AurumSpiral Child
Theme URI:    https://aurumspiral.com
Description:  Child theme de AurumSpiral basado en Twenty Twenty-Four
Author:       AurumSpiral
Author URI:   https://aurumspiral.com
Template:     twentytwentyfour
Version:      1.0.0
Text Domain:  aurumspiral-child
*/

/* ============================================================
   IMPORT PARENT THEME
   ============================================================ */
@import url("../twentytwentyfour/style.css");

/* ============================================================
   GOOGLE FONTS
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat+Alternates:wght@400;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

/* ============================================================
   CSS VARIABLES — BRAND TOKENS
   ============================================================ */
:root {
  --as-gold:        #D4AF37;
  --as-gold-light:  #E8C84A;
  --as-gold-dim:    #A88B25;
  --as-obsidian:    #0A0A0A;
  --as-graphite:    #1A1A1A;
  --as-card:        #141414;
  --as-card2:       #1e1e1e;
  --as-border:      rgba(212,175,55,0.15);
  --as-border-h:    rgba(212,175,55,0.40);
  --as-smoke:       #F5F5F5;
  --as-muted:       #7A7A7A;
  --as-font-head:   'Montserrat Alternates', sans-serif;
  --as-font-body:   'Inter', sans-serif;
}

/* ============================================================
   GLOBAL RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

body {
  background-color: var(--as-obsidian) !important;
  color: var(--as-smoke) !important;
  font-family: var(--as-font-body) !important;
  font-size: 15px;
  line-height: 1.8;
  background-image:
    linear-gradient(rgba(212,175,55,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,175,55,0.025) 1px, transparent 1px);
  background-size: 56px 56px;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6,
.wp-block-post-title,
.entry-title,
.site-title {
  font-family: var(--as-font-head) !important;
  color: var(--as-smoke) !important;
  line-height: 1.1;
  font-weight: 800;
}

h1 { font-size: clamp(32px, 4vw, 52px); }
h2 { font-size: clamp(24px, 3vw, 38px); }
h3 { font-size: clamp(18px, 2vw, 24px); }

p, li, td, th, blockquote {
  font-family: var(--as-font-body) !important;
  color: var(--as-smoke) !important;
}

a {
  color: var(--as-gold) !important;
  text-decoration: none;
  transition: color 0.2s;
}
a:hover { color: var(--as-gold-light) !important; }

/* ============================================================
   HEADER
   ============================================================ */
.wp-block-template-part[data-slug="header"],
header.wp-block-template-part,
#masthead,
.site-header,
header {
  background: rgba(10,10,10,0.95) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--as-border) !important;
  position: sticky !important;
  top: 0;
  z-index: 999;
  padding: 0 5% !important;
}

.wp-block-site-title a,
.site-title a,
.site-branding .site-title a {
  font-family: var(--as-font-head) !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--as-gold) !important;
  letter-spacing: 0.05em;
  text-decoration: none !important;
}

/* NAV MENU */
.wp-block-navigation,
.main-navigation,
nav.site-navigation {
  background: transparent !important;
}

.wp-block-navigation a,
.main-navigation a,
nav.site-navigation a {
  font-family: var(--as-font-body) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--as-muted) !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: color 0.2s !important;
  text-decoration: none !important;
}

.wp-block-navigation a:hover,
.main-navigation a:hover,
nav.site-navigation a:hover {
  color: var(--as-gold) !important;
}

/* Nav current */
.wp-block-navigation .current-menu-item > a,
.main-navigation .current-menu-item > a {
  color: var(--as-gold) !important;
}

/* ============================================================
   MAIN CONTENT AREA
   ============================================================ */
.wp-site-blocks,
.site-content,
main#primary,
main.wp-block-group {
  background: transparent !important;
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 5%;
}

/* ============================================================
   BLOG — POST CARDS (Archive / Home)
   ============================================================ */
.wp-block-post,
article.post,
article.type-post {
  background: var(--as-card) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 10px !important;
  padding: 28px !important;
  margin-bottom: 24px !important;
  transition: border-color 0.25s, transform 0.2s;
  position: relative;
  overflow: hidden;
}

.wp-block-post::before,
article.post::before,
article.type-post::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--as-gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s;
}

.wp-block-post:hover,
article.post:hover,
article.type-post:hover {
  border-color: var(--as-border-h) !important;
  transform: translateY(-2px);
}

.wp-block-post:hover::before,
article.post:hover::before,
article.type-post:hover::before {
  transform: scaleX(1);
}

/* Post title */
.wp-block-post-title,
.wp-block-post-title a,
.entry-title,
.entry-title a {
  font-family: var(--as-font-head) !important;
  font-size: clamp(18px, 2.2vw, 26px) !important;
  font-weight: 800 !important;
  color: var(--as-smoke) !important;
  line-height: 1.2 !important;
  margin-bottom: 12px !important;
}

.wp-block-post-title a:hover,
.entry-title a:hover {
  color: var(--as-gold) !important;
}

/* Post date & meta */
.wp-block-post-date,
.wp-block-post-author,
.posted-on, .byline,
.entry-meta {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--as-gold-dim) !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 10px !important;
  display: block;
}

/* Post excerpt */
.wp-block-post-excerpt,
.wp-block-post-excerpt p,
.entry-summary,
.entry-summary p {
  color: var(--as-muted) !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
}

/* Read more link */
.wp-block-post-excerpt .wp-block-post-excerpt__more-link,
.more-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 14px;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--as-gold) !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s;
}
.wp-block-post-excerpt .wp-block-post-excerpt__more-link:hover,
.more-link:hover {
  border-color: var(--as-gold);
}

/* Featured image */
.wp-block-post-featured-image img,
.post-thumbnail img {
  width: 100%;
  border-radius: 8px;
  border: 1px solid var(--as-border);
  margin-bottom: 20px;
  object-fit: cover;
}

/* Categories / tags */
.wp-block-post-terms a,
.cat-links a,
.tags-links a {
  display: inline-block;
  padding: 3px 10px;
  background: rgba(212,175,55,0.08);
  border: 1px solid var(--as-border);
  border-radius: 99px;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: var(--as-gold) !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-right: 4px;
  margin-bottom: 8px;
  transition: background 0.2s;
}
.wp-block-post-terms a:hover,
.cat-links a:hover,
.tags-links a:hover {
  background: rgba(212,175,55,0.18) !important;
}

/* ============================================================
   SINGLE POST
   ============================================================ */
.single-post article,
.single .hentry {
  background: var(--as-card) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 12px !important;
  padding: 40px !important;
  max-width: 780px;
  margin: 0 auto;
}

/* Content within single post */
.entry-content h2 {
  font-family: var(--as-font-head) !important;
  font-size: clamp(20px, 2.5vw, 30px) !important;
  color: var(--as-smoke) !important;
  margin: 36px 0 14px !important;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--as-border);
}

.entry-content h3 {
  font-family: var(--as-font-head) !important;
  font-size: 20px !important;
  color: var(--as-smoke) !important;
  margin: 28px 0 10px !important;
}

.entry-content p {
  color: rgba(245,245,245,0.85) !important;
  font-size: 15px !important;
  line-height: 1.85 !important;
  margin-bottom: 20px !important;
}

.entry-content blockquote {
  border-left: 3px solid var(--as-gold) !important;
  padding: 16px 20px !important;
  background: rgba(212,175,55,0.05) !important;
  border-radius: 0 8px 8px 0 !important;
  margin: 24px 0 !important;
}

.entry-content blockquote p {
  color: var(--as-gold) !important;
  font-style: italic;
}

.entry-content code {
  background: var(--as-card2) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 4px !important;
  padding: 2px 8px !important;
  font-size: 13px !important;
  color: var(--as-gold-light) !important;
}

.entry-content pre {
  background: var(--as-card2) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 8px !important;
  padding: 20px !important;
  overflow-x: auto;
  margin: 24px 0 !important;
}

.entry-content pre code {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  color: var(--as-smoke) !important;
}

.entry-content ul, .entry-content ol {
  padding-left: 20px !important;
  margin-bottom: 20px !important;
}

.entry-content li {
  color: rgba(245,245,245,0.85) !important;
  margin-bottom: 6px !important;
  line-height: 1.7 !important;
}

.entry-content hr {
  border: none !important;
  border-top: 1px solid var(--as-border) !important;
  margin: 36px 0 !important;
}

/* Post navigation */
.post-navigation {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 36px;
}

.nav-previous a, .nav-next a {
  display: block;
  background: var(--as-card) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 8px !important;
  padding: 16px !important;
  font-size: 13px !important;
  color: var(--as-muted) !important;
  transition: border-color 0.2s;
}

.nav-previous a:hover, .nav-next a:hover {
  border-color: var(--as-border-h) !important;
  color: var(--as-gold) !important;
}

/* ============================================================
   SIDEBAR (if exists)
   ============================================================ */
.widget-area,
aside.widget-area {
  background: transparent !important;
}

.widget {
  background: var(--as-card) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 10px !important;
  padding: 20px !important;
  margin-bottom: 20px !important;
}

.widget-title {
  font-family: var(--as-font-head) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--as-gold-dim) !important;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--as-border);
  margin-bottom: 14px !important;
}

.widget ul li {
  border-bottom: 1px solid var(--as-border) !important;
  padding: 8px 0 !important;
  color: var(--as-muted) !important;
  font-size: 13px !important;
}

.widget ul li:last-child { border: none !important; }

/* ============================================================
   SEARCH BAR
   ============================================================ */
.wp-block-search__input,
input[type="search"] {
  background: var(--as-card2) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  color: var(--as-smoke) !important;
  font-family: var(--as-font-body) !important;
  outline: none;
}

.wp-block-search__input:focus,
input[type="search"]:focus {
  border-color: var(--as-gold) !important;
  box-shadow: none !important;
}

.wp-block-search__button,
input[type="submit"],
button[type="submit"] {
  background: var(--as-gold) !important;
  color: var(--as-obsidian) !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 10px 20px !important;
  font-family: var(--as-font-body) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s;
}

.wp-block-search__button:hover,
input[type="submit"]:hover {
  background: var(--as-gold-light) !important;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.wp-block-query-pagination,
.pagination,
.page-links {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin: 40px 0;
}

.wp-block-query-pagination a,
.page-numbers,
.pagination a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--as-card) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 6px !important;
  font-size: 13px !important;
  color: var(--as-muted) !important;
  transition: all 0.2s;
}

.wp-block-query-pagination a:hover,
.page-numbers:hover,
.pagination a:hover {
  border-color: var(--as-gold) !important;
  color: var(--as-gold) !important;
  background: rgba(212,175,55,0.06) !important;
}

.wp-block-query-pagination .current,
.page-numbers.current {
  background: var(--as-gold) !important;
  border-color: var(--as-gold) !important;
  color: var(--as-obsidian) !important;
  font-weight: 700 !important;
}

/* ============================================================
   FOOTER
   ============================================================ */
.wp-block-template-part[data-slug="footer"],
footer.wp-block-template-part,
#colophon,
.site-footer,
footer {
  background: var(--as-obsidian) !important;
  border-top: 1px solid var(--as-border) !important;
  padding: 40px 5% !important;
  margin-top: 0 !important;
}

.site-info,
.site-footer .site-info,
footer p {
  font-size: 12px !important;
  color: var(--as-muted) !important;
  font-family: var(--as-font-body) !important;
}

.site-footer a {
  color: var(--as-muted) !important;
  font-size: 12px !important;
  transition: color 0.2s;
}

.site-footer a:hover {
  color: var(--as-gold) !important;
}

/* Gold line above footer */
footer::before {
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--as-gold), transparent);
  opacity: 0.3;
  margin-bottom: 32px;
}

/* ============================================================
   COMMENTS
   ============================================================ */
.comment-list li {
  background: var(--as-card2) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 8px !important;
  padding: 16px !important;
  margin-bottom: 12px !important;
}

.comment-author .fn {
  font-family: var(--as-font-head) !important;
  color: var(--as-smoke) !important;
  font-weight: 700 !important;
}

.comment-metadata a {
  color: var(--as-gold-dim) !important;
  font-size: 11px !important;
}

.comment-content p {
  color: rgba(245,245,245,0.75) !important;
  font-size: 14px !important;
}

/* Comment form */
.comment-form input,
.comment-form textarea {
  background: var(--as-card2) !important;
  border: 1px solid var(--as-border) !important;
  border-radius: 6px !important;
  color: var(--as-smoke) !important;
  padding: 10px 14px !important;
  font-family: var(--as-font-body) !important;
}

.comment-form input:focus,
.comment-form textarea:focus {
  border-color: var(--as-gold) !important;
  outline: none !important;
}

/* ============================================================
   GUTENBERG BLOCKS
   ============================================================ */
.wp-block-separator {
  border-color: var(--as-border) !important;
  opacity: 1 !important;
}

.wp-block-pullquote {
  border-top: 3px solid var(--as-gold) !important;
  border-bottom: 3px solid var(--as-gold) !important;
  padding: 24px !important;
}

.wp-block-pullquote blockquote p {
  color: var(--as-gold) !important;
  font-family: var(--as-font-head) !important;
  font-size: 20px !important;
}

.wp-block-table table {
  border-collapse: collapse;
  width: 100%;
}

.wp-block-table th {
  background: rgba(212,175,55,0.1) !important;
  color: var(--as-gold) !important;
  font-family: var(--as-font-head) !important;
  font-size: 12px !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 12px 16px !important;
  border: 1px solid var(--as-border) !important;
}

.wp-block-table td {
  padding: 10px 16px !important;
  border: 1px solid var(--as-border) !important;
  color: var(--as-smoke) !important;
  font-size: 14px !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  .wp-site-blocks,
  .site-content,
  main#primary {
    padding: 24px 4% !important;
  }

  .single-post article,
  .single .hentry {
    padding: 24px !important;
  }

  .post-navigation {
    grid-template-columns: 1fr;
  }

  header, .site-header {
    padding: 0 4% !important;
  }

  footer, .site-footer {
    padding: 28px 4% !important;
  }
}
