/* public/assets/css/style.css
   DIARIO DE RECONSTRUCCIÓN - UI base (tema oscuro)

   ✅ OBJETIVO:
   - Sin estilos inline en vistas
   - Componentes reutilizables (cards, forms, tables, buttons)
   - Responsive consistente (header + admin + home)

   ✅ CAMBIO:
   - TODO lo que está debajo del header usa 80% del ancho de pantalla.
   - En pantallas grandes aumentamos el max-width para que no se vea angosto.

   ✅ DEPURACIÓN:
   - CSS limpio, sin duplicados conflictivos.
   - POST sin “columna interna”: título + meta + contenido + media = mismo ancho.
*/

/* =========================
   Variables
========================= */
:root{
  --bg:#0b0d12;
  --panel:#121623;
  --panel2:#0f1320;
  --text:#e9e9ef;
  --muted:#b7b7c6;
  --border:rgba(255,255,255,.12);
  --shadow: 0 12px 40px rgba(0,0,0,.35);
  --link:#75acff;
  --link2:#287eff;

  --ok: rgba(16,185,129,.20);
  --okBorder: rgba(16,185,129,.35);

  --danger: rgba(239,68,68,.18);
  --dangerBorder: rgba(239,68,68,.35);

  /* ✅ Contenedor global: 80% pantalla */
  --containerW: 80vw;
  --containerMax: 1280px;
  --containerWideMax: 1400px;
}

/* =========================
   Reset / Base
========================= */
*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background:
    radial-gradient(1200px 600px at 20% 0%, rgba(124,58,237,.20), transparent 55%),
    radial-gradient(900px 500px at 80% 10%, rgba(167,139,250,.14), transparent 55%),
    var(--bg);
  color:var(--text);
  line-height:1.55;
}

a{color:var(--link);text-decoration:none}
a:hover{color:var(--link2);text-decoration:underline}

.small{font-size:.92rem}
.muted{opacity:.82}

code{
  background:rgba(0,0,0,.25);
  border:1px solid var(--border);
  padding:2px 6px;
  border-radius:8px;
}

/* =========================
   ✅ Contenedores globales
   - 80% debajo del header
========================= */
.container{
  width: min(var(--containerW), var(--containerMax));
  margin: 0 auto;
  padding: 22px;
}

.container-wide{
  width: min(var(--containerW), var(--containerWideMax));
  margin: 0 auto;
  padding: 22px;
}

@media (max-width: 900px){
  .container,
  .container-wide{padding:18px}
}
@media (max-width: 520px){
  .container,
  .container-wide{padding:14px}
}

/* ✅ Pantallas grandes: aumenta max-width */
@media (min-width: 1536px){
  :root{
    --containerMax: 1440px;
    --containerWideMax: 1560px;
  }
}
@media (min-width: 1920px){
  :root{
    --containerMax: 1600px;
    --containerWideMax: 1760px;
  }
}

/* =========================
   Header Logo Control
========================= */
.logo-header{
  height:38px;
  width:auto;
  max-width:180px;
  object-fit:contain;
  display:block;
}

/* =========================
   Topbar
========================= */
.topbar{
  position:sticky;
  top:0;
  backdrop-filter: blur(8px);
  background: rgba(10,12,18,.70);
  border-bottom:1px solid var(--border);
  padding:0;
  z-index:10;
}

/* Header compacto (sin inflar altura) */
.topbar .container{
  padding-top:10px;
  padding-bottom:10px;
}
@media (max-width: 520px){
  .topbar .container{
    padding-top:8px;
    padding-bottom:8px;
  }
}

.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}

