/* ==========================================================================
   Consulta RUC — buscador + ficha. Usa el sistema de diseño de CDEPos
   (variables de style.css: navy + naranja). Cargado solo en /consulta-ruc-paraguay.
   ========================================================================== */

.ruc-tool { margin-top: -36px; position: relative; z-index: 5; }
.ruc-search { position: relative; max-width: 700px; margin: 0 auto; }

.ruc-search-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 8px 8px 18px; background: var(--white);
  border: 2px solid var(--gray-200); border-radius: 16px;
  box-shadow: var(--shadow-lg);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.ruc-search.is-focus .ruc-search-bar {
  border-color: var(--orange-500);
  box-shadow: 0 0 0 4px rgba(245, 124, 0, .16), var(--shadow-lg);
}
.ruc-search-icon { color: var(--gray-400); flex-shrink: 0; }
.ruc-search input {
  flex: 1; border: 0; outline: 0; background: transparent;
  padding: 14px 0; font-size: 16px; color: var(--navy-900);
  font-family: inherit; min-width: 0;
}
.ruc-search input::placeholder { color: var(--gray-400); }
.ruc-search-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--orange-600); color: #fff; font-weight: 700; font-size: 15px;
  padding: 13px 20px; border-radius: 11px; border: 0; white-space: nowrap;
  transition: background var(--transition), transform var(--transition);
}
.ruc-search-btn:hover { background: var(--orange-500); transform: translateY(-1px); }
.ruc-search-btn:disabled { opacity: .7; pointer-events: none; }

