/* ═══════════════════════════════════════════════════════════
   Posonty Apellidos — buscador.css
   ═══════════════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────────────── */
:root {
    --pa-bg:          #0d0d0d;
    --pa-surface:     #141414;
    --pa-card:        #1a1a1a;
    --pa-card2:       #1f1f1f;
    --pa-border:      rgba(212,175,55,0.15);
    --pa-gold:        #d4af37;
    --pa-gold-light:  #f0d060;
    --pa-gold-dark:   #a8872a;
    --pa-text:        #e8e0d0;
    --pa-text-muted:  #8a8070;
    --pa-accent:      #c0392b;
    --pa-font-display: 'Playfair Display', Georgia, serif;
    --pa-font-body:    'Lato', sans-serif;
    --pa-radius:      8px;
    --pa-glow:        0 0 40px rgba(212,175,55,0.1);
}

/* ── Override global GeneratePress dentro del wrap ──────── */
#pa-wrap *,
#pa-wrap *::before,
#pa-wrap *::after {
    box-sizing: border-box;
}

/* Textos base dentro del wrap */
#pa-wrap p,
#pa-wrap li,
#pa-wrap span,
#pa-wrap label,
#pa-wrap td {
    color: #cbd5e1;
    -webkit-text-fill-color: #cbd5e1;
}
#pa-wrap h2,
#pa-wrap h3,
#pa-wrap h4 {
    color: #ffffff;
    -webkit-text-fill-color: #ffffff;
}
#pa-wrap strong,
#pa-wrap b {
    color: #ffffff;
    -webkit-text-fill-color: #ffffff;
}

/* ── Reset contenedor ─────────────────────────────────── */
#pa-wrap,
.pa-wrap {
    font-family: var(--pa-font-body);
    color: var(--pa-text);
    max-width: 1200px;
    margin: 0 auto;
    padding: 0;
}

/* ═══════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════ */
.pa-hero {
    background: var(--pa-bg);
    border: 1px solid var(--pa-border);
    border-radius: var(--pa-radius);
    padding: 64px 40px;
    text-align: center;
    position: relative;
    overflow: hidden;
    margin-bottom: 24px;
}

.pa-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 80% 40% at 50% 0%, rgba(212,175,55,0.08) 0%, transparent 70%),
        radial-gradient(ellipse 40% 60% at 100% 100%, rgba(192,57,43,0.05) 0%, transparent 60%);
    pointer-events: none;
}

.pa-hero__inner {
    position: relative;
    z-index: 1;
    max-width: 720px;
    margin: 0 auto;
}

.pa-hero__badge {
    display: inline-block;
    background: rgba(212,175,55,0.1);
    border: 1px solid var(--pa-border);
    color: var(--pa-gold);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    padding: 6px 16px;
    border-radius: 100px;
    margin-bottom: 24px;
}

.pa-hero__title {
    font-family: var(--pa-font-display) !important;
    font-size: clamp(2rem, 5vw, 3.2rem) !important;
    font-weight: 900 !important;
    color: #fff !important;
    line-height: 1.15 !important;
    margin: 0 0 16px !important;
    text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}

.pa-hero__sub {
    color: var(--pa-text-muted);
    font-size: 1rem;
    letter-spacing: 0.05em;
    margin: 0 0 40px !important;
}

/* ── Buscador ──────────────────────────────────────────── */
.pa-search {
    display: flex;
    gap: 0;
    max-width: 560px;
    margin: 0 auto 16px;
    border-radius: var(--pa-radius);
    overflow: hidden;
    box-shadow: 0 4px 30px rgba(0,0,0,0.4), 0 0 0 2px rgba(255,255,255,0.25);
    transition: box-shadow 0.2s;
}

.pa-search:focus-within {
    box-shadow: 0 4px 30px rgba(0,0,0,0.4), 0 0 0 2px rgba(212,175,55,0.8);
}

.pa-search input#pa-input {
    flex: 1;
    background: rgba(255,255,255,0.07) !important;
    border: none !important;
    border-right: 1px solid rgba(255,255,255,0.15) !important;
    color: #fff !important;
    font-family: var(--pa-font-body) !important;
    font-size: 1.1rem !important;
    padding: 18px 24px !important;
    outline: none !important;
    box-shadow: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
    -webkit-text-fill-color: #fff !important;
}

.pa-search input#pa-input::placeholder {
    color: rgba(255,255,255,0.4) !important;
    -webkit-text-fill-color: rgba(255,255,255,0.4) !important;
}

