/* =====================================================
  SITE.CSS — Estilos globales de la Home de Sinonimos.com.ar
  Fondo blanco, tipografía legible, rejilla fluida y bloques.
  ===================================================== */
:root{
  --ink:#20242a; 
  --muted:#5e6b78; 
  --accent:#0f2744; 
  --link:#0a6cff;
  --border:#e9eef5; 
  --bg:#fff; 
  --soft:#f6f9fc; 
  --radius:14px;
}

html,body{
  background:#fff;
  color:var(--ink);
  font-family:"Inter",ui-sans-serif,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  line-height:1.7;
  margin:0;
  padding:0;
}

a{
  color:var(--link);
  text-decoration:none;
}
a:hover{text-decoration:underline}

.muted{
  color:var(--muted);
  font-size:.95rem;
}
.kicker{
  font-size:.95rem;
  color:var(--muted);
  margin:0 0 .25rem;
}

.wrap{
  max-width:1100px;
  margin:24px auto;
  padding:0 16px;
}

.hero{
  background:linear-gradient(180deg,#fff,#f8fbff 65%);
  border:1px solid var(--border);
  border-radius:20px;
  padding:26px 20px;
  margin:18px 0 20px;
}
.hero h1{
  color:var(--accent);
  letter-spacing:-.01em;
  margin:.1rem 0 .5rem;
  font-size:1.9rem;
}
.hero p{
  color:#2a3340;
  margin:0 0 1rem;
}

.search{
  display:flex;
  gap:10px;
  margin-top:10px;
  flex-wrap:wrap;
}
.search input{
  flex:1 1 420px;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:12px;
  font-size:16px;
  outline:none;
}
.search button{
  padding:12px 16px;
  border-radius:12px;
  border:1px solid #0a6cff1a;
  background:#0a6cff;
  color:#fff;
  font-weight:600;
  cursor:pointer;
}
.search button:hover{
  filter:brightness(.95);
}

.grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:16px;
}

.card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
}

.card h2{
  font-size:1.15rem;
  margin:0 0 .5rem;
  color:var(--accent);
}

.pill-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.pill-list a{
  border:1px solid var(--border);
  padding:8px 10px;
  border-radius:999px;
  background:#fff;
}

.cols-2{
  columns:2;
  column-gap:18px;
}
.cols-3{
  columns:3;
  column-gap:18px;
}

.az{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.az a{
  border:1px solid var(--border);
  border-radius:9px;
  padding:6px 9px;
  background:#fff;
}

.list-inline{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.footer{
  margin:26px 0 30px;
  color:var(--muted);
  font-size:.95rem;
}
.footer h2{
  font-size:1.1rem;
  color:var(--accent);
}
.footer a{color:var(--link)}

details summary{
  cursor:pointer;
  font-weight:600;
  color:var(--accent);
}
details p{
  margin:.4rem 0 1rem;
}

/* =====================================================
   AJUSTES ESPECÍFICOS PARA #segun-contexto (todas las vistas)
   ===================================================== */

/* Quitamos fondo gris y recuadro del bloque .block-alt solo en esta sección */
#segun-contexto.block,
#segun-contexto.block-alt{
  background:transparent;
  border:none;
  padding-left:0;
  padding-right:0;
}

/* Aseguramos color de texto igual al resto del artículo */
#segun-contexto,
#segun-contexto p,
#segun-contexto table,
#segun-contexto td,
#segun-contexto th{
  color:var(--ink);
}
/* =====================================================
   ESPACIADO ENTRE SECCIONES DEL ARTÍCULO
   ===================================================== */
.sinonimos-entry section {
  margin-top: 42px;   /* antes ~18px — ahora con más aire */
  margin-bottom: 42px;
}

.sinonimos-entry section:first-child {
  margin-top: 0; /* evita espacio innecesario arriba del todo */
}

/* =====================================================
   BREAKPOINT INTERMEDIO
   ===================================================== */
@media (max-width:880px){
  .cols-3{columns:2}
}

/* =====================================================
   AJUSTES MOBILE + bloque "Sinónimos según contexto"
   ===================================================== */
