/*
Theme Name: softQrate
Theme URI: https://softqrate.com
Author: softQrate
Author URI: https://softqrate.com
Description: Tema corporativo softQrate para blog y páginas estáticas. Hereda navbar y footer del sitio principal, con tipografía y paleta consistentes. Pensado para que el blog se sienta parte natural de softqrate.com.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: softqrate
Tags: blog, business, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* =========================================
   1. Variables y reset
   ========================================= */
:root {
  --sq-ink:        #0E1416;
  --sq-ink-soft:   #2A3338;
  --sq-paper:      #FAF8F4;
  --sq-paper-2:    #F1ECE2;
  --sq-line:       #E2DAC9;
  --sq-accent:     #E8602A;
  --sq-accent-2:   #F5B441;
  --sq-mute:       #6C7378;

  --sq-radius:     14px;
  --sq-radius-sm:  8px;

  --sq-font-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --sq-font-body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --sq-font-mono:    ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  --sq-container:  1200px;
  --sq-container-narrow: 760px;

  --sq-shadow-1:   0 1px 2px rgba(14,20,22,.06), 0 8px 24px rgba(14,20,22,.06);
  --sq-shadow-2:   0 2px 4px rgba(14,20,22,.08), 0 24px 60px rgba(14,20,22,.10);
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--sq-font-body);
  font-size: 17px;
  line-height: 1.65;
  color: var(--sq-ink);
  background: var(--sq-paper);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--sq-ink); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--sq-accent); }

h1, h2, h3, h4, h5 {
  font-family: var(--sq-font-display);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 0 0 .5em;
  color: var(--sq-ink);
}
h1 { font-size: clamp(2.2rem, 4.8vw, 3.6rem); font-weight: 900; letter-spacing: -0.035em; }
h2 { font-size: clamp(1.7rem, 2.6vw, 2.2rem); font-weight: 800; }
h3 { font-size: 1.35rem; font-weight: 700; letter-spacing: -0.015em; }
h4 { font-size: 1.1rem; font-weight: 700; letter-spacing: -0.01em; }

p { margin: 0 0 1em; }
strong { font-weight: 700; }
em { font-style: italic; }

.container {
  width: 100%;
  max-width: var(--sq-container);
  margin: 0 auto;
  padding: 0 24px;
}
.container-narrow {
  width: 100%;
  max-width: var(--sq-container-narrow);
  margin: 0 auto;
  padding: 0 24px;
}

/* =========================================
   2. Botones
   ========================================= */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: var(--sq-radius-sm);
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: -0.005em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, background .2s ease, border-color .2s ease, color .2s ease, box-shadow .2s ease;
  text-decoration: none;
  white-space: nowrap;
  font-family: inherit;
}
.btn-primary { background: var(--sq-ink); color: var(--sq-paper); }
.btn-primary:hover { background: var(--sq-accent); color: #fff; transform: translateY(-1px); box-shadow: var(--sq-shadow-1); }
.btn-ghost { background: transparent; color: var(--sq-ink); border-color: var(--sq-line); }
.btn-ghost:hover { background: var(--sq-ink); color: var(--sq-paper); border-color: var(--sq-ink); }

/* =========================================
   3. Header (navbar sticky — clon del sitio principal)
   ========================================= */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(250,248,244,.85);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--sq-line);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
  gap: 32px;
}
.site-logo img,
.site-logo .brand-logo img,
.site-logo .custom-logo {
  height: 32px;
  width: auto;
  display: block;
}
.site-logo .brand-logo,
.site-logo .custom-logo-link { display: inline-block; line-height: 0; }
.site-logo .text-logo {
  font-family: var(--sq-font-display);
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--sq-ink);
}
.site-logo .text-logo b { font-weight: 900; color: var(--sq-accent); }

