/*
Theme Name: Expediente
Theme URI: https://tudominio.com
Author: Reyes Montoya
Description: Tema oscuro de estética "true crime" para criminólogas. Inicio, Blog, Casos destacados y Sobre mí. Diseño tipo dossier/expediente.
Version: 1.1.0
Requires at least: 6.8
Tested up to: 6.8
Requires PHP: 8.2
License: GNU General Public License v2 or later
Text Domain: expediente
*/

:root {
  --negro: #0d0d0f;
  --carbon: #16161a;
  --carbon-2: #1e1e24;
  --hueso: #e7e3da;
  --gris: #9a968c;
  --gris-2: #6c6961;
  --sangre: #8f2d2d;
  --sangre-viva: #b23a3a;
  --linea: #2a2a30;
  --amarillo-cinta: #d8b84a;

  --display: 'Playfair Display', Georgia, serif;
  --body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: 'JetBrains Mono', 'Courier New', monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  background: var(--negro);
  color: var(--hueso);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--sangre-viva); text-decoration: none; transition: color .2s; }
a:hover { color: var(--hueso); }

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.screen-reader-text:focus {
  z-index: 1000;
  width: auto;
  height: auto;
  margin: 0;
  padding: .7rem 1rem;
  clip: auto;
  background: var(--carbon);
  color: var(--hueso);
}

.wrap { max-width: 1120px; margin: 0 auto; padding: 0 24px; }
.wrap-narrow { max-width: 720px; margin: 0 auto; padding: 0 24px; }

h1, h2, h3, h4 { font-family: var(--display); font-weight: 700; line-height: 1.15; color: var(--hueso); }
h1 { font-size: clamp(2.4rem, 6vw, 4.2rem); }
h2 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
h3 { font-size: 1.4rem; }

.eyebrow {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--sangre-viva);
  display: inline-block;
  margin-bottom: 1rem;
}

/* ---------- HEADER ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(13,13,15,.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--linea);
}
.admin-bar .site-header { top: 32px; }
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 74px;
}
.brand {
  font-family: var(--display);
  font-size: 1.5rem; font-weight: 700; font-style: italic;
  color: var(--hueso); letter-spacing: .01em;
  display: flex; align-items: center;
}
.brand span { color: var(--sangre-viva); }
.brand-logo { height: 46px; width: auto; display: block; }
.brand .custom-logo { height: 46px; width: auto; }
.nav-menu { display: flex; gap: 2rem; list-style: none; align-items: center; }
.nav-menu a {
  color: var(--gris); font-size: .82rem; letter-spacing: .12em;
  text-transform: uppercase; font-weight: 500;
}
.nav-menu a:hover, .nav-menu .current-menu-item a { color: var(--hueso); }
.nav-toggle { display: none; background: none; border: 0; color: var(--hueso); cursor: pointer; }

/* ---------- HERO ---------- */
.hero {
  position: relative;
  padding: clamp(5rem, 12vw, 9rem) 0 clamp(4rem, 8vw, 7rem);
  border-bottom: 1px solid var(--linea);
  overflow: hidden;
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(600px 400px at 80% -10%, rgba(143,45,45,.18), transparent 60%),
    repeating-linear-gradient(0deg, transparent, transparent 38px, rgba(255,255,255,.015) 38px, rgba(255,255,255,.015) 39px);
  pointer-events: none;
}
.hero-inner { position: relative; max-width: 820px; }
.hero h1 { margin: .5rem 0 1.5rem; }
.hero h1 em { color: var(--sangre-viva); font-style: italic; }
.hero p { font-size: 1.15rem; color: var(--gris); max-width: 560px; }
.hero-actions { margin-top: 2.4rem; display: flex; gap: 1rem; flex-wrap: wrap; }

.btn {
  display: inline-block; padding: .85rem 1.7rem;
  font-family: var(--mono); font-size: .78rem; letter-spacing: .12em;
  text-transform: uppercase; font-weight: 500;
  border: 1px solid var(--sangre); color: var(--hueso);
  background: var(--sangre); transition: all .2s;
}
.btn:hover { background: transparent; color: var(--hueso); border-color: var(--hueso); }
.btn-ghost { background: transparent; border-color: var(--linea); color: var(--gris); }
.btn-ghost:hover { border-color: var(--hueso); color: var(--hueso); }