@media (max-width:640px){

  .grid{
    grid-template-columns:repeat(6,1fr);
  }

  .cols-2,
  .cols-3{
    columns:1;
  }

  /* Sección sin recuadro exterior ni fondo gris */
  #segun-contexto{
    margin-top:18px;
    margin-bottom:18px;
    padding:0;
    background:transparent;
    border:none;
  }

  #segun-contexto h2{
    font-size:1.15rem;
    margin-top:0;
  }

  #segun-contexto p{
    font-size:1rem;     /* mismo tamaño que el resto del artículo */
    line-height:1.6;
    margin-bottom:.75rem;
  }

  /* Tabla convertida a tarjetas verticales */
  #segun-contexto table{
    width:100% !important;
    border-collapse:separate;
    border-spacing:0;
    font-size:1rem;     /* mismo tamaño que el cuerpo de texto */
  }

  #segun-contexto thead{
    display:none;
  }

  #segun-contexto table,
  #segun-contexto tbody,
  #segun-contexto tr,
  #segun-contexto td{
    display:block;
    width:100%;
  }

  /* Cada fila como card independiente */
  #segun-contexto tbody tr{
    margin-bottom:16px;
    background:#fff;           /* mismo fondo que el artículo */
    border-radius:12px;
    /*border:1px solid var(--border);*/
    padding:12px 14px;
    /*box-sizing:border-box;*/
  }

  #segun-contexto td{
    padding:6px 0;
  }

  /* Primera celda: título del contexto */
  #segun-contexto td:first-child{
    font-weight:600;
    color:var(--accent);
    margin-bottom:6px;
    font-size:1rem;
  }

  /* Segunda celda: sinónimos recomendados (color fuerte, no suave) */
  #segun-contexto td:nth-child(2){
    font-size:1rem;
    color:var(--ink);          /* MISMO color que el resto del artículo */
  }

  /* Tercera celda: notas de uso (ligeramente más pequeñas, pero mismo color base) */
  #segun-contexto td:nth-child(3){
    margin-top:6px;
    font-size:1rem;
    color:var(--ink);          /* también fuerte, no muted */
  }
  @font-face {
  font-family: 'Libre Franklin';
  src: url('/wp-content/uploads/fonts/librefranklin/LibreFranklin-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Libre Franklin';
  src: url('/wp-content/uploads/fonts/librefranklin/LibreFranklin-SemiBold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
}
.pagination {
  margin-top: 1.5rem;
  text-align: center;
}

.pagination ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: inline-flex;
  gap: 0.5rem;
}

.pagination li {
  display: inline-block;
}

.pagination a,
.pagination span {
  display: inline-block;
  padding: 0.4rem 0.7rem;
  border-radius: 4px;
  text-decoration: none;
  font-size: 0.9rem;
}

.pagination a {
  border: 1px solid #ddd;
}

.pagination .current {
  font-weight: 600;
  border: 1px solid #444;
}

/* =========================================
   Widget de letra debajo de cada post
   ========================================= */
.sinonimos-letter-widget{
  position:relative;
  margin-top:32px;
  padding:18px 20px 20px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  background:linear-gradient(135deg,var(--soft),#ffffff);
  box-shadow:0 10px 25px rgba(15,39,68,0.06);
  overflow:hidden;
}

/* barra vertical lateral */
.sinonimos-letter-widget::before{
  content:"";
  position:absolute;
  inset:0;
  width:4px;
  background:var(--link);
  opacity:.95;
}

/* desplazar contenido */
.sinonimos-letter-widget > *{
  position:relative;
  margin-left:10px;
}

/* kicker */
.sinonimos-letter-widget .kicker{
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.75rem;
  color:var(--muted);
  margin:0 0 .3rem;
}

/* título */
.sinonimos-letter-widget .widget-title{
  font-size:1.1rem;
  line-height:1.25;
  margin:.1rem 0 .45rem;
  color:var(--accent);
}

/* descripción */
.sinonimos-letter-widget .muted{
  font-size:.9rem;
  margin:0 0 .9rem;
}

/* contenedor de enlaces */
.sinonimos-letter-widget-links{
  margin-top:.15rem;
}

/* botones/enlaces */
.sinonimos-letter-widget-links a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:none; /* ← sin borde azul */
  border-radius:999px;
  padding:7px 13px;
  background:#fff;
  font-size:.9rem;
  color:var(--accent);
  text-decoration:none !important; /* ← eliminar subrayado */
  box-shadow:0 4px 12px rgba(15,39,68,0.06);
  transition:
    background .15s ease,
    color .15s ease,
    box-shadow .15s ease,
    transform .15s ease;
}

/* flechita decorativa */
.sinonimos-letter-widget-links a::after{
  content:"→";
  font-size:.85em;
  opacity:.75;
}

/* el primer enlace más destacado */
.sinonimos-letter-widget-links a:first-child{
  background:var(--link);
  color:#fff;
}

/* hover */
.sinonimos-letter-widget-links a:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(15,39,68,0.12);
}