.primary-nav ul {
  display: flex;
  gap: 28px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.primary-nav a {
  font-weight: 500;
  font-size: .95rem;
  color: var(--sq-ink-soft);
  position: relative;
}
.primary-nav a::after {
  content: "";
  position: absolute;
  left: 0; bottom: -6px;
  width: 0; height: 2px;
  background: var(--sq-accent);
  transition: width .25s ease;
}
.primary-nav a:hover::after,
.primary-nav .current-menu-item > a::after,
.primary-nav .current_page_item > a::after { width: 100%; }

.header-actions { display: flex; gap: 12px; align-items: center; }

.nav-toggle {
  display: none;
  background: none;
  border: 0;
  width: 40px; height: 40px;
  cursor: pointer;
  padding: 8px;
}
.nav-toggle span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--sq-ink);
  margin: 4px 0;
}

@media (max-width: 900px) {
  .primary-nav, .header-actions .btn-ghost { display: none; }
  .nav-toggle { display: block; }
  .nav-open .primary-nav {
    display: block;
    position: absolute;
    top: 100%; left: 0; right: 0;
    background: var(--sq-paper);
    border-bottom: 1px solid var(--sq-line);
    padding: 24px;
  }
  .nav-open .primary-nav ul { flex-direction: column; gap: 18px; }
}

/* =========================================
   4. Page header (cabecera de blog/single/archive/page)
   ========================================= */
.page-header {
  padding: 80px 0 48px;
  border-bottom: 1px solid var(--sq-line);
  margin-bottom: 64px;
  position: relative;
  overflow: hidden;
}
.page-header::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(50% 70% at 90% 0%, rgba(232,96,42,.06), transparent 60%);
  pointer-events: none;
}
.page-header__inner { position: relative; }
.page-header h1 { max-width: 24ch; margin-bottom: 14px; }
.page-header p { color: var(--sq-mute); max-width: 56ch; font-size: 1.05rem; }

.kicker {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sq-accent);
  margin-bottom: 18px;
}

/* =========================================
   5. Listado de posts
   ========================================= */
