/* ============================================================
   RucPerú — Ficha Documental Peruana
   Papel crema + tinta + rojo bandera. Editorial, confiable, veloz.
   ============================================================ */

:root {
    --papel: #f7f3ec;
    --papel-alto: #fdfbf7;
    --papel-hundido: #efe9de;
    --tinta: #211e1b;
    --tinta-suave: #5c564e;
    --tinta-tenue: #8a8378;
    --linea: #d9d2c4;
    --linea-fuerte: #b9b0a0;
    --rojo: #d91023;
    --rojo-tinta: #a90c1b;
    --rojo-papel: #fbe9ea;
    --verde: #2f6b3c;
    --verde-papel: #e6efe2;
    --ambar: #9a6310;
    --ambar-papel: #f8eed9;
    --serif: "Fraunces", Georgia, serif;
    --sans: "Archivo", "Helvetica Neue", sans-serif;
    --mono: "IBM Plex Mono", ui-monospace, monospace;
    --radio: 4px;
    --sombra-ficha: 0 1px 2px rgba(33, 30, 27, .07), 0 12px 32px -12px rgba(33, 30, 27, .25);
    --transicion: 180ms cubic-bezier(.4, 0, .2, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
    font-family: var(--sans);
    font-size: 16px;
    line-height: 1.55;
    color: var(--tinta);
    background-color: var(--papel);
    /* Grano de papel sutil */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .04 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

main { flex: 1; }

.contenedor { width: 100%; max-width: 880px; margin: 0 auto; padding: 0 1.25rem; }

::selection { background: var(--rojo); color: var(--papel-alto); }

:focus-visible { outline: 2px solid var(--rojo); outline-offset: 2px; border-radius: 2px; }

/* ---------- Cabecera ---------- */

.cabecera {
    border-bottom: 1px solid var(--linea);
    background: color-mix(in srgb, var(--papel-alto) 86%, transparent);
    backdrop-filter: blur(6px);
    position: sticky; top: 0; z-index: 20;
}

.cabecera-fila { display: flex; align-items: center; gap: 1rem; height: 64px; }

.marca {
    display: inline-flex; align-items: center; gap: .6rem;
    text-decoration: none; color: var(--tinta);
}

.marca-sello {
    display: grid; place-items: center;
    width: 34px; height: 34px;
    background: var(--rojo); color: var(--papel-alto);
    font-family: var(--serif); font-weight: 800; font-size: 1.25rem;
    border-radius: 8px;
    box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--papel-alto) 35%, transparent);
    transform: rotate(-3deg);
    transition: transform var(--transicion);
}

.marca:hover .marca-sello { transform: rotate(2deg) scale(1.05); }

.marca-texto { font-family: var(--serif); font-weight: 700; font-size: 1.3rem; letter-spacing: -.01em; }
.marca-texto em { font-style: normal; color: var(--rojo); }

.nav { margin-left: auto; display: flex; align-items: center; gap: 1.4rem; }

.nav a, .enlace-boton {
    font-size: .92rem; font-weight: 500; color: var(--tinta-suave);
    text-decoration: none; transition: color var(--transicion);
}

.nav a:hover, .enlace-boton:hover { color: var(--tinta); }

.nav a.activo { color: var(--tinta); font-weight: 600; }
.nav a.activo::after {
    content: ""; display: block; height: 2px; margin-top: 1px;
    background: var(--rojo); border-radius: 2px;
}

.nav-form { display: inline-flex; }

.enlace-boton { background: none; border: 0; cursor: pointer; font-family: inherit; padding: 0; }

.nav-cta {
    padding: .45rem .9rem; border-radius: 999px;
    background: var(--tinta); color: var(--papel-alto) !important;
    font-weight: 600 !important;
    transition: background var(--transicion), transform var(--transicion);
}

.nav-cta:hover { background: var(--rojo); transform: translateY(-1px); }

/* ---------- Hero / búsqueda ---------- */