/* móvil */
@media (max-width:640px){
  .sinonimos-letter-widget{
    margin-top:24px;
    padding:16px 16px 18px;
  }
  .sinonimos-letter-widget .widget-title{
    font-size:1.02rem;
  }
  .sinonimos-letter-widget-links{
    gap:8px;
  }
  .sinonimos-letter-widget-links a{
    width:100%;
    justify-content:center;
  }
}
/* =========================================
   Widget de "Sinónimos relacionados"
   ========================================= */
.sinonimos-relacionados{
  margin-top:32px;
}

.sinonimos-relacionados .widget-title{
  font-size:1.05rem;
  margin:0 0 .8rem;
  color:var(--accent);
}

/* Grid: 2 columnas en escritorio */
.sinonimos-relacionados-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

/* Item individual */
.sinonimo-relacionado-item a{
  display:block;
  text-decoration:none;
}

/* Imagen: que se vea completa, sin recorte */
.sinonimo-relacionado-thumb{
  width:100%;
  height:auto;
  display:block;
  border-radius:var(--radius);
  /* quitamos aspect-ratio y object-fit para que no se corte */
}

/* Versión móvil: 1 columna */
@media (max-width:640px){
  .sinonimos-relacionados{
    margin-top:24px;
  }
  .sinonimos-relacionados-grid{
    grid-template-columns:1fr;
  }
}
.post-navigation,
.navigation.post-navigation,
.nav-links,
.nav-next,
.nav-previous {
    display: none !important;
}
/* Grid responsive */
.sinonimos-relacionados {
    margin-top: 40px;
}

.sinonimos-relacionados-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

@media (max-width: 768px) {
    .sinonimos-relacionados-grid {
        grid-template-columns: 1fr;
    }
}

/* Item del grid */
.sinonimo-relacionado-item a.sinonimo-relacionado-thumb-css {
    display: block;
    width: 100%;
    padding-top: 100%; /* cuadrado */
    background-size: cover;
    background-position: center;
    border-radius: 8px;
}
/* Bloque de posts relacionados: título */
.sinonimos-relacionados {
  margin-top: 32px;
}

.sinonimos-relacionados-title {
  text-align: center;
  font-size: 1.2rem;
  font-weight: 600;
  margin: 0 0 12px;
}

/* Grid base (escritorio: 2 columnas) */
.sinonimos-relacionados-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.sinonimo-relacionado-item {
  /* por ahora vacío, por si luego quieres sombras, bordes, etc. */
}

.sinonimo-relacionado-thumb-css {
  display: block;
  width: 100%;
  padding-top: 75%;          /* altura 4:3 en escritorio */
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 12px;
}

/* MÓVIL: reducir tamaño de las imágenes */
@media (max-width: 768px) {
  .sinonimos-relacionados-grid {
    grid-template-columns: 1fr;  /* una sola columna en móvil */
    max-width: 320px;            /* hace que el bloque no sea tan ancho */
    margin: 0 auto;
  }

  .sinonimo-relacionado-thumb-css {
    padding-top: 60%;            /* menos altura -> imagen más pequeña */
  }
}

/* =========================================
   Herramienta: Detector de palabras repetidas
   Diseño en una columna (UX)
   ========================================= */

.detector-palabras-repetidas.card{
  max-width:880px;
  margin:26px auto 0;
  padding:0;
  border-radius:22px;
  border:1px solid var(--border);
  background:#fff;
  box-shadow:0 12px 30px rgba(15,39,68,0.06);
}

.detector-inner{
  padding:22px 22px 20px;
}

/* Encabezado */

.detector-header{
  margin-bottom:18px;
}

.detector-header .kicker{
  margin:0 0 .35rem;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--muted);
}