/* ---------- SECTIONS ---------- */
.section { padding: clamp(4rem, 9vw, 7rem) 0; }
.section--bordered { border-top: 1px solid var(--linea); }
.section-head { margin-bottom: 3rem; }
.section-head h2 em { font-style: italic; color: var(--sangre-viva); }
.section-action { margin-top: 2.5rem; }
.empty-state { color: var(--gris); }
.archive-description {
  color: var(--gris);
  font-size: 1.05rem;
  max-width: 620px;
  margin-top: 1.4rem;
}

/* ---------- DOSSIER / CASE CARDS (signature) ---------- */
.cases-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1.5rem;
}
.case-card {
  position: relative;
  background: var(--carbon);
  border: 1px solid var(--linea);
  padding: 2rem 1.8rem 1.8rem;
  transition: border-color .25s, transform .25s;
}
.case-card::before {
  content: "EXPEDIENTE";
  position: absolute; top: 0; right: 0;
  font-family: var(--mono); font-size: .6rem; letter-spacing: .2em;
  color: var(--gris-2); background: var(--carbon-2);
  padding: .3rem .6rem; border-left: 1px solid var(--linea); border-bottom: 1px solid var(--linea);
}
.case-card:hover { border-color: var(--sangre); transform: translateY(-4px); }
.case-file { font-family: var(--mono); font-size: .7rem; color: var(--sangre-viva); letter-spacing: .1em; margin-bottom: .8rem; }
.case-card h3 { margin-bottom: .6rem; }
.case-card h3 a { color: var(--hueso); }
.case-card h3 a:hover { color: var(--sangre-viva); }
.case-meta { font-family: var(--mono); font-size: .72rem; color: var(--gris-2); margin-top: 1.2rem; padding-top: 1rem; border-top: 1px dashed var(--linea); display: flex; justify-content: space-between; }
.case-excerpt { color: var(--gris); font-size: .95rem; }

/* ---------- POST LIST (blog) ---------- */
.post-list { display: flex; flex-direction: column; gap: 0; }
.post-row {
  display: grid; grid-template-columns: 130px 1fr; gap: 2rem;
  padding: 2.2rem 0; border-bottom: 1px solid var(--linea);
  align-items: start;
}
.post-row:first-child { border-top: 1px solid var(--linea); }
.post-date { font-family: var(--mono); font-size: .72rem; color: var(--gris-2); letter-spacing: .08em; padding-top: .4rem; }
.post-row h3 { font-size: 1.55rem; margin-bottom: .6rem; }
.post-row h3 a { color: var(--hueso); }
.post-row h3 a:hover { color: var(--sangre-viva); }
.post-row .excerpt { color: var(--gris); font-size: .98rem; }
.post-tags { margin-top: .9rem; }
.tag { font-family: var(--mono); font-size: .66rem; letter-spacing: .1em; text-transform: uppercase; color: var(--gris-2); border: 1px solid var(--linea); padding: .2rem .55rem; margin-right: .4rem; }

/* ---------- SINGLE / PAGE CONTENT ---------- */
.entry-header { padding: clamp(4rem,8vw,6rem) 0 2.5rem; border-bottom: 1px solid var(--linea); }
.entry-header .meta { font-family: var(--mono); font-size: .74rem; color: var(--gris-2); letter-spacing: .1em; margin-top: 1.4rem; }
.entry-content { padding: 3rem 0; font-size: 1.08rem; }
.entry-content--flush { padding-top: 0; }
.entry-content p { margin-bottom: 1.5rem; }
.entry-content h2, .entry-content h3 { margin: 2.4rem 0 1rem; }
.entry-content h2 { color: var(--hueso); }
.entry-content blockquote {
  border-left: 3px solid var(--sangre); padding: .4rem 0 .4rem 1.6rem;
  margin: 2rem 0; font-family: var(--display); font-style: italic; font-size: 1.3rem; color: var(--hueso);
}
.entry-content ul, .entry-content ol { margin: 0 0 1.5rem 1.4rem; }
.entry-content li { margin-bottom: .5rem; }
.entry-content img { margin: 2rem 0; border: 1px solid var(--linea); }
.entry-content a { text-decoration: underline; text-underline-offset: 3px; }
.featured-media { margin: 2.5rem 0; border: 1px solid var(--linea); }
.entry-footer-nav { padding: 2.5rem 0; border-top: 1px solid var(--linea); margin-top: 2rem; }