.hero { padding: 4.5rem 0 2.5rem; }

.hero-etiqueta {
    display: inline-flex; align-items: center; gap: .45rem;
    font-family: var(--mono); font-size: .72rem; letter-spacing: .14em;
    text-transform: uppercase; color: var(--rojo-tinta);
    border: 1px solid color-mix(in srgb, var(--rojo) 35%, var(--linea));
    background: var(--rojo-papel);
    padding: .3rem .7rem; border-radius: 999px;
    margin-bottom: 1.2rem;
    animation: aparece .5s .05s both;
}

.hero-etiqueta::before { content: "●"; font-size: .55rem; color: var(--rojo); }

.hero h1 {
    font-family: var(--serif);
    font-size: clamp(2.3rem, 6vw, 3.6rem);
    font-weight: 700;
    line-height: 1.04;
    letter-spacing: -.025em;
    max-width: 14ch;
    animation: aparece .55s .12s both;
}

.hero h1 em { font-style: italic; color: var(--rojo); font-weight: 600; }

.hero-sub {
    margin-top: 1rem; font-size: 1.08rem; color: var(--tinta-suave);
    max-width: 52ch;
    animation: aparece .55s .2s both;
}

/* Buscador */

.buscador { margin-top: 2rem; animation: aparece .55s .28s both; }

.buscador-caja {
    display: flex; gap: .5rem; align-items: stretch;
    background: var(--papel-alto);
    border: 1.5px solid var(--linea-fuerte);
    border-radius: 12px;
    padding: .45rem;
    box-shadow: 0 1px 0 rgba(33,30,27,.04);
    transition: border-color var(--transicion), box-shadow var(--transicion);
}

.buscador-caja:focus-within {
    border-color: var(--rojo);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--rojo) 12%, transparent);
}

.buscador input {
    flex: 1; min-width: 0;
    border: 0; background: transparent;
    font-family: var(--mono); font-size: 1.25rem; letter-spacing: .12em;
    color: var(--tinta);
    padding: .55rem .75rem;
}

.buscador input::placeholder { color: var(--tinta-tenue); letter-spacing: .08em; }
.buscador input:focus { outline: none; }

.buscador button {
    border: 0; cursor: pointer;
    font-family: var(--sans); font-weight: 600; font-size: 1rem;
    color: var(--papel-alto); background: var(--rojo);
    padding: .55rem 1.5rem; border-radius: 8px;
    transition: background var(--transicion), transform var(--transicion);
}

.buscador button:hover { background: var(--rojo-tinta); transform: translateY(-1px); }
.buscador button:active { transform: translateY(0); }
.buscador button:disabled { opacity: .55; cursor: progress; transform: none; }

.buscador-ayuda { margin-top: .6rem; font-size: .85rem; color: var(--tinta-tenue); }
.buscador-ayuda code { font-family: var(--mono); font-size: .82rem; }

/* ---------- Estados ---------- */

.estado { margin-top: 1.75rem; padding: 1.1rem 1.3rem; border-radius: var(--radio); font-size: .97rem; }
.estado.vacio { background: var(--papel-hundido); color: var(--tinta-suave); border: 1px dashed var(--linea-fuerte); }
.estado.error { background: var(--rojo-papel); color: var(--rojo-tinta); border: 1px solid color-mix(in srgb, var(--rojo) 30%, var(--linea)); }
.estado.cargando { background: var(--papel-hundido); color: var(--tinta-suave); border: 1px solid var(--linea); }

.estado.cargando::before {
    content: ""; display: inline-block; vertical-align: -2px;
    width: 12px; height: 12px; margin-right: .6rem;
    border: 2px solid var(--linea-fuerte); border-top-color: var(--rojo);
    border-radius: 50%;
    animation: gira .7s linear infinite;
}

@keyframes gira { to { transform: rotate(360deg); } }

/* ---------- Ficha de resultado ---------- */