#pa-btn,
#pa-btn:link,
#pa-btn:visited,
#pa-btn:hover,
#pa-btn:focus,
#pa-btn:active,
.pa-wrap #pa-btn {
    background: var(--pa-gold) !important;
    color: #0a0a0a !important;
    -webkit-text-fill-color: #0a0a0a !important;
    border: none !important;
    padding: 18px 32px !important;
    font-family: var(--pa-font-body) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    border-radius: 0 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    transition: background 0.2s !important;
    line-height: 1 !important;
}

#pa-btn:hover,
.pa-wrap #pa-btn:hover {
    background: var(--pa-gold-light) !important;
    color: #0a0a0a !important;
    -webkit-text-fill-color: #0a0a0a !important;
}

.pa-btn__text,
.pa-btn__icon {
    color: #0a0a0a !important;
    -webkit-text-fill-color: #0a0a0a !important;
}

.pa-btn__icon {
    font-size: 1.2em;
    transition: transform 0.2s;
}
#pa-btn:hover .pa-btn__icon {
    transform: translateX(4px);
}

.pa-hero__note {
    color: var(--pa-text-muted) !important;
    font-size: 0.8rem !important;
    margin: 0 !important;
    letter-spacing: 0.05em;
}

/* ═══════════════════════════════════════════════════════════
   LOADER
   ═══════════════════════════════════════════════════════════ */
.pa-loader {
    text-align: center;
    padding: 48px;
    background: var(--pa-surface);
    border: 1px solid var(--pa-border);
    border-radius: var(--pa-radius);
    margin-bottom: 24px;
}

.pa-loader__ring {
    width: 48px;
    height: 48px;
    border: 3px solid rgba(212,175,55,0.2);
    border-top-color: var(--pa-gold);
    border-radius: 50%;
    animation: pa-spin 0.8s linear infinite;
    margin: 0 auto 16px;
}

@keyframes pa-spin {
    to { transform: rotate(360deg); }
}

.pa-loader__text {
    color: var(--pa-text-muted);
    font-size: 0.9rem;
    margin: 0;
}

/* ═══════════════════════════════════════════════════════════
   RESULTADO
   ═══════════════════════════════════════════════════════════ */
.pa-resultado {
    margin-bottom: 24px;
    animation: pa-fadein 0.5s ease;
}

@keyframes pa-fadein {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}

.pa-informe {
    background: var(--pa-surface);
    border: 1px solid var(--pa-border);
    border-radius: var(--pa-radius);
    overflow: hidden;
}

/* Cabecera del informe */
.pa-informe__header {
    background: linear-gradient(135deg, #0d0d0d 0%, #1a1208 100%);
    border-bottom: 1px solid var(--pa-border);
    padding: 40px;
    display: flex;
    align-items: center;
    gap: 32px;
}

.pa-informe__escudo {
    width: 100px;
    height: 100px;
    flex-shrink: 0;
    background: rgba(212,175,55,0.05);
    border: 1px solid var(--pa-border);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
}

.pa-informe__titulo {
    font-family: var(--pa-font-display) !important;
    font-size: clamp(1.8rem, 4vw, 2.8rem) !important;
    font-weight: 900 !important;
    color: var(--pa-gold) !important;
    margin: 0 0 8px !important;
    text-shadow: 0 2px 10px rgba(212,175,55,0.3);
}

.pa-informe__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.pa-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: 100px;
    font-size: 0.8rem;
    font-weight: 600;
    border: 1px solid;
}

.pa-badge--idioma {
    background: rgba(212,175,55,0.1);
    border-color: rgba(212,175,55,0.3);
    color: var(--pa-gold);
}

.pa-badge--region {
    background: rgba(192,57,43,0.1);
    border-color: rgba(192,57,43,0.3);
    color: #e74c3c;
}

.pa-badge--siglo {
    background: rgba(39,174,96,0.1);
    border-color: rgba(39,174,96,0.3);
    color: #2ecc71;
}

.pa-badge--pais {
    background: rgba(52,152,219,0.1);
    border-color: rgba(52,152,219,0.3);
    color: #3498db;
}

