/*
Theme Name: CineTerror
Theme URI: http://joanwebsite.local
Description: Portal de cine de terror. Tema oscuro que muestra las entradas según su "Tipo de entrada" (noticia, crítica, criticaYoutube, estreno, tráiler). Requiere ACF y el mu-plugin cineterror-campos.
Author: CineTerror
Version: 1.0.0
Requires at least: 6.2
Requires PHP: 7.4
Text Domain: cineterror
*/

/* ===== Reset / base ===== */
*,*::before,*::after{box-sizing:border-box}
:root{
  --bg:#09090b;        /* zinc-950 */
  --card:#18181b;      /* zinc-900 */
  --card2:#1f1f23;
  --border:#27272a;    /* zinc-800 */
  --red:#dc2626;       /* red-600 */
  --red-hover:#ef4444; /* red-500 */
  --red-dark:#7f1d1d;  /* red-900 */
  --text:#fafafa;
  --muted:#9ca3af;     /* gray-400 */
  --muted2:#d1d5db;    /* gray-300 */
  --max:1280px;
}
/* ===== Modo claro ===== */
html.light{
  --bg:#f4f4f5;
  --card:#ffffff;
  --card2:#f0f0f2;
  --border:#e4e4e7;
  --text:#18181b;
  --muted:#52525b;
  --muted2:#3f3f46;
}
html.light body{color:var(--text)}
html.light .empty-note{color:var(--muted)}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{margin:0;line-height:1.2}
.container{max-width:var(--max);margin:0 auto;padding:0 1rem}