.ficha {
    margin-top: 1.75rem;
    background: var(--papel-alto);
    border: 1px solid var(--linea-fuerte);
    border-radius: var(--radio);
    box-shadow: var(--sombra-ficha);
    overflow: hidden;
    animation: ficha-entra .45s cubic-bezier(.2, .8, .3, 1) both;
}

@keyframes ficha-entra {
    from { opacity: 0; transform: translateY(14px) rotate(.4deg); }
    to { opacity: 1; transform: none; }
}

.ficha-franja {
    height: 6px;
    background: repeating-linear-gradient(135deg, var(--rojo) 0 14px, var(--papel-alto) 14px 20px, var(--rojo) 20px 34px);
}

.ficha-cuerpo { padding: 1.75rem 1.9rem 1.9rem; position: relative; }

.ficha-rotulo {
    font-family: var(--mono); font-size: .68rem; letter-spacing: .18em;
    text-transform: uppercase; color: var(--tinta-tenue);
    margin-bottom: .65rem;
}

.ficha-razon {
    font-family: var(--serif); font-weight: 700;
    font-size: clamp(1.35rem, 3.4vw, 1.9rem);
    line-height: 1.12; letter-spacing: -.015em;
    max-width: 24ch;
}

.ficha-ruc {
    font-family: var(--mono); font-size: 1.05rem; letter-spacing: .16em;
    color: var(--tinta-suave); margin-top: .5rem;
    font-variant-numeric: tabular-nums;
}

/* Sello de estado */

.sellos { position: absolute; top: 1.4rem; right: 1.6rem; display: flex; flex-direction: column; gap: .5rem; align-items: flex-end; }

.sello {
    font-family: var(--mono); font-size: .72rem; font-weight: 600;
    letter-spacing: .14em; text-transform: uppercase;
    padding: .35rem .75rem;
    border: 2px solid currentColor; border-radius: 3px;
    transform: rotate(2.5deg);
    animation: sello-cae .35s cubic-bezier(.2, 1.4, .4, 1) both;
}

.sello:nth-child(2) { transform: rotate(-1.5deg); animation-delay: .12s; }

@keyframes sello-cae {
    from { opacity: 0; transform: scale(1.5) rotate(8deg); }
    to { opacity: 1; }
}

.sello.ok { color: var(--verde); background: var(--verde-papel); }
.sello.no { color: var(--rojo-tinta); background: var(--rojo-papel); }

/* Domicilios */

.ficha-seccion {
    margin-top: 1.75rem; padding-top: 1.4rem;
    border-top: 1px dashed var(--linea-fuerte);
}

.ficha-seccion-tit {
    font-family: var(--mono); font-size: .68rem; letter-spacing: .18em;
    text-transform: uppercase; color: var(--tinta-tenue);
    margin-bottom: .9rem;
}

.domicilio { display: grid; grid-template-columns: 96px 1fr; gap: .35rem 1.1rem; padding: .8rem 0; }
.domicilio + .domicilio { border-top: 1px solid var(--linea); }

.domicilio-tipo {
    grid-row: span 2;
    font-family: var(--mono); font-size: .7rem; font-weight: 600;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--rojo-tinta); padding-top: .15rem;
}

.domicilio-dir { font-size: .98rem; font-weight: 500; }
.domicilio-meta { font-size: .82rem; color: var(--tinta-tenue); font-family: var(--mono); }

.ficha-fuente {
    margin-top: 1.6rem; padding-top: 1.1rem;
    border-top: 1px dashed var(--linea-fuerte);
    font-size: .8rem; color: var(--tinta-tenue);
    display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
}

.ficha-fuente.desactualizada { color: var(--ambar); }

/* ---------- Bandas de la portada ---------- */

.banda { border-top: 1px solid var(--linea); padding: 3rem 0; }

.banda h2 {
    font-family: var(--serif); font-size: 1.5rem; font-weight: 700;
    letter-spacing: -.015em; margin-bottom: 1.4rem;
}