/* Rareza score */
.pa-rareza {
    margin-top: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.pa-rareza__label {
    font-size: 0.75rem;
    color: var(--pa-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    white-space: nowrap;
}

.pa-rareza__bar {
    flex: 1;
    height: 6px;
    background: rgba(255,255,255,0.08);
    border-radius: 3px;
    overflow: hidden;
    max-width: 200px;
}

.pa-rareza__fill {
    height: 100%;
    background: linear-gradient(90deg, var(--pa-gold-dark), var(--pa-gold));
    border-radius: 3px;
    transition: width 1s ease;
}

.pa-rareza__val {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--pa-gold);
    white-space: nowrap;
}

/* Cuerpo del informe */
.pa-informe__body {
    padding: 32px 40px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

@media (max-width: 640px) {
    .pa-informe__body { grid-template-columns: 1fr; padding: 24px; }
    .pa-informe__header { flex-direction: column; text-align: center; padding: 32px 24px; }
}

.pa-campo {
    background: var(--pa-card);
    border: 1px solid var(--pa-border);
    border-radius: var(--pa-radius);
    padding: 20px;
}

.pa-campo--full {
    grid-column: 1 / -1;
}

.pa-campo__label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--pa-gold);
    margin-bottom: 8px;
    display: block;
}

.pa-campo__val {
    color: var(--pa-text);
    font-size: 0.95rem;
    line-height: 1.6;
    margin: 0;
}

/* Curiosidad viral */
.pa-curiosidad {
    background: linear-gradient(135deg, rgba(212,175,55,0.05), rgba(192,57,43,0.05));
    border: 1px solid rgba(212,175,55,0.2);
    border-radius: var(--pa-radius);
    padding: 24px;
    grid-column: 1 / -1;
    position: relative;
}

.pa-curiosidad::before {
    content: '💡';
    font-size: 1.5rem;
    margin-right: 8px;
}

.pa-curiosidad__title {
    font-family: var(--pa-font-display);
    font-size: 1rem;
    color: var(--pa-gold);
    margin: 0 0 8px;
    font-weight: 700;
}

.pa-curiosidad__text {
    color: var(--pa-text);
    font-size: 0.95rem;
    line-height: 1.6;
    margin: 0;
}

/* Página propia */
.pa-pagina-link {
    grid-column: 1 / -1;
    text-align: center;
    padding: 16px;
    border-top: 1px solid var(--pa-border);
}

.pa-pagina-link a {
    color: var(--pa-gold) !important;
    text-decoration: none !important;
    font-size: 0.9rem;
}

/* ═══════════════════════════════════════════════════════════
   CANVAS — IMAGEN HISTORIA
   ═══════════════════════════════════════════════════════════ */
.pa-canvas-wrap {
    background: var(--pa-surface);
    border: 1px solid var(--pa-border);
    border-radius: var(--pa-radius);
    padding: 40px;
    text-align: center;
    margin-bottom: 24px;
}

.pa-canvas-wrap__title {
    font-family: var(--pa-font-display) !important;
    font-size: 1.6rem !important;
    color: #fff !important;
    margin: 0 0 8px !important;
}

.pa-canvas-wrap__sub {
    color: var(--pa-text-muted) !important;
    font-size: 0.9rem !important;
    margin: 0 0 32px !important;
}

.pa-canvas-container {
    display: inline-block;
    border: 1px solid var(--pa-border);
    border-radius: var(--pa-radius);
    overflow: hidden;
    box-shadow: var(--pa-glow);
    max-width: 280px;
    width: 100%;
}

#pa-canvas {
    display: block;
    width: 100%;
    height: auto;
}

.pa-download-btn {
    display: inline-flex !important;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    background: var(--pa-gold) !important;
    color: #0a0a0a !important;
    border: none !important;
    padding: 16px 40px !important;
    border-radius: var(--pa-radius) !important;
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    margin: 24px auto !important;
    transition: background 0.2s, transform 0.2s !important;
}

.pa-download-btn:hover {
    background: var(--pa-gold-light) !important;
    transform: translateY(-2px) !important;
}

.pa-download-btn__sub {
    font-size: 0.75rem !important;
    font-weight: 400 !important;
    opacity: 0.7;
}

.pa-canvas-cta {
    color: var(--pa-text-muted) !important;
    -webkit-text-fill-color: var(--pa-text-muted) !important;
    font-size: 0.85rem !important;
    margin: 0 !important;
    background: transparent !important;
}

.pa-canvas-cta a,
.pa-canvas-cta strong {
    color: var(--pa-gold) !important;
    -webkit-text-fill-color: var(--pa-gold) !important;
}

/* ═══════════════════════════════════════════════════════════
   BLOQUE SEO ESTÁTICO — overrides fuertes sobre GeneratePress
   ═══════════════════════════════════════════════════════════ */
.pa-seo-block {
    margin-top: 32px;
}