.detector-header .detector-title{
  margin:0 0 .45rem;
  font-size:1.9rem;
  line-height:1.2;
  letter-spacing:-.02em;
  color:var(--accent);
}

.detector-header .detector-subtitle{
  margin:0;
  max-width:640px;
  font-size:.96rem;
}

/* Layout general (una columna) */

.detector-layout{
  display:flex;
  flex-direction:column;
  gap:18px;
}

/* Formulario y textarea */

.detector-form{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.detector-main-input{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.detector-label{
  font-weight:500;
  font-size:.95rem;
  color:var(--accent);
}

.detector-textarea{
  width:100%;
  box-sizing:border-box;
  border-radius:16px;
  border:1px solid var(--border);
  padding:11px 13px;
  font-family:inherit;
  font-size:.98rem;
  line-height:1.5;
  resize:vertical;
  min-height:210px;
  background:#fbfcff;
  transition:border-color .12s ease, box-shadow .12s ease, background .12s ease;
}

.detector-textarea::placeholder{
  color:var(--muted);
}

.detector-textarea:focus{
  outline:none;
  border-color:var(--link);
  background:#fff;
  box-shadow:0 0 0 1px rgba(10,108,255,0.18);
}

/* Meta (palabras, caracteres, estado) */

.detector-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px 14px;
  margin-top:4px;
  font-size:.85rem;
}

.detector-meta-item{
  display:inline-flex;
  align-items:baseline;
  gap:4px;
}

.detector-meta-label{
  color:var(--muted);
}

.detector-meta-value{
  font-weight:600;
  color:var(--accent);
}

.detector-meta-status{
  margin-left:auto;
  padding:3px 9px;
  border-radius:999px;
  background:#f3f7ff;
  color:#1b4bb8;
}

/* Barra de controles */

.detector-toolbar{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  gap:14px 18px;
  margin-top:4px;
  padding:10px 12px;
  border-radius:16px;
  background:#f7f9fc;
  border:1px solid var(--border);
}

.detector-control-group{
  display:flex;
  flex-direction:column;
  gap:4px;
}

.detector-sub-label{
  font-size:.86rem;
  color:var(--muted);
}

.detector-helper{
  display:block;
  font-size:.8rem;
  color:var(--muted);
  margin-top:1px;
}

.detector-input-number{
  width:92px;
  padding:7px 9px;
  border-radius:999px;
  border:1px solid var(--border);
  font-size:.9rem;
  background:#fff;
  transition:border-color .12s ease, box-shadow .12s ease;
}

.detector-input-number:focus{
  outline:none;
  border-color:var(--link);
  box-shadow:0 0 0 1px rgba(10,108,255,0.16);
}

.detector-checkbox-group{
  flex-direction:row;
  align-items:flex-start;
  gap:8px;
  max-width:280px;
}

.detector-checkbox{
  margin-top:2px;
  width:18px;
  height:18px;
  cursor:pointer;
}

/* Botón principal */

.detector-btn{
  margin-left:auto;
  padding:10px 22px;
  border-radius:999px;
  border:none;
  background:#0a6cff;
  color:#fff;
  font-weight:600;
  font-size:.95rem;
  cursor:pointer;
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 5px 14px rgba(10,108,255,0.30);
  transition:transform .08s ease, box-shadow .08s ease, filter .08s ease;
}

.detector-btn:hover{
  filter:brightness(.97);
  transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(10,108,255,0.35);
}

.detector-btn:active{
  transform:translateY(0);
  box-shadow:0 4px 10px rgba(10,108,255,0.25);
}

/* Resumen y KPIs */

.detector-summary{
  padding-top:4px;
  border-top:1px solid rgba(230,234,242,0.9);
}

.detector-summary-title{
  margin:8px 0 .55rem;
  font-size:1.02rem;
  color:var(--accent);
}

.detector-kpis{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.detector-kpi{
  flex:1;
  min-width:110px;
  padding:8px 10px;
  border-radius:12px;
  background:#f7f9fc;
}

.detector-kpi-label{
  display:block;
  font-size:.8rem;
  color:var(--muted);
  margin-bottom:2px;
}

.detector-kpi-value{
  font-size:1.05rem;
  font-weight:600;
  color:var(--accent);
}

/* Resultados */

.detector-resultados{
  margin-top:10px;
}

.detector-resultados-header{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:baseline;
  gap:6px 10px;
  margin-bottom:8px;
}

.detector-resultados-title{
  margin:0;
  font-size:1.05rem;
  color:var(--accent);
}

.detector-resultados-ayuda{
  margin:0;
  font-size:.88rem;
}

.detector-tabla-wrap{
  overflow-x:auto;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
}

.detector-tabla{
  width:100%;
  border-collapse:collapse;
  font-size:.94rem;
}

.detector-tabla th,
.detector-tabla td{
  padding:8px 11px;
  text-align:left;
}

.detector-tabla thead th{
  font-weight:600;
  color:var(--accent);
  background:#f6f8fb;
  border-bottom:1px solid var(--border);
}

.detector-tabla tbody tr:nth-child(odd){
  background:#fbfdff;
}

.detector-tabla tbody tr:hover{
  background:#eef3ff;
}

.detector-col-palabra{
  font-weight:500;
}

.detector-chip-frecuencia{
  display:inline-flex;
  align-items:center;
  padding:3px 9px;
  border-radius:999px;
  background:#edf3ff;
  font-size:.84rem;
}

.detector-chip-frecuencia span{
  font-weight:600;
  margin-right:4px;
}

/* =========================
   Guía extendida del detector
   ========================= */

.detector-guide{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(230,234,242,0.95);
}

.detector-guide-title{
  margin:0 0 .9rem;
  font-size:1.15rem;
  color:var(--accent);
}

.detector-guide--extended .detector-guide-grid{
  display:flex;
  gap:22px;
  align-items:flex-start;
  margin-bottom:16px;
}

.detector-guide-col{
  flex:1;
  min-width:0;
}

.detector-guide-col h3{
  margin:.1rem 0 .4rem;
  font-size:1rem;
  color:var(--accent);
}

.detector-guide-list{
  margin:.2rem 0 .8rem 1.1rem;
  padding:0;
  font-size:.92rem;
}

.detector-guide-steps{
  margin:.2rem 0 .8rem 1.2rem;
  padding:0;
  font-size:.92rem;
}

.detector-guide-steps li{
  margin-bottom:.25rem;
}

/* Bloques de ejemplo */

.detector-guide-example{
  padding:8px 10px;
  border-radius:12px;
  background:#f7f9fc;
  border:1px solid var(--border);
  margin-bottom:.65rem;
  font-size:.92rem;
}

.detector-guide-example h4{
  margin:0 0 .25rem;
  font-size:.9rem;
  color:var(--accent);
}

/* FAQs */

.detector-faq{
  border-radius:14px;
  border:1px solid var(--border);
  background:#fbfcff;
  padding:12px 14px;
}

.detector-faq-title{
  margin:0 0 .4rem;
  font-size:1rem;
  color:var(--accent);
}

.detector-faq-item{
  margin-bottom:.35rem;
  border-radius:10px;
  padding:4px 4px;
}

.detector-faq-item:last-child{
  margin-bottom:0;
}

.detector-faq-item summary{
  cursor:pointer;
  list-style:none;
  font-size:.9rem;
  font-weight:500;
  color:var(--accent);
  position:relative;
  padding-right:18px;
}

.detector-faq-item summary::marker{
  content:"";
}

.detector-faq-item summary::-webkit-details-marker{
  display:none;
}

.detector-faq-item summary::after{
  content:"›";
  position:absolute;
  right:0;
  top:0;
  font-size:.9rem;
  transform:rotate(90deg);
  color:var(--muted);
  transition:transform .15s ease;
}

.detector-faq-item[open] summary::after{
  transform:rotate(-90deg);
}

.detector-faq-item p{
  margin:.25rem 0 .1rem;
  font-size:.9rem;
}

/* Nota final / tip */

.detector-guide-note{
  margin-top:.4rem;
  font-size:.88rem;
}

/* Bloque explicativo largo debajo (si lo usas) */

.detector-explicacion{
  max-width:880px;
  margin:26px auto 0;
}

/* =========================
   Responsive
   ========================= */

@media (max-width:768px){
  .detector-guide--extended .detector-guide-grid{
    flex-direction:column;
    gap:16px;
  }
}

@media (max-width:640px){
  .detector-palabras-repetidas.card{
    margin:20px auto 0;
    border-radius:20px;
  }

  .detector-inner{
    padding:18px 15px 18px;
  }

  .detector-header .detector-title{
    font-size:1.6rem;
  }

  .detector-toolbar{
    flex-direction:column;
    align-items:stretch;
  }

  .detector-checkbox-group{
    max-width:none;
  }

  .detector-btn{
    width:100%;
    margin-left:0;
  }

  .detector-kpis{
    flex-direction:row;
  }

  .detector-kpi{
    flex:1;
  }

  .detector-resultados-header{
    flex-direction:column;
    align-items:flex-start;
  }

  .detector-tabla th,
  .detector-tabla td{
    padding:7px 9px;
  }
}
/* Ajuste UX: bloque de opciones en una sola columna */
.detector-toolbar{
  display:flex;
  flex-direction:column;      /* TODO en columna */
  align-items:stretch;
  gap:10px;
  margin-top:6px;
  padding:12px 14px;
  border-radius:16px;
  background:#f7f9fc;
  border:1px solid var(--border);
}

/* Cada grupo ocupa todo el ancho para alinear bien las etiquetas */
.detector-control-group{
  width:100%;
  max-width:none;
}

/* Checkboxes alineados al texto, sin cortes raros */
.detector-checkbox-group{
  flex-direction:row;
  align-items:flex-start;
  gap:8px;
}

/* Botón alineado a la derecha, pero en su propia fila */
.detector-btn{
  align-self:flex-end;
  margin-left:0;
  margin-top:4px;
}
/* Guía siempre en una sola columna */
.detector-guide--extended .detector-guide-grid{
  display:flex;
  flex-direction:column;
  gap:16px;
}

/* Por si quedara alguna regla previa para pantallas grandes, la anulamos */
@media (min-width:769px){
  .detector-guide--extended .detector-guide-grid{
    flex-direction:column;
  }
}
/* ================================
   PULIDO DE TIPOGRAFÍA Y ESPACIADO
   Guía completa del detector
   ================================ */

/* Contenedor general de la guía */
.detector-guide{
  margin-top:28px !important;
  padding-top:24px !important;
  border-top:1px solid rgba(230,234,242,0.95);
}

/* Título principal de la guía */
.detector-guide-title{
  margin:0 0 1.3rem !important;
  font-size:1.35rem !important;
  line-height:1.35 !important;
  font-weight:700;
  color:var(--accent);
}

/* Títulos secundarios (h3) */
.detector-guide-col h3,
.detector-faq-title{
  margin:1.6rem 0 .6rem !important;
  font-size:1.1rem !important;
  font-weight:600;
  line-height:1.4;
  color:var(--accent);
}

/* Primera aparición de h3 en cada columna sin doble margen */
.detector-guide-col h3:first-child{
  margin-top:0 !important;
}

/* Párrafos */
.detector-guide p{
  margin:.4rem 0 1rem !important;
  font-size:1rem !important;
  line-height:1.6 !important;
  color:#2d333a;
}

/* Listas */
.detector-guide-list,
.detector-guide-steps{
  margin:.35rem 0 1.2rem 1.2rem !important;
  padding:0;
  font-size:.98rem !important;
  line-height:1.55;
}

.detector-guide-list li,
.detector-guide-steps li{
  margin-bottom:.4rem !important;
}

/* Bloques de ejemplo */
.detector-guide-example{
  padding:12px 14px !important;
  border-radius:12px;
  margin:1rem 0 !important;
  background:#f7f9fc;
  border:1px solid var(--border);
}

.detector-guide-example h4{
  margin:0 0 .4rem !important;
  font-size:1rem !important;
  font-weight:600;
  color:var(--accent);
}

/* FAQs */
.detector-faq{
  margin-top:2rem !important;
  padding:16px 18px !important;
  border-radius:14px;
  background:#fbfcff;
  border:1px solid var(--border);
}

.detector-faq-title{
  font-size:1.1rem !important;
  margin:0 0 1rem !important;
}

.detector-faq-item{
  margin-bottom:1rem !important;
  padding:6px 4px !important;
}

.detector-faq-item summary{
  font-size:1rem !important;
  margin-bottom:.35rem !important;
  line-height:1.45;
}

.detector-faq-item p{
  font-size:.98rem !important;
  line-height:1.55;
  margin:.25rem 0 .5rem !important;
}

/* Nota final */
.detector-guide-note{
  margin-top:1rem !important;
  font-size:.95rem !important;
  line-height:1.55 !important;
}
/* =========================================
   Herramienta: Contador de caracteres y palabras
   Diseño similar al detector de palabras repetidas
   ========================================= */

.contador-herramienta.card{
  max-width: 880px;
  margin: 26px auto 0;
  padding: 0;
  border-radius: 22px;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: 0 12px 30px rgba(15,39,68,0.06);
}

.contador-inner{
  padding: 22px 22px 20px;
}

/* Encabezado */

.contador-header{
  margin-bottom: 18px;
}

.contador-header .kicker{
  margin: 0 0 .35rem;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--muted);
}

.contador-header .contador-title{
  margin: 0 0 .45rem;
  font-size: 1.9rem;
  line-height: 1.2;
  letter-spacing: -.02em;
  color: var(--accent);
}

.contador-header .contador-subtitle{
  margin: 0;
  max-width: 640px;
  font-size: .96rem;
}

/* Layout general */

.contador-layout{
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* A partir de escritorio: textarea izquierda, resumen derecha */

@media (min-width: 900px){
  .contador-layout{
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
    gap: 22px 26px;
    align-items: flex-start;
  }

  .contador-form{
    grid-column: 1 / 2;
  }

  .contador-summary{
    grid-column: 2 / 3;
  }

  .contador-resultados,
  .contador-guide{
    grid-column: 1 / 3;
  }
}

/* Formulario + textarea */

.contador-form{
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.contador-main-input{
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contador-main-label{
  font-weight: 500;
  font-size: .95rem;
  color: var(--accent);
}

.contador-textarea{
  width: 100%;
  box-sizing: border-box;
  border-radius: 16px;
  border: 1px solid var(--border);
  padding: 11px 13px;
  font-family: inherit;
  font-size: .98rem;
  line-height: 1.5;
  resize: vertical;
  min-height: 230px;
  background: #fbfcff;
  transition: border-color .12s ease, box-shadow .12s ease, background .12s ease;
}

.contador-textarea::placeholder{
  color: var(--muted);
}

.contador-textarea:focus{
  outline: none;
  border-color: var(--link);
  background: #fff;
  box-shadow: 0 0 0 1px rgba(10,108,255,0.18);
}

/* Botones debajo del textarea */

.contador-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 6px;
}

.contador-btn{
  padding: 9px 18px;
  border-radius: 999px;
  border: none;
  font-size: .92rem;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .08s ease, box-shadow .08s ease, filter .08s ease;
}

/* Primario (por si lo usas en el futuro) */
.contador-btn.primario{
  background: #0a6cff;
  color: #fff;
  box-shadow: 0 5px 14px rgba(10,108,255,0.30);
}

.contador-btn.primario:hover{
  filter: brightness(.97);
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(10,108,255,0.35);
}

/* Secundarios (limpiar/copiar) */

.contador-btn.secundario{
  background: #fff;
  color: var(--accent);
  border: 1px solid var(--border);
  box-shadow: 0 4px 10px rgba(15,39,68,0.04);
}

.contador-btn.secundario:hover{
  filter: brightness(.99);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(15,39,68,0.09);
}

/* Toolbar de opciones */

.contador-toolbar{
  margin-top: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  background: #f7f9fc;
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contador-control-group{
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contador-sub-label{
  font-size: .86rem;
  color: var(--muted);
}

.contador-checkbox-group{
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.contador-checkbox{
  margin-top: 2px;
  width: 18px;
  height: 18px;
  cursor: pointer;
}

.contador-helper{
  display: block;
  font-size: .8rem;
  color: var(--muted);
  margin-top: 1px;
}

/* Resumen (KPIs) */

.contador-summary{
  padding-top: 4px;
  border-top: 1px solid rgba(230,234,242,0.9);
}

.contador-summary-title{
  margin: 8px 0 .55rem;
  font-size: 1.02rem;
  color: var(--accent);
}

.contador-kpis{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.contador-kpi{
  flex: 1;
  min-width: 120px;
  padding: 8px 10px;
  border-radius: 12px;
  background: #f7f9fc;
}

.contador-kpi-label{
  display: block;
  font-size: .8rem;
  color: var(--muted);
  margin-bottom: 2px;
}

.contador-kpi-value{
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--accent);
}

/* Palabras más utilizadas */

.contador-resultados{
  margin-top: 4px;
}

.contador-resultados-header{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: baseline;
  gap: 6px 10px;
  margin-bottom: 8px;
}

.contador-resultados-title{
  margin: 0;
  font-size: 1.05rem;
  color: var(--accent);
}

.contador-resultados-ayuda{
  margin: 0;
  font-size: .88rem;
}

.contador-tabla-wrap{
  overflow-x: auto;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
}

.contador-tabla-wrap p.muted{
  padding: 8px 10px;
}

.contador-tabla{
  width: 100%;
  border-collapse: collapse;
  font-size: .94rem;
}

.contador-tabla th,
.contador-tabla td{
  padding: 8px 11px;
  text-align: left;
}

.contador-tabla thead th{
  font-weight: 600;
  color: var(--accent);
  background: #f6f8fb;
  border-bottom: 1px solid var(--border);
}

.contador-tabla tbody tr:nth-child(odd){
  background: #fbfdff;
}

.contador-tabla tbody tr:hover{
  background: #eef3ff;
}

/* Guía y FAQ */

.contador-guide{
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(230,234,242,0.95);
}

.contador-guide-title{
  margin: 0 0 .9rem;
  font-size: 1.15rem;
  color: var(--accent);
}

.contador-guide-grid{
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.contador-guide-col h3{
  margin: .1rem 0 .4rem;
  font-size: 1rem;
  color: var(--accent);
}

.contador-guide-list{
  margin: .2rem 0 .8rem 1.1rem;
  padding: 0;
  font-size: .92rem;
}

.contador-guide-example{
  padding: 10px 12px;
  border-radius: 12px;
  background: #fff;              /* antes #f7f9fc */
  border: 1px solid var(--border);
  font-size: .92rem;
  box-shadow: 0 4px 10px rgba(15,39,68,0.03); /* toque muy suave, opcional */
  margin-bottom: 16px;
}


.contador-guide-example h4{
  margin: 0 0 .25rem;
  font-size: .9rem;
  color: var(--accent);
}

/* FAQs del contador (reutilizamos estilo general) */

.contador-faq{
  border-radius: 14px;
  border: 1px solid var(--border);
  background: #fff;              /* antes #fbfcff */
  padding: 12px 14px;
  margin-top: 8px;
}

.contador-faq-title{
  margin: 0 0 .4rem;
  font-size: 1rem;
  color: var(--accent);
}

.contador-faq-item{
  margin-bottom: .35rem;
  border-radius: 10px;
  padding: 4px 4px;
}

.contador-faq-item:last-child{
  margin-bottom: 0;
}

.contador-faq-item summary{
  cursor: pointer;
  list-style: none;
  font-size: .9rem;
  font-weight: 500;
  color: var(--accent);
  position: relative;
  padding-right: 18px;
}

.contador-faq-item summary::marker{
  content: "";
}

.contador-faq-item summary::-webkit-details-marker{
  display: none;
}

.contador-faq-item summary::after{
  content: "›";
  position: absolute;
  right: 0;
  top: 0;
  font-size: .9rem;
  transform: rotate(90deg);
  color: var(--muted);
  transition: transform .15s ease;
}

.contador-faq-item[open] summary::after{
  transform: rotate(-90deg);
}

.contador-faq-item p{
  margin: .25rem 0 .1rem;
  font-size: .9rem;
}

/* Responsive ajustes finos */

@media (max-width: 640px){
  .contador-herramienta.card{
    margin: 20px auto 0;
    border-radius: 20px;
  }

  .contador-inner{
    padding: 18px 15px 18px;
  }

  .contador-header .contador-title{
    font-size: 1.6rem;
  }

  .contador-kpis{
    flex-direction: row;
  }

  .contador-kpi{
    flex: 1;
  }

  .contador-resultados-header{
    flex-direction: column;
    align-items: flex-start;
  }

  .contador-tabla th,
  .contador-tabla td{
    padding: 7px 9px;
  }

  .contador-actions{
    justify-content: flex-start;
  }
}
/* Quitar el margen del último card */
.contador-guide-example:last-child {
  margin-bottom: 0;
}