.tarjetas { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }

.tarjeta {
    background: var(--papel-alto); border: 1px solid var(--linea);
    border-radius: var(--radio); padding: 1.3rem 1.4rem;
}

.tarjeta .num {
    font-family: var(--serif); font-size: 1.9rem; font-weight: 700;
    color: var(--rojo); line-height: 1;
}

.tarjeta h3 { font-size: .98rem; font-weight: 600; margin-top: .55rem; }
.tarjeta p { font-size: .88rem; color: var(--tinta-suave); margin-top: .3rem; }

.banda-api {
    display: grid; grid-template-columns: 1fr 1.1fr; gap: 2.5rem; align-items: center;
}

.banda-api .texto p { color: var(--tinta-suave); margin-top: .6rem; max-width: 44ch; }

.boton-secundario {
    display: inline-block; margin-top: 1.2rem;
    padding: .6rem 1.2rem; border-radius: 8px;
    border: 1.5px solid var(--tinta); color: var(--tinta);
    font-weight: 600; font-size: .95rem; text-decoration: none;
    transition: background var(--transicion), color var(--transicion);
}

.boton-secundario:hover { background: var(--tinta); color: var(--papel-alto); }

/* ---------- Bloques de código ---------- */

.codigo {
    background: var(--tinta); color: #e8e2d6;
    border-radius: 10px; padding: 1.1rem 1.3rem;
    font-family: var(--mono); font-size: .84rem; line-height: 1.65;
    overflow-x: auto;
    box-shadow: var(--sombra-ficha);
}

.codigo .cmd { color: #f3b6bb; }
.codigo .cmd::before { content: "$ "; color: var(--rojo); font-weight: 600; }
.codigo .resa { color: #9ec99f; }
.codigo .clave { color: #d8a657; }

/* ---------- Documentación ---------- */

.docs { padding: 3.5rem 0 4rem; }

.docs-cabeza { margin-bottom: 2.5rem; }

.docs-cabeza h1 {
    font-family: var(--serif); font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 700; letter-spacing: -.02em; line-height: 1.08;
}

.docs-cabeza p { margin-top: .8rem; font-size: 1.05rem; color: var(--tinta-suave); max-width: 56ch; }

.docs h2 {
    font-family: var(--serif); font-size: 1.45rem; font-weight: 700;
    letter-spacing: -.015em;
    margin: 2.8rem 0 1rem;
    padding-top: 2.2rem; border-top: 1px solid var(--linea);
}

.docs h2:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }

.docs p { color: var(--tinta-suave); margin-bottom: .9rem; max-width: 68ch; }
.docs p strong { color: var(--tinta); }

.docs .codigo { margin: 1.1rem 0 1.4rem; }

.endpoint {
    display: flex; align-items: center; gap: .7rem; flex-wrap: wrap;
    font-family: var(--mono); font-size: .95rem;
    background: var(--papel-alto); border: 1px solid var(--linea-fuerte);
    border-left: 4px solid var(--rojo);
    padding: .8rem 1.1rem; border-radius: var(--radio);
    margin: 1.1rem 0;
}

.endpoint .metodo { color: var(--verde); font-weight: 600; }

.tabla { width: 100%; border-collapse: collapse; margin: 1.1rem 0 1.6rem; font-size: .9rem; }
.tabla th {
    text-align: left; font-family: var(--mono); font-size: .68rem;
    letter-spacing: .14em; text-transform: uppercase; color: var(--tinta-tenue);
    padding: .55rem .8rem; border-bottom: 2px solid var(--linea-fuerte);
}
.tabla td { padding: .65rem .8rem; border-bottom: 1px solid var(--linea); vertical-align: top; }
.tabla td:first-child { font-family: var(--mono); font-size: .84rem; white-space: nowrap; }
.tabla .si { color: var(--verde); font-weight: 600; }

code.inline {
    font-family: var(--mono); font-size: .85em;
    background: var(--papel-hundido); border: 1px solid var(--linea);
    padding: .1rem .35rem; border-radius: 4px;
}

/* ---------- Formularios de cuenta ---------- */

.cuenta { padding: 4rem 0; }

.cuenta-caja {
    max-width: 430px; margin: 0 auto;
    background: var(--papel-alto);
    border: 1px solid var(--linea-fuerte); border-radius: var(--radio);
    box-shadow: var(--sombra-ficha);
    overflow: hidden;
    animation: ficha-entra .4s both;
}

.cuenta-franja { height: 5px; background: var(--rojo); }

.cuenta-cuerpo { padding: 2rem 2.1rem 2.2rem; }

.cuenta-cuerpo h1 {
    font-family: var(--serif); font-size: 1.7rem; font-weight: 700;
    letter-spacing: -.02em; margin-bottom: .4rem;
}

.cuenta-sub { font-size: .93rem; color: var(--tinta-suave); margin-bottom: 1.6rem; }

.campo { margin-bottom: 1.1rem; }

.campo label { display: block; font-size: .85rem; font-weight: 600; margin-bottom: .35rem; }

.campo input {
    width: 100%; font-family: var(--sans); font-size: 1rem;
    padding: .65rem .8rem;
    background: var(--papel); color: var(--tinta);
    border: 1.5px solid var(--linea-fuerte); border-radius: 8px;
    transition: border-color var(--transicion), box-shadow var(--transicion);
}

.campo input:focus {
    outline: none; border-color: var(--rojo);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--rojo) 12%, transparent);
}