.pa-seo {
    background: #141414 !important;
    border: 1px solid rgba(212,175,55,0.15) !important;
    border-radius: var(--pa-radius);
    padding: 48px 40px;
}

/* Todos los textos dentro del bloque SEO — override total */
#pa-wrap .pa-seo h2,
#pa-wrap .pa-seo h3,
.pa-seo-block .pa-seo h2,
.pa-seo-block .pa-seo h3 {
    font-family: var(--pa-font-display) !important;
    color: #ffffff !important;
    font-size: 1.4rem !important;
    margin: 0 0 12px !important;
    padding-top: 32px !important;
    border-top: 1px solid rgba(212,175,55,0.15) !important;
    background: transparent !important;
    -webkit-text-fill-color: #ffffff !important;
}

#pa-wrap .pa-seo h2:first-child,
.pa-seo-block .pa-seo h2:first-child {
    border-top: none !important;
    padding-top: 0 !important;
}

#pa-wrap .pa-seo p,
#pa-wrap .pa-seo li,
#pa-wrap .pa-seo span,
.pa-seo-block .pa-seo p,
.pa-seo-block .pa-seo li,
.pa-seo-block .pa-seo span {
    color: #cbd5e1 !important;
    line-height: 1.75 !important;
    font-size: 0.97rem !important;
    background: transparent !important;
    -webkit-text-fill-color: #cbd5e1 !important;
}

#pa-wrap .pa-seo strong,
.pa-seo-block .pa-seo strong {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

#pa-wrap .pa-seo em,
.pa-seo-block .pa-seo em {
    color: var(--pa-gold) !important;
    -webkit-text-fill-color: var(--pa-gold) !important;
}

/* Fix blockquotes y cajas internas que GeneratePress estiliza */
#pa-wrap .pa-seo blockquote,
#pa-wrap .pa-seo blockquote p,
.pa-seo-block blockquote,
.pa-seo-block blockquote p {
    background: rgba(212,175,55,0.06) !important;
    border-left: 3px solid var(--pa-gold) !important;
    color: #cbd5e1 !important;
    -webkit-text-fill-color: #cbd5e1 !important;
    padding: 16px 20px !important;
    margin: 0 !important;
}

/* Fix links dentro del bloque SEO */
#pa-wrap .pa-seo a,
.pa-seo-block .pa-seo a {
    color: var(--pa-gold) !important;
    -webkit-text-fill-color: var(--pa-gold) !important;
    text-decoration: underline !important;
}

/* ═══════════════════════════════════════════════════════════
   WIDGET CTA COMPACTO — [apellido_cta]
   ═══════════════════════════════════════════════════════════ */

.pa-cta-widget {
    border-radius: var(--pa-radius);
    overflow: hidden;
    margin: 24px 0;
    font-family: var(--pa-font-body);
    max-width: 1200px;
}

/* ── Tema oscuro (default) ─────────────────────────────── */
.pa-cta-widget--oscuro {
    background: #0d0d0d;
    border: 1px solid rgba(200,168,74,0.2);
    box-shadow: 0 4px 30px rgba(0,0,0,0.3);
}

.pa-cta-widget--oscuro .pa-cta-widget__titulo {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

.pa-cta-widget--oscuro .pa-cta-widget__sub {
    color: #8a8070 !important;
    -webkit-text-fill-color: #8a8070 !important;
}

.pa-cta-widget--oscuro .pa-cta-widget__escudo {
    background: rgba(200,168,74,0.08);
    border: 1px solid rgba(200,168,74,0.15);
    color: #c8a84a;
}

.pa-cta-widget--oscuro .pa-cta-widget__tags span {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.25) !important;
    -webkit-text-fill-color: rgba(255,255,255,0.25) !important;
}

/* ── Tema claro ────────────────────────────────────────── */
.pa-cta-widget--claro {
    background: #f8f6f2;
    border: 1px solid rgba(146,120,48,0.2);
    box-shadow: 0 2px 20px rgba(0,0,0,0.06);
}

.pa-cta-widget--claro .pa-cta-widget__titulo {
    color: #1a1a1a !important;
    -webkit-text-fill-color: #1a1a1a !important;
}

.pa-cta-widget--claro .pa-cta-widget__sub {
    color: #666 !important;
    -webkit-text-fill-color: #666 !important;
}

.pa-cta-widget--claro .pa-cta-widget__escudo {
    background: rgba(146,120,48,0.08);
    border: 1px solid rgba(146,120,48,0.2);
    color: #927830;
}

.pa-cta-widget--claro .pa-cta-widget__tags span {
    background: rgba(0,0,0,0.04);
    border: 1px solid rgba(0,0,0,0.08);
    color: rgba(0,0,0,0.25) !important;
    -webkit-text-fill-color: rgba(0,0,0,0.25) !important;
}

/* ── Layout inner ──────────────────────────────────────── */
.pa-cta-widget__inner {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 24px 28px;
}

.pa-cta-widget__escudo {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    flex-shrink: 0;
}

.pa-cta-widget__texto {
    flex: 1;
    min-width: 0;
}

.pa-cta-widget__titulo {
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    margin: 0 0 4px !important;
    line-height: 1.3 !important;
}

.pa-cta-widget__sub {
    font-size: 0.875rem !important;
    margin: 0 !important;
    line-height: 1.4 !important;
}

.pa-cta-widget__btn {
    display: inline-flex !important;
    align-items: center !important;
    background: #c8a84a !important;
    color: #0a0a0a !important;
    -webkit-text-fill-color: #0a0a0a !important;
    text-decoration: none !important;
    padding: 12px 22px !important;
    border-radius: 6px !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    transition: background 0.2s, transform 0.2s !important;
    border: none !important;
    box-shadow: none !important;
}

.pa-cta-widget__btn:hover {
    background: #e8c870 !important;
    color: #0a0a0a !important;
    -webkit-text-fill-color: #0a0a0a !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
}

/* Tags decorativos de apellidos */
.pa-cta-widget__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 0 28px 18px;
}