.posts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  padding-bottom: 96px;
}
.post-card {
  background: #fff;
  border: 1px solid var(--sq-line);
  border-radius: var(--sq-radius);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  display: flex;
  flex-direction: column;
}
.post-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sq-shadow-2);
  border-color: var(--sq-ink);
}
.post-card__thumb {
  display: block;
  aspect-ratio: 16/10;
  background: var(--sq-paper-2);
  background-size: cover;
  background-position: center;
}
.post-card__thumb--empty {
  background:
    linear-gradient(135deg, var(--sq-paper-2) 0%, var(--sq-paper) 100%);
  position: relative;
}
.post-card__thumb--empty::after {
  content: "softQrate";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--sq-font-display);
  font-size: 1.6rem;
  color: var(--sq-line);
  letter-spacing: -0.02em;
}
.post-card__body { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.post-card__meta {
  font-family: var(--sq-font-mono);
  font-size: 0.75rem;
  color: var(--sq-mute);
  margin-bottom: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.post-card h2, .post-card h3 { font-size: 1.3rem; margin-bottom: 10px; line-height: 1.2; }
.post-card h2 a, .post-card h3 a { color: var(--sq-ink); }
.post-card h2 a:hover, .post-card h3 a:hover { color: var(--sq-accent); }
.post-card__excerpt { color: var(--sq-ink-soft); font-size: 0.95rem; flex: 1; margin: 0; }
.post-card__more { margin-top: 16px; font-weight: 600; font-size: 0.92rem; color: var(--sq-accent); }

@media (max-width: 900px) {
  .posts-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .posts-grid { grid-template-columns: 1fr; }
}

/* =========================================
   6. Single post / page content
   ========================================= */
.post-content {
  margin: 0 auto 96px;
  font-size: 1.08rem;
  line-height: 1.75;
}
.post-content > * { margin-bottom: 1.4em; }
.post-content h2 { margin-top: 2em; font-size: clamp(1.6rem, 2.4vw, 2rem); }
.post-content h3 { margin-top: 1.8em; }
.post-content ul, .post-content ol { padding-left: 28px; }
.post-content ul li, .post-content ol li { margin-bottom: 0.4em; }
.post-content a { color: var(--sq-accent); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.post-content a:hover { text-decoration-thickness: 2px; }
.post-content blockquote {
  border-left: 3px solid var(--sq-accent);
  padding: 4px 0 4px 24px;
  font-family: var(--sq-font-display);
  font-size: 1.35rem;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -0.01em;
  color: var(--sq-ink);
  margin: 1.5em 0;
}
.post-content blockquote cite { display: block; font-family: var(--sq-font-body); font-style: normal; font-size: 0.95rem; color: var(--sq-mute); margin-top: 12px; }
.post-content code {
  background: var(--sq-paper-2);
  padding: 2px 6px;
  border-radius: 4px;
  font-family: var(--sq-font-mono);
  font-size: 0.92em;
}
.post-content pre {
  background: var(--sq-ink);
  color: var(--sq-paper);
  padding: 22px;
  border-radius: var(--sq-radius-sm);
  overflow-x: auto;
  font-family: var(--sq-font-mono);
  font-size: 0.92em;
  line-height: 1.6;
}
.post-content pre code { background: transparent; color: inherit; padding: 0; }
.post-content img, .post-content figure {
  border-radius: var(--sq-radius-sm);
  margin-left: auto;
  margin-right: auto;
}
.post-content figcaption { font-size: 0.85rem; color: var(--sq-mute); text-align: center; margin-top: 8px; }
.post-content hr { border: 0; border-top: 1px solid var(--sq-line); margin: 2.5em 0; }
.post-content table { width: 100%; border-collapse: collapse; margin: 1.5em 0; }
.post-content table th, .post-content table td { padding: 12px; border-bottom: 1px solid var(--sq-line); text-align: left; }
.post-content table th { font-weight: 700; background: var(--sq-paper-2); }

.post-thumb-wrap {
  margin: 0 auto 40px;
  border-radius: var(--sq-radius);
  overflow: hidden;
  max-width: var(--sq-container-narrow);
}

/* Footer del post: tags, navegación entre posts */
.post-meta-bottom {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--sq-line);
  font-size: 0.92rem;
  color: var(--sq-mute);
}
.post-meta-bottom a { color: var(--sq-ink-soft); }
.post-meta-bottom .tags { margin-top: 8px; }
.post-meta-bottom .tags a {
  display: inline-block;
  padding: 4px 12px;
  border: 1px solid var(--sq-line);
  border-radius: 999px;
  margin: 0 4px 4px 0;
  font-size: 0.82rem;
}
.post-meta-bottom .tags a:hover { background: var(--sq-ink); color: var(--sq-paper); border-color: var(--sq-ink); }

.post-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin: 64px 0;
}
.post-nav a {
  display: block;
  padding: 20px 24px;
  border: 1px solid var(--sq-line);
  border-radius: var(--sq-radius-sm);
  color: var(--sq-ink-soft);
  transition: background .2s, border-color .2s;
}
.post-nav a:hover { background: var(--sq-ink); color: var(--sq-paper); border-color: var(--sq-ink); }
.post-nav a span { display: block; font-size: 0.78rem; color: var(--sq-mute); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 6px; }
.post-nav a:hover span { color: var(--sq-accent-2); }
.post-nav .next { text-align: right; }

@media (max-width: 600px) {
  .post-nav { grid-template-columns: 1fr; }
  .post-nav .next { text-align: left; }
}

/* =========================================
   7. Paginación
   ========================================= */
.pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  padding: 16px 0 96px;
  flex-wrap: wrap;
}
.pagination .page-numbers {
  padding: 10px 16px;
  border: 1px solid var(--sq-line);
  border-radius: var(--sq-radius-sm);
  font-size: 0.92rem;
  color: var(--sq-ink-soft);
  text-decoration: none;
}
.pagination .current,
.pagination a.page-numbers:hover { background: var(--sq-ink); color: var(--sq-paper); border-color: var(--sq-ink); }

/* =========================================
   8. Comments
   ========================================= */
.comments-area { margin: 64px auto 96px; }
.comments-area h2 { margin-bottom: 32px; }
.comment-list { list-style: none; padding: 0; margin: 0 0 48px; }
.comment-list li { border-bottom: 1px solid var(--sq-line); padding: 24px 0; }
.comment-author { font-weight: 700; }
.comment-meta { font-size: 0.85rem; color: var(--sq-mute); margin-bottom: 8px; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--sq-line);
  border-radius: var(--sq-radius-sm);
  font-family: inherit;
  font-size: 1rem;
  background: #fff;
  margin-bottom: 14px;
}
.comment-form input:focus, .comment-form textarea:focus {
  outline: none;
  border-color: var(--sq-ink);
}

