html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

a, .btn-link {
    color: #0071c1;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn {
    display: inline-block;
    padding: 0.375rem 0.75rem;
    border-radius: 0.25rem;
    border: 1px solid transparent;
    cursor: pointer;
}

.form-label { display: block; margin-bottom: 0.25rem; }
.form-control {
    display: block;
    width: 100%;
    padding: 0.375rem 0.75rem;
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
}
.form-check { display: flex; align-items: center; gap: 0.5rem; }
.form-check-input { width: 1rem; height: 1rem; }
.d-grid { display: grid; }
.mb-3 { margin-bottom: 1rem; }
.text-danger { color: #dc3545; }
.alert-danger { background: #f8d7da; color: #721c24; padding: 0.75rem; border-radius: 0.25rem; }

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}

/* Resultado de investigación: legibilidad y presentación */
.investigacion-resultado {
    overflow: visible;
    max-height: none;
    white-space: normal;
    word-wrap: break-word;
    font-size: 1.125rem;
    line-height: 1.65;
    font-family: 'Segoe UI', 'Source Sans 3', Georgia, 'Times New Roman', serif;
    color: #1a1a1a;
}

.investigacion-resultado p {
    margin-bottom: 1rem;
}

.investigacion-resultado h1, .investigacion-resultado h2, .investigacion-resultado h3 {
    font-family: 'Segoe UI', 'Source Sans 3', Georgia, serif;
    margin-top: 1.25rem;
    margin-bottom: 0.75rem;
    font-weight: 600;
}

/* Listas con viñetas mejor alineadas */
.investigacion-resultado ul,
.investigacion-resultado ol {
    margin: 0.75rem 0;
    padding-left: 2rem;
    list-style-position: outside;
}

.investigacion-resultado ul {
    list-style-type: disc;
}

.investigacion-resultado ol {
    list-style-type: decimal;
}

.investigacion-resultado li {
    margin-bottom: 0.4rem;
    padding-left: 0.35rem;
}

/* Referencias y enlaces en azul, abrir en nueva pestaña */
.investigacion-resultado a,
.investigacion-resultado .ref-wol {
    color: #0066cc;
    text-decoration: none;
    border-bottom: 1px solid rgba(0, 102, 204, 0.35);
    transition: color 0.15s, border-bottom-color 0.15s;
}

.investigacion-resultado a:hover,
.investigacion-resultado .ref-wol:hover {
    color: #004499;
    border-bottom-color: #004499;
}

.investigacion-resultado a[target="_blank"]::after,
.investigacion-resultado .ref-wol[target="_blank"]::after {
    content: " \2197";
    font-size: 0.75em;
    opacity: 0.8;
}