.pa-cta-widget__tags span {
    font-size: 0.75rem !important;
    padding: 3px 10px;
    border-radius: 100px;
    font-family: var(--pa-font-body);
}

@media (max-width: 600px) {
    .pa-cta-widget__inner {
        flex-direction: column;
        text-align: center;
        padding: 20px;
    }
    .pa-cta-widget__btn {
        width: 100% !important;
        justify-content: center !important;
    }
    .pa-cta-widget__tags {
        justify-content: center;
        padding: 0 16px 16px;
    }
}
.pa-ad {
    margin: 24px 0;
    text-align: center;
    min-height: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--pa-card);
    border: 1px dashed var(--pa-border);
    border-radius: var(--pa-radius);
}

/* ═══════════════════════════════════════════════════════════
   SINGLE PAGE de apellido
   ═══════════════════════════════════════════════════════════ */
.pa-single__hero {
    background: var(--pa-bg);
    border-bottom: 1px solid var(--pa-border);
    padding: 64px 40px 48px;
    text-align: center;
}

.pa-single__hero-inner {
    max-width: 720px;
    margin: 0 auto;
}

.pa-single__badge {
    display: inline-block;
    background: rgba(212,175,55,0.1);
    border: 1px solid var(--pa-border);
    color: var(--pa-gold);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    padding: 6px 16px;
    border-radius: 100px;
    margin-bottom: 20px;
}

.pa-single__title {
    font-family: var(--pa-font-display) !important;
    font-size: clamp(2rem, 5vw, 3.5rem) !important;
    color: var(--pa-gold) !important;
    margin: 0 0 16px !important;
    font-weight: 900 !important;
}

.pa-single__meta {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 16px;
    color: var(--pa-text-muted);
    font-size: 0.9rem;
}

.pa-single__content {
    max-width: 860px;
    margin: 0 auto;
    padding: 48px 40px;
    color: var(--pa-text);
    line-height: 1.75;
}

.pa-single__content h2 {
    font-family: var(--pa-font-display) !important;
    color: #fff !important;
    font-size: 1.5rem !important;
    margin: 40px 0 12px !important;
    border-left: 3px solid var(--pa-gold);
    padding-left: 16px !important;
}

.pa-single__content p,
.pa-single__content li {
    color: #cbd5e1 !important;
}

.pa-single__content strong {
    color: #fff !important;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .pa-hero { padding: 40px 20px; }
    .pa-seo  { padding: 32px 20px; }
    .pa-canvas-wrap { padding: 32px 20px; }
    .pa-search { flex-direction: column; }
    .pa-search input#pa-input,
    #pa-btn { border-radius: var(--pa-radius) !important; }
    #pa-btn { width: 100% !important; justify-content: center !important; }
}

@media (max-width: 480px) {
    .pa-informe__header { padding: 24px 16px; }
    .pa-informe__body   { padding: 16px; }
    .pa-single__content { padding: 32px 16px; }
}