.brand{
  font-weight:900;
  letter-spacing:.5px;
  color:var(--text);
  white-space:nowrap;
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.nav{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

/* Link-like button */
.inline{display:inline;margin:0}
.linklike{
  background:none;
  border:0;
  color:var(--link);
  cursor:pointer;
  padding:0;
  font:inherit;
  opacity:.95;
}
.linklike:hover{color:var(--link2);text-decoration:underline}

/* =========================
   Nav pills
========================= */
.nav a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  line-height:1;
  white-space:nowrap;
  text-decoration:none;
  color: rgba(255,255,255,.86);
  font-size:.92rem;
}
.nav a:hover{
  color:#fff;
  background: rgba(255,255,255,.06);
  text-decoration:none;
}

.nav form.inline{display:inline-flex;margin:0}
.nav button.linklike{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  line-height:1;
  white-space:nowrap;
  font:inherit;
  cursor:pointer;
  color: rgba(255,255,255,.86);
}
.nav button.linklike:hover{
  color:#fff;
  background: rgba(255,255,255,.06);
  text-decoration:none;
}

/* =========================
   Layout
========================= */
main.container{
  padding-top:28px;
  padding-bottom:40px;
  flex:1;
}

h1,h2,h3{margin:0 0 14px 0;line-height:1.18}
h1{font-size:clamp(1.65rem, 3.6vw, 2.2rem)}
h2{font-size:clamp(1.35rem, 3.0vw, 1.9rem)}

.card{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  box-shadow: var(--shadow);
}

.stack{display:flex;flex-direction:column;gap:12px}
.toolbar{display:flex;gap:10px;align-items:center;margin-top:12px}
.toolbar--wrap{flex-wrap:wrap}

hr{border:0;border-top:1px solid var(--border);margin:18px 0}

/* =========================
   Alerts / Flash
========================= */
.alert{
  padding:11px 12px;
  border-radius:12px;
  margin:12px 0;
  border:1px solid var(--border);
  font-weight:700;
  letter-spacing:.2px;
}
.alert.success{
  background: var(--ok);
  border-color: var(--okBorder);
  color:#ffffff;
  text-shadow: 0 1px 0 rgba(0,0,0,.35);
}
.alert.error{
  background: var(--danger);
  border-color: var(--dangerBorder);
  color:#ffffff;
  text-shadow: 0 1px 0 rgba(0,0,0,.35);
}

/* =========================
   Buttons
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  padding:10px 14px;
  cursor:pointer;
  font-weight:800;
  color:var(--text);
  background: rgba(167,139,250,.16);
}
.btn:hover{background: rgba(167,139,250,.22)}
.btn--primary{background: rgba(167,139,250,.22); border-color: rgba(167,139,250,.35)}
.btn--primary:hover{background: rgba(167,139,250,.28)}
.btn--ghost{background: rgba(255,255,255,.04)}
.btn--ghost:hover{background: rgba(255,255,255,.07)}
.btn--success{background: rgba(16,185,129,.18); border-color: rgba(16,185,129,.35)}
.btn--success:hover{background: rgba(16,185,129,.24)}
.btn--danger{background: rgba(239,68,68,.16); border-color: rgba(239,68,68,.35)}
.btn--danger:hover{background: rgba(239,68,68,.22)}
.btn--mini{padding:8px 10px;border-radius:10px;font-weight:800;font-size:.92rem}

/* =========================
   Forms
========================= */
.form{display:grid;gap:12px;margin-top:12px}
.form-grid{display:grid;gap:12px;grid-template-columns: 1fr 1fr}
.field{display:flex;flex-direction:column;gap:6px}
.field--sm{grid-column: span 1}
.field--full{grid-column: 1 / -1}
.field-help{font-size:.92rem; color:rgba(255,255,255,.70)}
.field-error{font-size:.92rem; color:#fecaca; font-weight:700}

label{color:var(--muted);font-size:.95rem}

.input,.select,.textarea{
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background: rgba(0,0,0,.28);
  color:var(--text);
  outline:none;
}
.textarea{
  resize: vertical;
  min-height: 220px;
}
.input:focus,.select:focus,.textarea:focus{
  border-color: rgba(167,139,250,.55);
  box-shadow: 0 0 0 3px rgba(167,139,250,.18);
}

/* =========================
   Tables (Admin)
========================= */
.table-wrap{overflow:auto;-webkit-overflow-scrolling: touch}
.table{width:100%;border-collapse:collapse}
.table th, .table td{
  padding:10px;
  border-bottom:1px solid rgba(255,255,255,.12);
  vertical-align:top;
}
.table th{color:rgba(255,255,255,.85);text-align:left;font-size:.95rem}
.w-id{width:70px}
.w-state{width:120px}
.w-actions{width:190px}
.row-actions{display:flex;gap:10px;flex-wrap:wrap}

.badge{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  font-weight:800;
  font-size:.9rem;
}
.badge--success{background: rgba(16,185,129,.16); border-color: rgba(16,185,129,.35)}
.badge--muted{background: rgba(255,255,255,.05)}

/* =========================
   Filters (Admin)
========================= */
.filters{display:flex;gap:12px;align-items:end;flex-wrap:wrap}
.filters__actions{display:flex;gap:10px;align-items:center}

/* =========================
   Pagination
========================= */
.pagination{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:18px;
  flex-wrap:wrap;
}

/* =========================
   Home cards
========================= */
.post-card{transition: transform .12s ease, background .12s ease, border-color .12s ease}
.post-card:hover{transform: translateY(-1px);border-color: rgba(167,139,250,.28)}

.post-card__title{margin:0 0 8px;font-weight:900;letter-spacing:.2px}
.post-card__title a{
  text-decoration:none;
  display:-webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
.post-card__meta{margin:0 0 10px;color: rgba(255,255,255,.70);font-size:.92rem}
.post-card__excerpt{
  margin:0;
  color: rgba(255,255,255,.82);
  overflow-wrap:anywhere;
  word-break: break-word;
  display:-webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:hidden;
}

/* =========================
   Empty state
========================= */
.empty{
  border:1px dashed rgba(255,255,255,.22);
  border-radius:14px;
  padding:18px;
  background: rgba(0,0,0,.14);
}

/* =========================
   Account
========================= */
.account-card{max-width:560px;margin:0 auto}
.account-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.account-row:last-child{border-bottom:0}
.account-label{color:rgba(255,255,255,.75);font-weight:800}
.account-value{color:var(--text);font-weight:700}

/* =========================
   Comments (público)
========================= */
.c-box{
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:14px;
  margin:14px 0;
  background:rgba(0,0,0,.18);
}
.c-box__title{margin-top:0}

.c-honeypot{
  position:absolute !important;
  left:-9999px !important;
  top:-9999px !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
  opacity:0 !important;
}

.c-grid{display:grid;grid-template-columns: 1fr 1fr;gap:12px}
.c-field label{display:block;margin-bottom:6px;color:#cbd5e1;font-size:.95rem}
.c-field input{
  width:100%;
  padding:10px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.25);
  color:#fff;
  border-radius:10px;
}
.c-field--full{margin-top:12px}
.c-field textarea{
  width:100%;
  padding:10px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.25);
  color:#fff;
  border-radius:10px;
  resize:vertical;
}
.c-muted{color:#9ca3af;font-size:.9rem;margin:6px 0 0}

.c-btn{
  margin-top:12px;
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(124,58,237,.25);
  color:#fff;
  border-radius:10px;
  cursor:pointer;
  font-weight:800;
}
.c-btn:hover{background:rgba(124,58,237,.35)}

.c-list{display:flex;flex-direction:column;gap:12px;margin-top:10px}
.c-comment{
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:12px;
  background:rgba(0,0,0,.16);
}
.c-comment__head{display:flex;justify-content:space-between;gap:10px;color:#e5e7eb}
.c-comment__head span{color:#9ca3af;font-size:.95rem}
.c-comment__body{margin-top:8px;white-space:pre-wrap;line-height:1.6;color:#e5e7eb}

/* Admin comment cell */
.comment-cell{min-width:320px}
.comment-body{white-space:pre-wrap;line-height:1.5}

/* =========================
   Footer
========================= */
.footer{
  border-top:1px solid var(--border);
  background: rgba(10,12,18,.92);
  backdrop-filter: blur(8px);
  display:flex;
  position:relative;
  z-index:2;
}
.footer .container{padding:12px 0}
.footer small{opacity:.75}

.footer .container.footer__inner{
  padding:14px 0;
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:center;
  text-align:center;
}

.footer__links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
}

.footer__links a{
  color: rgba(255,255,255,.78);
  text-decoration:none;
  font-size:.92rem;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.footer__links a:hover{
  color:#fff;
  background: rgba(255,255,255,.06);
  text-decoration:none;
}

/* =========================
   Post Media (imagen / video)
========================= */
.post-media-grid{
  margin:18px 0;
  display:grid;
  gap:16px;
  align-items:start;
}
.post-media-grid--one{max-width:50%;margin-left:auto;margin-right:auto}
.post-media-grid--two{grid-template-columns: 1fr}
@media (min-width: 860px){
  .post-media-grid--two{grid-template-columns: 1fr 1fr}
}

.post-media__frame{
  border:1px solid var(--border);
  border-radius:16px;
  background: rgba(0,0,0,.22);
  box-shadow: var(--shadow);
  aspect-ratio: 16 / 9;
  display:flex;
  align-items:stretch;
  overflow:hidden; /* ✅ evita artefactos raros */
}

.post-media__img{
  width:100%;
  height:100%;
  object-fit:contain;
  background:rgba(0,0,0,.55);
  display:block;
  border-radius:16px;
}

.video-embed{position:relative;width:100%;height:100%}
.video-embed iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  display:block;
}

/* =========================
   ✅ POST (LIMPIO y CONSISTENTE)
   - Sin max-width internos que creen “columnita”
========================= */
.post{max-width:100%}
.post__head{max-width:100%}

/* Si quieres centrar título/meta, cambia a center */
.post__head--center{ text-align:left; }

.post__title{
  max-width:100%;
}

/* Meta consistente */
.post__meta{
  margin-top:2px;
  color: rgba(255,255,255,.80);
}

/* Contenido:
   - El “espacio entre párrafos” se controla con margin-bottom del p.
   - line-height controla el espaciado dentro de una línea, no entre párrafos.
*/
.post__content{
  max-width:90%;
  margin:0;

  white-space: normal;
  overflow-wrap:anywhere;
  word-break: break-word;

  font-size: 1.05rem;
  line-height: 1.6; /* valor estable: no “baila” */
}

/* ✅ AQUÍ ajustas el espacio entre párrafos */
.post__content p{
  margin: 0 0 5px 0;
}
.post__content p:last-child{margin-bottom:0}

/* =========================
   Admin - Post Cover
========================= */
.h2-tight{margin-top:0}
.post-cover-card{margin-bottom:18px}

}

/* === FIX CENTRADO portada (admin) === */
/* Centra el título y el bloque de portada dentro de la card */
.post-cover-card{
  text-align:center;
}

/* Centra SIEMPRE la imagen aunque haya reglas encima */
.post-cover-card .post-cover-preview{
  display:flex !important;
  justify-content:center !important;
}

/* Mantén tu tamaño actual (30%) y que no se rompa */
.post-cover-card .post-cover-img{
  width:30% !important;        /* mantiene el tamaño que querías */
  max-width:760px;
  height:auto;
  display:block;
  margin:0 auto;              /* extra por si flex no aplica */
}

/* =========================
   Responsive: Topbar / Menú
========================= */
@media (max-width: 900px){
  .topbar__inner{
    flex-wrap:wrap;
    gap:12px;
    padding: 0 16px;
  }
  .brand{
    flex:1 1 100%;
    justify-content:center;
  }
  .nav{
    flex:1 1 100%;
    justify-content:center;
    gap:8px;
  }
}
@media (max-width: 430px){
  .nav a,
  .nav button.linklike{
    font-size:13px;
    padding:7px 10px;
  }
}

/* =========================
   Responsive: Forms / Comments
========================= */
@media (max-width: 760px){
  .form-grid{grid-template-columns:1fr}
  .c-grid{grid-template-columns:1fr}
}

/* =========================
   Responsive: Admin tables (móvil)
========================= */
@media (max-width: 820px){
  .filters{align-items:stretch}
  .filters .field{width:100%}
  .filters__actions{width:100%;justify-content:flex-start}
  .table{min-width: 760px}
  .row-actions{gap:8px}
  .btn--mini{padding:9px 10px}
}
@media (max-width: 520px){
  .btn{width:100%}
  .row-actions .btn{width:auto}
}

/* =========================
   Legal pages
========================= */
.page-legal .legal{
  max-width: 820px;
  margin: 0 auto;
  padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--shadow);
}
.page-legal .legal h1{margin: 0 0 12px 0}
.page-legal .legal h2{
  margin: 22px 0 10px 0;
  font-size: 1.1rem;
  color: rgba(255,255,255,.88);
}
.page-legal .legal p{margin: 10px 0;color: rgba(255,255,255,.86)}
.page-legal .legal ul{margin: 10px 0 10px 20px;padding:0}
.page-legal .legal li{margin: 6px 0;color: rgba(255,255,255,.84)}
.page-legal .legal strong{color: rgba(255,255,255,.92)}

.page-legal .contact-email{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(167,139,250,.10);
  font-weight:900;
  letter-spacing:.2px;
  margin:8px 0 4px;
}
.page-legal .contact-email::before{content:"✉️";opacity:.9}

@media (max-width: 520px){
  .page-legal .legal{padding:14px}
}

/* =========================
   FIX: evitar “imagenes gigantes” en home/post
========================= */
main img{
  max-width:100%;
  height:auto;
  display:block;
}
.post-cover-img{max-width:100%;height:auto}

.hero-img{
  width:100%;
  max-width:980px;
  margin:0 auto 18px;
  border-radius:16px;
  overflow:hidden;
}
.hero-img img{
  width:100%;
  height:auto;
  max-height:260px;
  object-fit:contain;
}

/* =========================
   FIX: Logo del header (forzado)
========================= */
.topbar .brand .logo-header{
  height: 42px !important;
  max-height: 42px !important;
  width: auto !important;
  max-width: 220px;
  display:block !important;
  object-fit:contain;
}
@media (max-width: 520px){
  .topbar .brand .logo-header{
    height: 32px !important;
    max-height: 32px !important;
    max-width: 180px;
  }
}