/* ===== Header ===== */
.site-header{
  position:relative;
  background:linear-gradient(to bottom,#000 0%,#18181b 50%,#000 100%);
  border-bottom:1px solid var(--red-dark);
  overflow:hidden;
}
.site-header::before{content:"";position:absolute;inset:0;background:#000;opacity:.4;z-index:0}
.site-header__inner{position:relative;z-index:1;padding:1.5rem 1rem}
.site-brand{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}
.site-brand__icon-img{height:88px;width:auto;filter:drop-shadow(0 0 14px rgba(220,38,38,.45))}
.site-brand__letras{height:64px;width:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}
.site-brand__tagline{display:block;text-align:center;color:#9ca3af;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:1rem}
.main-nav{display:flex;gap:1.75rem;justify-content:center;align-items:center;flex-wrap:wrap}
.main-nav a{
  color:#d1d5db;text-transform:uppercase;font-size:.8rem;font-weight:600;letter-spacing:.08em;
  transition:color .2s;padding:.25rem 0;border-bottom:2px solid transparent;
}
.main-nav a:hover{color:var(--red-hover);border-bottom-color:var(--red)}

/* Logo responsive: en móvil solo el icono */
@media(max-width:640px){
  .site-brand__icon-img{height:64px}
  .site-brand__letras{display:none}
}
/* En pantallas medianas, icono algo menor */
@media(min-width:641px) and (max-width:900px){
  .site-brand__icon-img{height:72px}
  .site-brand__letras{height:52px}
}

/* ===== Botón modo claro/oscuro ===== */
.theme-toggle{
  width:38px;height:38px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.06);border:1px solid var(--border);
  color:#fff;font-size:1.05rem;line-height:1;
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;
  transition:background .2s,border-color .2s,transform .2s;
}
.theme-toggle:hover{background:var(--red);border-color:var(--red);transform:scale(1.05)}
.theme-toggle__moon{display:none}
html.light .theme-toggle__sun{display:none}
html.light .theme-toggle__moon{display:inline}

/* ===== Botón hamburguesa (oculto en escritorio) ===== */
.nav-toggle{display:none;position:absolute;top:1.25rem;left:1rem;z-index:3;
  width:42px;height:42px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.06);border:1px solid var(--border);
  align-items:center;justify-content:center;transition:background .2s,border-color .2s}
.nav-toggle:hover{background:var(--red);border-color:var(--red)}
.nav-toggle__bars,.nav-toggle__bars::before,.nav-toggle__bars::after{
  content:"";display:block;width:20px;height:2px;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s}
.nav-toggle__bars{position:relative}
.nav-toggle__bars::before{position:absolute;top:-6px;left:0}
.nav-toggle__bars::after{position:absolute;top:6px;left:0}
body.ct-nav-open .nav-toggle__bars{background:transparent}
body.ct-nav-open .nav-toggle__bars::before{transform:translateY(6px) rotate(45deg)}
body.ct-nav-open .nav-toggle__bars::after{transform:translateY(-6px) rotate(-45deg)}

/* ===== Cabecera y pie en modo claro ===== */
html.light .site-header{background:linear-gradient(to bottom,#ffffff,#ececed,#ffffff);border-bottom-color:#e4e4e7}
html.light .site-header::before{opacity:0}
html.light .site-brand__tagline{color:#52525b}
html.light .main-nav a{color:#3f3f46}
html.light .theme-toggle,html.light .nav-toggle{color:#18181b;background:rgba(0,0,0,.05);border-color:#d4d4d8}
html.light .nav-toggle__bars,html.light .nav-toggle__bars::before,html.light .nav-toggle__bars::after{background:#18181b}
html.light .theme-toggle:hover,html.light .nav-toggle:hover{background:var(--red);border-color:var(--red);color:#fff}
html.light .site-footer{background:#ececed;border-top-color:#e4e4e7}
html.light .site-footer__inner{color:#52525b}

/* ===== Responsive: menú hamburguesa al bajar la resolución ===== */
@media(max-width:768px){
  .site-header__inner{padding-top:1rem}
  .nav-toggle{display:flex}
  .theme-toggle{position:static;width:auto;height:auto;border-radius:.5rem;padding:.5rem .9rem;gap:.4rem}
  .theme-toggle::after{content:"Modo claro / oscuro";font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
  .main-nav{display:none;flex-direction:column;align-items:center;gap:1rem;
    margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);width:100%}
  body.ct-nav-open .main-nav{display:flex}
  .main-nav a{font-size:.95rem;padding:.35rem 0}
}

/* ===== Layout ===== */
.site-main{padding:2.5rem 0}
.layout{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:1024px){.layout{grid-template-columns:minmax(0,2.4fr) minmax(0,1fr)}}

/* ===== Section heading ===== */
.section-title{
  font-size:1.6rem;font-weight:800;margin-bottom:1.25rem;
  display:flex;align-items:center;gap:.5rem;
  border-left:4px solid var(--red);padding-left:.75rem;
}
.section + .section{margin-top:3rem}

/* ===== Card base ===== */
.card{
  display:block;
  background:var(--card);border:1px solid var(--border);border-radius:.75rem;overflow:hidden;
  transition:transform .3s,border-color .3s,box-shadow .3s;
}
.card:hover{transform:translateY(-4px);border-color:var(--red-dark);box-shadow:0 10px 30px rgba(0,0,0,.6)}
.card__media{position:relative;overflow:hidden}
.card__media img{width:100%;object-fit:cover;transition:transform .5s}
.card:hover .card__media img{transform:scale(1.08)}
.card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,#000,transparent 60%);opacity:.6}
.badge{
  position:absolute;top:1rem;left:1rem;z-index:2;
  background:var(--red);color:#fff;padding:.25rem .75rem;border-radius:999px;
  font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
}
.card__body{padding:1.25rem}
.card__title{font-size:1.15rem;font-weight:800;margin-bottom:.5rem;transition:color .3s}
.card:hover .card__title{color:var(--red-hover)}
.card__excerpt{color:var(--muted);font-size:.9rem;margin-bottom:.85rem}
.card__meta{display:flex;gap:1rem;align-items:center;color:var(--muted);font-size:.78rem;flex-wrap:wrap}
.card__meta .dot{width:4px;height:4px;border-radius:50%;background:var(--red)}

/* ===== Featured ===== */
.featured{display:block;position:relative;border-radius:.85rem;overflow:hidden;margin-bottom:2.5rem;border:1px solid var(--border)}
.featured img{display:block;width:100%;height:500px;object-fit:cover}
.featured__overlay{position:absolute;inset:0;background:linear-gradient(to top,#000 5%,rgba(0,0,0,.4) 50%,transparent)}
.featured__content{position:absolute;left:0;right:0;bottom:0;padding:2rem;display:flex;flex-direction:column;align-items:flex-start}
.featured__badge{display:inline-block;background:var(--red);color:#fff;padding:.3rem .9rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.85rem}
.featured__title{display:block;font-size:2rem;font-weight:900;margin-bottom:.6rem;max-width:46ch}
.featured__excerpt{display:block;color:var(--muted2);max-width:60ch;margin-bottom:.75rem}
.featured__meta{display:flex;gap:1rem;align-items:center;color:var(--muted);font-size:.82rem}
@media(max-width:640px){.featured img{height:340px}.featured__title{font-size:1.4rem}}

/* ===== News grid ===== */
.news-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.news-grid{grid-template-columns:1fr 1fr}}
.news-grid .card__media img{height:220px}

/* ===== Reviews ===== */
.review-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.review-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1280px){.review-grid{grid-template-columns:1fr 1fr 1fr}}
.review-grid .card__media img{height:190px}
.review__head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.4rem}
.nota{
  display:inline-flex;align-items:center;gap:.2rem;background:var(--red);color:#fff;
  padding:.2rem .55rem;border-radius:.4rem;font-weight:800;font-size:.85rem;white-space:nowrap;
}
.nota::before{content:"★";font-size:.8em}

/* ===== Videos ===== */
.video-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.video-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1280px){.video-grid{grid-template-columns:1fr 1fr 1fr}}
.video-grid .card__media img{height:180px}
.video__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;background:rgba(0,0,0,0);transition:background .3s}
.card:hover .video__play{background:rgba(0,0,0,.55)}
.video__play span{width:54px;height:54px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;opacity:.9;transform:scale(.9);transition:transform .3s}
.card:hover .video__play span{transform:scale(1)}
.video__play span::before{content:"";border-left:16px solid #fff;border-top:10px solid transparent;border-bottom:10px solid transparent;margin-left:4px}
.video__duration{position:absolute;bottom:.6rem;right:.6rem;z-index:2;background:rgba(0,0,0,.85);color:#fff;font-size:.72rem;font-weight:700;padding:.15rem .5rem;border-radius:.3rem}
.video__views{color:var(--muted);font-size:.78rem}

/* ===== Sidebar ===== */
.sidebar{display:flex;flex-direction:column;gap:1.5rem}
.widget{background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem}
.widget__title{font-size:1.15rem;font-weight:800;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.widget__title .ic{color:var(--red)}
.wlist{display:flex;flex-direction:column}
.wlist > *{display:flex;gap:.75rem;padding:.7rem 0;border-bottom:1px solid var(--border)}
.wlist > *:last-child{border-bottom:0;padding-bottom:0}
.wlist > *:first-child{padding-top:0}
.estreno__date{color:var(--red-hover);font-size:.8rem;font-weight:700}
.estreno__title{font-weight:600;font-size:.92rem}
.trailer-item{align-items:center}
.trailer-item .yt{color:var(--red);font-size:1.1rem}
.trailer-item:hover .estreno__title{color:var(--red-hover)}
.ranked{counter-reset:r}
.ranked > a{align-items:center}
.ranked > a::before{
  counter-increment:r;content:counter(r);
  flex:0 0 auto;width:2rem;height:2rem;border-radius:.4rem;background:var(--card2);border:1px solid var(--border);
  color:var(--red);font-weight:900;display:flex;align-items:center;justify-content:center;font-size:1rem;
}
.ranked > a:hover{color:var(--red-hover)}
.ultima-critica{display:flex;gap:.85rem;align-items:center}
.ultima-critica img{width:64px;height:64px;border-radius:.5rem;object-fit:cover;flex:0 0 auto}
.social{display:flex;gap:.6rem;flex-wrap:wrap}
.social a{flex:1;text-align:center;background:var(--card2);border:1px solid var(--border);border-radius:.5rem;padding:.55rem;font-size:.8rem;font-weight:600;transition:background .2s,color .2s}
.social a:hover{background:var(--red);color:#fff;border-color:var(--red)}

/* ===== Footer ===== */
.site-footer{border-top:1px solid var(--red-dark);background:#000;margin-top:3rem}
.site-footer__inner{padding:2rem 1rem;text-align:center;color:var(--muted);font-size:.85rem}
.site-footer__inner strong{color:var(--red-hover)}

/* ===== Single post ===== */
.single-wrap{max-width:820px;margin:0 auto}
.single-wrap .entry-title{font-size:2.2rem;font-weight:900;margin-bottom:1rem}
.single-wrap .entry-meta{color:var(--muted);font-size:.85rem;margin-bottom:1.5rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.single-wrap .entry-thumb{border-radius:.75rem;overflow:hidden;margin-bottom:1.5rem}
.single-wrap .entry-content{color:var(--muted2);font-size:1.05rem}
.single-wrap .entry-content p{margin:0 0 1.1rem}
.single-wrap .entry-content a{color:var(--red-hover);text-decoration:underline}
.embed-yt{position:relative;padding-bottom:56.25%;height:0;margin:1.5rem 0;border-radius:.75rem;overflow:hidden}
.embed-yt iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.back-link{display:inline-block;margin-bottom:1.5rem;color:var(--muted);font-size:.85rem}
.back-link:hover{color:var(--red-hover)}
.empty-note{color:var(--muted);background:var(--card);border:1px dashed var(--border);border-radius:.6rem;padding:1rem;font-size:.9rem}