.ruc-search-hints {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  justify-content: center; padding: 14px 6px 0; font-size: 13px; color: var(--gray-500);
}
.hint-chip {
  padding: 6px 12px; border-radius: 999px; background: var(--gray-50);
  color: var(--gray-700); font-size: 13px; font-weight: 600; border: 1px solid var(--gray-200);
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}
.hint-chip:hover { background: #fff; border-color: var(--orange-400); color: var(--orange-600); }

/* ----------  Dropdown de resultados  ---------- */
.ruc-results {
  position: absolute; left: 0; right: 0; top: calc(100% + 8px);
  background: #fff; border-radius: 14px; border: 1px solid var(--gray-100);
  box-shadow: var(--shadow-xl); padding: 8px; z-index: 20; display: none; text-align: left;
}
.ruc-results-head { display: flex; justify-content: space-between; padding: 8px 12px 4px; font-size: 12px; color: var(--gray-400); font-weight: 600; }
.ruc-result { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px; border-radius: 10px; transition: background var(--transition); }
.ruc-result:hover { background: var(--gray-50); }
.ruc-result-razon { font-weight: 700; font-size: 15px; color: var(--navy-900); margin-bottom: 4px; }
.ruc-result-meta { display: flex; gap: 6px; font-size: 12.5px; color: var(--gray-400); flex-wrap: wrap; }
.ruc-results-foot { font-size: 11.5px; color: var(--gray-400); text-align: center; padding: 10px 8px 4px; border-top: 1px solid var(--gray-100); margin-top: 4px; }

/* ----------  Pill de estado  ---------- */
.ruc-pill { font-size: 11px; font-weight: 800; letter-spacing: .04em; padding: 5px 10px; border-radius: 999px; white-space: nowrap; }
.ruc-pill.ok { background: #E6F4EA; color: var(--green-500); }
.ruc-pill.warn { background: #FCE9D9; color: var(--orange-600); }

/* ----------  Aviso (no encontrado / error / formato)  ---------- */
.ruc-empty {
  display: none; gap: 12px; align-items: flex-start; margin: 14px auto 0; max-width: 700px;
  padding: 16px 18px; background: #fff; border: 1px solid var(--gray-200);
  border-left: 4px solid var(--orange-500); border-radius: 12px; box-shadow: var(--shadow-sm);
  text-align: left; color: var(--orange-600);
}
.ruc-empty svg { flex-shrink: 0; margin-top: 2px; }
.ruc-empty strong { display: block; font-size: 15px; color: var(--navy-900); margin-bottom: 3px; }
.ruc-empty span { font-size: 14px; color: var(--gray-500); }

/* ----------  Ficha del contribuyente  ---------- */
.ruc-ficha {
  display: none; margin: 16px auto 0; max-width: 700px; background: #fff;
  border: 1px solid var(--gray-100); border-radius: 16px; box-shadow: var(--shadow-lg);
  overflow: hidden; text-align: left; animation: rucFichaIn .22s ease;
}
@keyframes rucFichaIn { from { opacity: 0; transform: translateY(-6px); } }
.ruc-ficha-head { display: flex; align-items: center; gap: 14px; padding: 18px 20px; border-bottom: 1px solid var(--gray-100); background: var(--gray-50); }
.ruc-ficha-id { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.ruc-ficha-razon { font-family: var(--font-display); font-weight: 800; font-size: 17px; color: var(--navy-900); }
.ruc-ficha-ruc { font-size: 12.5px; color: var(--gray-400); }
.ruc-ficha-close { width: 30px; height: 30px; border-radius: 8px; font-size: 22px; line-height: 1; color: var(--gray-400); background: transparent; border: 0; display: grid; place-items: center; flex-shrink: 0; }
.ruc-ficha-close:hover { background: var(--gray-100); color: var(--navy-900); }
.ruc-ficha-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 24px; padding: 20px; }
.hc-k { font-size: 11px; color: var(--gray-400); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; margin-bottom: 4px; }
.hc-v { font-size: 14px; font-weight: 600; color: var(--navy-900); }
.ruc-ficha-foot { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 14px 20px; border-top: 1px dashed var(--gray-200); font-size: 12px; color: var(--gray-400); flex-wrap: wrap; }
.ruc-ficha-link { font-weight: 700; font-size: 13px; color: var(--orange-600); }

.ruc-mono { font-family: ui-monospace, 'SF Mono', Menlo, monospace; }
.ruc-disclaimer { max-width: 700px; margin: 14px auto 0; font-size: 12.5px; color: var(--gray-400); text-align: center; }

/* ----------  Layout 2 columnas: buscador + ficha de ejemplo  ---------- */
.ruc-tool { margin-top: -28px; position: relative; z-index: 5; }
.ruc-tool-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 32px; align-items: start; }
.ruc-tool-grid .ruc-search { max-width: none; margin: 0; }

/* Tarjeta de ejemplo (estilo "ventana de navegador") */
.ruc-ex { position: relative; background: #fff; border: 1px solid var(--gray-100); border-radius: 18px; box-shadow: var(--shadow-lg); overflow: hidden; }
.ruc-ex__head { display: flex; align-items: center; gap: 6px; padding: 12px 14px; border-bottom: 1px solid var(--gray-100); background: var(--gray-50); }
.ruc-ex__dot { width: 9px; height: 9px; border-radius: 50%; background: #D9DEE7; }
.ruc-ex__dot:nth-child(1) { background: #FF5F57; } .ruc-ex__dot:nth-child(2) { background: #FEBC2E; } .ruc-ex__dot:nth-child(3) { background: #28C840; }
.ruc-ex__url { margin-left: 8px; font-size: 12px; color: var(--gray-400); font-family: ui-monospace, Menlo, monospace; }
.ruc-ex__body { padding: 20px 22px 22px; }
.ruc-ex__row { display: flex; align-items: center; gap: 12px; }
.ruc-ex__label { font-size: 11px; color: var(--gray-400); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.ruc-ex__val { font-size: 18px; font-weight: 700; flex: 1; color: var(--navy-900); }
.ruc-ex__divider { height: 1px; background: var(--gray-100); margin: 16px 0; }
.ruc-ex__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ruc-ex__cta { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: 2px; font-size: 13px; font-weight: 700; color: var(--orange-600); }
.ruc-ex__tag { position: absolute; top: -12px; right: 16px; background: var(--orange-600); color: #fff; font-size: 11px; font-weight: 700; padding: 5px 12px; border-radius: 999px; box-shadow: var(--shadow); }

/* Grilla de herramientas (reusa .features/.feature) */
a.feature { display: flex; flex-direction: column; color: inherit; }
a.feature:hover { color: inherit; }
.feature__badge { display: inline-block; align-self: flex-start; margin-top: 12px; font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; }
.feature__badge--here { background: #E6F4EA; color: var(--green-500); }
.feature__badge--go { background: #FEEFE3; color: var(--orange-600); }
.feature__badge--soon { background: var(--gray-100); color: var(--gray-500); }

@media (max-width: 860px) {
  .ruc-tool { margin-top: -14px; }
  .ruc-tool-grid { grid-template-columns: 1fr; gap: 20px; }
}

/* ----------  FAQ (details/summary nativo, accesible y SEO-friendly)  ---------- */
.ruc-faq { max-width: var(--max-w-narrow); margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }
.ruc-faq details { background: #fff; border: 1px solid var(--gray-100); border-radius: 12px; box-shadow: var(--shadow-sm); overflow: hidden; }
.ruc-faq summary { list-style: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 18px 22px; font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--navy-900); }
.ruc-faq summary::-webkit-details-marker { display: none; }
.ruc-faq summary::after { content: '+'; font-weight: 400; font-size: 22px; color: var(--orange-600); transition: transform var(--transition); }
.ruc-faq details[open] summary::after { content: '−'; }
.ruc-faq details p { margin: 0; padding: 0 22px 20px; color: var(--gray-700); font-size: 15px; line-height: 1.6; }

@media (max-width: 560px) {
  .ruc-tool { margin-top: -20px; }
  .ruc-search-bar { flex-wrap: wrap; }
  .ruc-search-btn { width: 100%; justify-content: center; }
  .ruc-ficha-grid { grid-template-columns: 1fr; }
}