/* =========================================
   9. Search
   ========================================= */
.search-form {
  display: flex;
  gap: 8px;
  max-width: 500px;
}
.search-form input[type="search"] {
  flex: 1;
  padding: 12px 14px;
  border: 1px solid var(--sq-line);
  border-radius: var(--sq-radius-sm);
  font-family: inherit;
  font-size: 1rem;
  background: #fff;
}
.search-form input[type="search"]:focus { outline: none; border-color: var(--sq-ink); }
.search-form button {
  padding: 12px 18px;
  border: 0;
  border-radius: var(--sq-radius-sm);
  background: var(--sq-ink);
  color: var(--sq-paper);
  cursor: pointer;
  font-weight: 600;
  font-family: inherit;
}
.search-form button:hover { background: var(--sq-accent); }

/* =========================================
   10. Footer (clon del sitio principal)
   ========================================= */
.site-footer {
  background: var(--sq-paper-2);
  padding: 64px 0 32px;
  border-top: 1px solid var(--sq-line);
}
.site-footer__top {
  display: grid;
  grid-template-columns: 1.5fr 2fr;
  gap: 60px;
  margin-bottom: 48px;
}
.site-footer__brand img,
.site-footer__brand .brand-logo img,
.site-footer__brand .custom-logo {
  height: 36px;
  width: auto;
  margin-bottom: 16px;
  display: block;
}
.site-footer__brand .brand-logo { display: inline-block; line-height: 0; margin-bottom: 16px; }
.site-footer__brand .text-logo {
  font-family: var(--sq-font-display);
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  display: block;
  margin-bottom: 16px;
}
.site-footer__brand .text-logo b { color: var(--sq-accent); font-weight: 900; }
.site-footer__brand p { color: var(--sq-mute); font-size: 0.95rem; max-width: 36ch; }

.footer-nav {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px 32px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-nav a { color: var(--sq-ink-soft); font-size: 0.95rem; }
.footer-nav a:hover { color: var(--sq-accent); }

.site-footer__bottom {
  border-top: 1px solid var(--sq-line);
  padding-top: 24px;
  font-size: 0.85rem;
  color: var(--sq-mute);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

@media (max-width: 800px) {
  .site-footer__top { grid-template-columns: 1fr; gap: 32px; }
}

/* =========================================
   11. Sidebar (opcional)
   ========================================= */
.has-sidebar {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 64px;
}
.sidebar .widget { margin-bottom: 32px; }
.sidebar .widget-title {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sq-mute);
  margin-bottom: 14px;
  font-family: var(--sq-font-body);
}
.sidebar ul { list-style: none; padding: 0; margin: 0; }
.sidebar li { padding: 8px 0; border-bottom: 1px dashed var(--sq-line); font-size: 0.95rem; }

@media (max-width: 900px) {
  .has-sidebar { grid-template-columns: 1fr; }
}

/* =========================================
   12. Utilidades / accesibilidad
   ========================================= */
.screen-reader-text {
  border: 0; clip: rect(1px,1px,1px,1px);
  -webkit-clip-path: inset(50%); clip-path: inset(50%);
  height: 1px; margin: -1px; overflow: hidden;
  padding: 0; position: absolute; width: 1px; word-wrap: normal !important;
}
.alignleft { float: left; margin: 0 1.5em 1em 0; }
.alignright { float: right; margin: 0 0 1em 1.5em; }
.aligncenter { display: block; margin: 0 auto 1em; }
.alignwide { max-width: 1100px; margin-left: auto; margin-right: auto; }
.alignfull { width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: 0.85rem; color: var(--sq-mute); margin-top: 8px; text-align: center; }

::selection { background: var(--sq-accent); color: #fff; }

.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--sq-ink); color: var(--sq-paper);
  padding: 8px 16px; z-index: 999;
}
.skip-link:focus { left: 8px; top: 8px; }