.campo .error-texto { display: block; margin-top: .35rem; font-size: .82rem; color: var(--rojo-tinta); }

.boton-principal {
    width: 100%; margin-top: .4rem;
    border: 0; cursor: pointer; border-radius: 8px;
    background: var(--rojo); color: var(--papel-alto);
    font-family: var(--sans); font-weight: 600; font-size: 1rem;
    padding: .75rem 1rem;
    transition: background var(--transicion), transform var(--transicion);
}

.boton-principal:hover { background: var(--rojo-tinta); transform: translateY(-1px); }

.cuenta-pie { margin-top: 1.4rem; font-size: .88rem; color: var(--tinta-suave); text-align: center; }
.cuenta-pie a { color: var(--rojo-tinta); font-weight: 600; text-decoration: none; }
.cuenta-pie a:hover { text-decoration: underline; }

/* ---------- Panel ---------- */

.panel { padding: 3.5rem 0 4rem; }

.panel-cabeza { display: flex; align-items: baseline; gap: 1rem; flex-wrap: wrap; margin-bottom: 2rem; }

.panel-cabeza h1 {
    font-family: var(--serif); font-size: 2rem; font-weight: 700; letter-spacing: -.02em;
}

.panel-cabeza .saludo { color: var(--tinta-tenue); font-size: .95rem; }

.aviso-ok {
    background: var(--verde-papel); color: var(--verde);
    border: 1px solid color-mix(in srgb, var(--verde) 30%, var(--linea));
    padding: .8rem 1.1rem; border-radius: var(--radio);
    font-size: .92rem; font-weight: 500; margin-bottom: 1.5rem;
    animation: aparece .4s both;
}

.key-ficha {
    background: var(--papel-alto); border: 1px solid var(--linea-fuerte);
    border-radius: var(--radio); box-shadow: var(--sombra-ficha);
    overflow: hidden; margin-bottom: 2rem;
}

.key-franja { height: 5px; background: repeating-linear-gradient(135deg, var(--rojo) 0 14px, var(--papel-alto) 14px 20px, var(--rojo) 20px 34px); }

.key-cuerpo { padding: 1.7rem 1.9rem 1.9rem; }

.key-cuerpo h2 { font-family: var(--serif); font-size: 1.25rem; font-weight: 700; margin-bottom: .35rem; }
.key-cuerpo > p { font-size: .9rem; color: var(--tinta-suave); margin-bottom: 1.2rem; max-width: 60ch; }