/* ---------- ABOUT ---------- */
.about-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 4rem; align-items: start; }
.about-aside { min-width: 0; }
.about-photo { border: 1px solid var(--linea); position: relative; }
.about-photo::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 0 80px rgba(0,0,0,.6); }
.about-photo--placeholder {
  aspect-ratio: 3 / 4;
  background: var(--carbon);
  display: flex;
  align-items: center;
  justify-content: center;
}
.about-photo--placeholder span {
  font-family: var(--mono);
  font-size: .75rem;
  color: var(--gris-2);
  letter-spacing: .1em;
}
.credentials { margin-top: 2rem; list-style: none; }
.credentials li { padding: .7rem 0; border-bottom: 1px solid var(--linea); font-family: var(--mono); font-size: .82rem; color: var(--gris); display: flex; gap: .8rem; }
.credentials li::before { content: "▸"; color: var(--sangre-viva); }

/* ---------- FOOTER ---------- */
.site-footer { border-top: 1px solid var(--linea); padding: 3.5rem 0; margin-top: 2rem; }
.footer-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1.5rem; }
.footer-brand { font-family: var(--display); font-style: italic; font-size: 1.3rem; }
.footer-brand span { color: var(--sangre-viva); }
.footer-logo { height: 54px; width: auto; display: block; }
.footer-social { display: flex; gap: 1.4rem; list-style: none; margin: 0; padding: 0; font-family: var(--mono); font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; }
.footer-social li { list-style: none; }
.footer-note { font-family: var(--mono); font-size: .7rem; color: var(--gris-2); margin-top: 2rem; letter-spacing: .06em; }

/* ---------- PAGINATION ---------- */
.pagination { margin: 3rem 0; display: flex; gap: .6rem; font-family: var(--mono); font-size: .8rem; }
.pagination .page-numbers { padding: .5rem .9rem; border: 1px solid var(--linea); color: var(--gris); }
.pagination .current { background: var(--sangre); color: var(--hueso); border-color: var(--sangre); }

/* ---------- COMMENTS ---------- */
.comments-area { padding: 2rem 0; border-top: 1px solid var(--linea); }
.comments-title { margin-bottom: 1.5rem; font-size: 1.4rem; }
.comment-list { list-style: none; margin: 0; padding: 0; }
.comment-list .comment { border-bottom: 1px solid var(--linea); padding: 1.2rem 0; }
.comment-meta { font-family: var(--mono); font-size: .72rem; color: var(--gris-2); }
.comment-content { color: var(--gris); margin-top: .8rem; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 820px) {
  .nav-menu { position: fixed; inset: 74px 0 auto 0; background: var(--carbon); flex-direction: column; gap: 0; padding: 1rem 0; border-bottom: 1px solid var(--linea); display: none; }
  .nav-menu.open { display: flex; }
  .nav-menu li { width: 100%; }
  .nav-menu a { display: block; padding: 1rem 24px; }
  .nav-toggle { display: block; }
  .about-grid { grid-template-columns: 1fr; gap: 2rem; }
  .post-row { grid-template-columns: 1fr; gap: .6rem; }
  .post-date { padding-top: 0; }
}

@media (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}


/* Compact spacing patch */
.hero{padding:clamp(3.5rem,8vw,6rem) 0 clamp(2.5rem,5vw,4rem)!important;}
.section{padding:clamp(2.5rem,5vw,4rem) 0!important;}
.section-head{margin-bottom:1.5rem!important;}
.section-action{margin-top:1.25rem!important;}
.entry-header{padding:clamp(2.5rem,5vw,4rem) 0 1.25rem!important;}
.wrap > *:last-child{margin-bottom:0!important;}
@media(max-width:768px){
.hero{padding:2.8rem 0 2.5rem!important;}
.section{padding:2.25rem 0!important;}
.hero p{margin-bottom:1rem!important;}
.section-head{margin-bottom:1rem!important;}
}


.section{padding:64px 0!important;}
.home-content.section{padding-bottom:40px!important;}
.section-head{margin-bottom:32px!important;}
.section-action{margin-top:24px!important;text-align:center;}


/* Compact home spacing overrides */
.home .section{padding:2.5rem 0!important;}
.home-content.section{padding:2rem 0!important;}
.section-head{margin-bottom:1.25rem!important;}
.section-action{margin-top:1.25rem!important;}
.entry-content>*:last-child{margin-bottom:0!important;}
.entry-content>*{margin-top:0.8rem; margin-bottom:0.8rem;}