.key-valor {
    display: flex; gap: .5rem; align-items: center;
    background: var(--tinta); border-radius: 10px;
    padding: .85rem 1.1rem;
}

.key-valor code {
    flex: 1; min-width: 0;
    font-family: var(--mono); font-size: .88rem; letter-spacing: .04em;
    color: #e8e2d6; word-break: break-all;
}

.key-copiar {
    flex-shrink: 0; border: 1px solid #4a453e; cursor: pointer;
    background: transparent; color: #cfc8ba;
    font-family: var(--sans); font-size: .8rem; font-weight: 600;
    padding: .4rem .8rem; border-radius: 6px;
    transition: background var(--transicion), color var(--transicion);
}

.key-copiar:hover { background: #38332d; color: var(--papel-alto); }
.key-copiar.copiado { background: var(--verde); border-color: var(--verde); color: #fff; }

.key-meta { margin-top: .8rem; font-size: .8rem; color: var(--tinta-tenue); font-family: var(--mono); }

.key-acciones { margin-top: 1.4rem; display: flex; gap: .8rem; align-items: center; flex-wrap: wrap; }

.boton-peligro {
    border: 1.5px solid var(--rojo-tinta); background: transparent; cursor: pointer;
    color: var(--rojo-tinta); font-family: var(--sans); font-weight: 600; font-size: .88rem;
    padding: .5rem 1rem; border-radius: 8px;
    transition: background var(--transicion), color var(--transicion);
}

.boton-peligro:hover { background: var(--rojo-tinta); color: var(--papel-alto); }

.key-acciones .nota { font-size: .8rem; color: var(--tinta-tenue); }

.panel h2.seccion {
    font-family: var(--serif); font-size: 1.3rem; font-weight: 700;
    margin: 2.2rem 0 1rem;
}

.limites { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.5rem; }

.limite {
    background: var(--papel-alto); border: 1px solid var(--linea);
    border-radius: var(--radio); padding: 1.1rem 1.3rem;
}

.limite .cifra { font-family: var(--serif); font-size: 1.7rem; font-weight: 700; }
.limite.destacado .cifra { color: var(--rojo); }
.limite .desc { font-size: .85rem; color: var(--tinta-suave); margin-top: .2rem; }

/* ---------- Pie ---------- */

.pie { border-top: 1px solid var(--linea); padding: 2rem 0 2.5rem; margin-top: 4rem; }

.pie-fila { display: flex; flex-direction: column; gap: .5rem; }

.pie-marca { font-family: var(--serif); font-weight: 700; font-size: 1rem; }
.pie-marca em { font-style: normal; color: var(--rojo); }
.pie-sep { color: var(--tinta-tenue); font-weight: 400; }

.pie-nota { font-size: .8rem; color: var(--tinta-tenue); max-width: 64ch; }

.pie-nav { display: flex; gap: 1.4rem; margin-top: .4rem; }
.pie-nav a { font-size: .84rem; color: var(--tinta-suave); text-decoration: none; }
.pie-nav a:hover { color: var(--rojo-tinta); }

/* ---------- Animaciones y utilidades ---------- */

@keyframes aparece {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: none; }
}

.oculto { display: none !important; }

@media (max-width: 720px) {
    .tarjetas { grid-template-columns: 1fr; }
    .banda-api { grid-template-columns: 1fr; gap: 1.5rem; }
    .limites { grid-template-columns: 1fr; }
    .sellos { position: static; flex-direction: row; margin-bottom: 1rem; }
    .ficha-cuerpo { padding: 1.4rem 1.3rem 1.5rem; }
    .domicilio { grid-template-columns: 1fr; }
    .domicilio-tipo { grid-row: auto; }
    .nav { gap: .9rem; }
    .nav a:not(.nav-cta):not(.activo) { display: none; }
    .hero { padding-top: 3rem; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
    html { scroll-behavior: auto; }
}
