/* =====================================================================
   Grupo Nam Nam - sistema de diseno base
   Paleta: blanco hueso / negro / acento terracota
   ===================================================================== */

:root {
    /* Paleta */
    --c-bg:          #faf7f2;
    --c-surface:     #ffffff;
    --c-surface-2:   #f3ede4;
    --c-border:      #e3dccf;
    --c-border-2:    #cdc4b3;
    --c-ink:         #1c1a17;
    --c-ink-2:       #4a4540;
    --c-muted:       #7a7268;

    --c-accent:      #b85c38;        /* terracota */
    --c-accent-700:  #964627;
    --c-accent-50:   #fbece4;

    --c-secondary:   #2c2a26;        /* negro calido */
    --c-success:     #2d6a4f;
    --c-success-50:  #e6f1ec;
    --c-danger:      #b3261e;
    --c-danger-50:   #fbe5e3;
    --c-warning:     #b08000;
    --c-warning-50:  #fbf3d8;

    /* Tipografia */
    --font-sans:  'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --font-serif: 'Fraunces', Georgia, 'Times New Roman', serif;

    /* Espaciado (escala 4px) */
    --sp-1: 4px;   --sp-2: 8px;   --sp-3: 12px;
    --sp-4: 16px;  --sp-5: 20px;  --sp-6: 24px;
    --sp-8: 32px;  --sp-10: 40px; --sp-12: 48px;
    --sp-16: 64px;

    /* Radio + sombra */
    --r-sm: 6px;
    --r-md: 10px;
    --r-lg: 16px;
    --r-pill: 999px;
    --shadow-sm: 0 1px 2px rgba(28, 26, 23, 0.06);
    --shadow-md: 0 6px 18px rgba(28, 26, 23, 0.08);
    --shadow-lg: 0 18px 48px rgba(28, 26, 23, 0.14);
}

*, *::before, *::after { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    font-family: var(--font-sans);
    color: var(--c-ink);
    background: var(--c-bg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a { color: var(--c-accent-700); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3, h4 {
    font-family: var(--font-serif);
    color: var(--c-ink);
    margin: 0 0 var(--sp-3);
    letter-spacing: -0.01em;
}
h1 { font-size: 1.875rem; }
h2 { font-size: 1.375rem; }
h3 { font-size: 1.125rem; }

p { line-height: 1.55; color: var(--c-ink-2); margin: 0 0 var(--sp-3); }

/* ---------- Botones ---------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-2);
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: 0.95rem;
    line-height: 1;
    padding: 12px 18px;
    border-radius: var(--r-md);
    border: 1px solid transparent;
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease, transform 0.05s ease;
    text-decoration: none;
}
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: 2px solid var(--c-accent); outline-offset: 2px; }

.btn--primary   { background: var(--c-accent); color: #fff; }
.btn--primary:hover { background: var(--c-accent-700); text-decoration: none; }

.btn--secondary { background: var(--c-surface); color: var(--c-ink); border-color: var(--c-border-2); }
.btn--secondary:hover { background: var(--c-surface-2); text-decoration: none; }

.btn--ghost     { background: transparent; color: var(--c-ink-2); border-color: transparent; }
.btn--ghost:hover { background: var(--c-surface-2); color: var(--c-ink); text-decoration: none; }

.btn--danger    { background: var(--c-danger); color: #fff; }
.btn--danger:hover { background: #8e1d18; text-decoration: none; }

.btn--block { width: 100%; }
.btn--lg    { padding: 16px 22px; font-size: 1rem; }

/* ---------- Formularios ---------- */
.form { display: flex; flex-direction: column; gap: var(--sp-4); }

.field { display: flex; flex-direction: column; gap: var(--sp-2); }
.field__label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--c-ink-2);
    letter-spacing: 0.01em;
}
.field__input {
    font-family: var(--font-sans);
    font-size: 0.95rem;
    padding: 11px 14px;
    border: 1px solid var(--c-border);
    border-radius: var(--r-md);
    background: var(--c-surface);
    color: var(--c-ink);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.field__input:hover { border-color: var(--c-border-2); }
.field__input:focus {
    outline: none;
    border-color: var(--c-accent);
    box-shadow: 0 0 0 3px var(--c-accent-50);
}
.field__input--error {
    border-color: var(--c-danger);
    background: var(--c-danger-50);
}
.field__error {
    margin: 0;
    font-size: 0.85rem;
    color: var(--c-danger);
}
.field__hint {
    margin: 0;
    font-size: 0.78rem;
    color: var(--c-muted);
}

select.field__input {
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%237a7268' d='M6 8 0 0h12z'/></svg>");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

/* ---------- Alertas ---------- */
.alert {
    border-radius: var(--r-md);
    padding: 12px 16px;
    margin-bottom: var(--sp-4);
    font-size: 0.95rem;
    border: 1px solid transparent;
    animation: alert-slide-in 0.25s ease;
    line-height: 1.4;
}
.alert--success { background: var(--c-success-50); border-color: #b8d6c5; color: var(--c-success); }
.alert--error   { background: var(--c-danger-50);  border-color: #e9b6b3; color: var(--c-danger); }
.alert--warning { background: var(--c-warning-50); border-color: #e7d28a; color: var(--c-warning); }
.alert--info    { background: var(--c-accent-50);  border-color: #f0d4c0; color: var(--c-accent-700); }

.alert--dismissible {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
}
.alert__msg { flex: 1 1 auto; }
.alert__close {
    flex: 0 0 auto;
    background: transparent;
    border: 0;
    color: inherit;
    font-size: 1.4rem;
    line-height: 1;
    cursor: pointer;
    padding: 0 4px;
    opacity: 0.7;
    transition: opacity 0.15s;
}
.alert__close:hover { opacity: 1; }

@keyframes alert-slide-in {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ---------- Card ---------- */
.card {
    background: var(--c-surface);
    border: 1px solid var(--c-border);
    border-radius: var(--r-lg);
    padding: var(--sp-6);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--sp-6);
}
.card__title { margin-bottom: var(--sp-2); }
.card__lede  { color: var(--c-ink-2); margin-bottom: var(--sp-4); }

/* ---------- Grid ---------- */
.grid { display: grid; gap: var(--sp-4); }
.grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 1100px) { .grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 768px)  { .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; } }

/* ---------- KPI ---------- */
.kpi {
    background: var(--c-surface);
    border: 1px solid var(--c-border);
    border-radius: var(--r-lg);
    padding: var(--sp-5);
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
    box-shadow: var(--shadow-sm);
    text-decoration: none;
    color: inherit;
    transition: transform 0.1s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.kpi--link:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
    border-color: var(--c-border-2);
    text-decoration: none;
}
.kpi--warning {
    background: var(--c-warning-50);
    border-color: #e7d28a;
}
.kpi--warning .kpi__value { color: var(--c-warning); }
.kpi__label {
    font-size: 0.78rem;
    color: var(--c-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}
.kpi__value {
    font-family: var(--font-serif);
    font-size: 2.25rem;
    color: var(--c-ink);
    line-height: 1.05;
}
.kpi__hint {
    font-size: 0.78rem;
    color: var(--c-muted);
}

/* ---------- Card extras ---------- */
.card__cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-2);
    margin-top: var(--sp-2);
}

/* ---------- Page head (encabezado de paginas CRUD) ---------- */
.page-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--sp-4);
    flex-wrap: wrap;
    margin-bottom: var(--sp-5);
}
.page-head__title {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    margin: 0 0 var(--sp-1);
}
.page-head__lede {
    color: var(--c-ink-2);
    margin: 0;
    max-width: 60ch;
}
.page-head__actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }

/* ---------- Toolbar (filtros / busqueda) ---------- */
.toolbar {
    display: flex;
    gap: var(--sp-2);
    flex-wrap: wrap;
    margin-bottom: var(--sp-4);
    background: var(--c-surface);
    border: 1px solid var(--c-border);
    border-radius: var(--r-md);
    padding: var(--sp-3);
}
.toolbar__search {
    flex: 1 1 280px;
    min-width: 200px;
    font-family: var(--font-sans);
    font-size: 0.95rem;
    padding: 10px 14px;
    border: 1px solid var(--c-border);
    border-radius: var(--r-md);
    background: var(--c-bg);
    color: var(--c-ink);
}
.toolbar__search:focus {
    outline: none;
    border-color: var(--c-accent);
    box-shadow: 0 0 0 3px var(--c-accent-50);
    background: var(--c-surface);
}
.toolbar__select { flex: 0 1 240px; padding-top: 10px; padding-bottom: 10px; }

/* ---------- Tabla ---------- */
.table-wrap {
    background: var(--c-surface);
    border: 1px solid var(--c-border);
    border-radius: var(--r-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}
.table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
}
.table thead th {
    text-align: left;
    background: var(--c-surface-2);
    color: var(--c-ink-2);
    font-weight: 600;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 12px 16px;
    border-bottom: 1px solid var(--c-border);
    white-space: nowrap;
}
.table tbody tr {
    border-bottom: 1px solid var(--c-border);
    transition: background 0.1s ease;
}
.table tbody tr:last-child { border-bottom: none; }
.table tbody tr:nth-child(even) { background: rgba(243, 237, 228, 0.35); }
.table tbody tr:hover { background: var(--c-accent-50); }
.table td {
    padding: 12px 16px;
    color: var(--c-ink);
    vertical-align: middle;
}
.table__col-num { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.table__col-narrow { width: 1%; white-space: nowrap; }
.table__col-actions { width: 1%; white-space: nowrap; text-align: right; }
.table__link { color: var(--c-ink); font-weight: 600; }
.table__link:hover { color: var(--c-accent-700); text-decoration: none; }
.table-foot {
    margin: var(--sp-3) 0 0;
    color: var(--c-muted);
    font-size: 0.85rem;
}

@media (max-width: 768px) {
    .table thead { display: none; }
    .table, .table tbody, .table tr, .table td { display: block; width: 100%; }
    .table tr { padding: var(--sp-3) var(--sp-4); }
    .table td { padding: 4px 0; border: none; }
    .table td.table__col-actions { text-align: left; padding-top: var(--sp-3); }
    .table td.table__col-num { text-align: left; }
}

/* ---------- Badges / etiquetas ---------- */
.badge {
    display: inline-block;
    background: var(--c-secondary);
    color: #fff;
    font-family: var(--font-sans);
    font-size: 0.78rem;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: var(--r-pill);
    letter-spacing: 0.04em;
}
.badge--soft    { background: var(--c-surface-2); color: var(--c-ink-2); border: 1px solid var(--c-border); }
.badge--accent  { background: var(--c-accent-50); color: var(--c-accent-700); border: 1px solid #f0d4c0; }
.badge--warning { background: var(--c-warning-50); color: var(--c-warning); border: 1px solid #e7d28a; }

.muted { color: var(--c-muted); }

/* ---------- Botones extra ---------- */
.btn--sm { padding: 7px 12px; font-size: 0.85rem; }

/* ---------- Acciones de fila ---------- */
.row-actions { display: inline-flex; gap: var(--sp-2); align-items: center; justify-content: flex-end; }
.row-actions__form { margin: 0; }

/* ---------- Empty state ---------- */
.empty-state {
    background: var(--c-surface);
    border: 1px dashed var(--c-border-2);
    border-radius: var(--r-lg);
    padding: var(--sp-10) var(--sp-6);
    text-align: center;
}
.empty-state__title {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    margin: 0 0 var(--sp-2);
    color: var(--c-ink);
}
.empty-state__text {
    color: var(--c-ink-2);
    margin: 0 0 var(--sp-4);
}

/* ---------- Form card (formularios CRUD multi-seccion) ---------- */
.form-card {
    background: var(--c-surface);
    border: 1px solid var(--c-border);
    border-radius: var(--r-lg);
    padding: var(--sp-6);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    gap: var(--sp-6);
}
.form-card__section {
    border: none;
    border-top: 1px solid var(--c-border);
    padding: var(--sp-5) 0 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sp-4);
}
.form-card__section:first-of-type {
    border-top: none;
    padding-top: 0;
}
.form-card__section legend {
    font-family: var(--font-serif);
    font-size: 1.05rem;
    color: var(--c-ink);
    padding: 0 0 var(--sp-2);
    font-weight: 700;
}
.form-card__actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--sp-2);
    border-top: 1px solid var(--c-border);
    padding-top: var(--sp-5);
}

.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--sp-4); }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--sp-4); }
@media (max-width: 768px) {
    .grid-2, .grid-3 { grid-template-columns: 1fr; }
}

/* ---------- Tabla editable (lineas de albaran) ---------- */
.lineas-wrap {
    overflow-x: auto;
    border: 1px solid var(--c-border);
    border-radius: var(--r-md);
    background: var(--c-surface);
}
.table--editable {
    width: 100%;
    min-width: 880px;
}
.table--editable thead th {
    background: var(--c-surface-2);
    padding: 10px 10px;
}
.table--editable tbody tr {
    background: var(--c-surface);
}
.table--editable tbody tr:nth-child(even) { background: rgba(243, 237, 228, 0.25); }
.table--editable tbody tr:hover { background: var(--c-surface); }
.table--editable td {
    padding: 6px 10px;
    vertical-align: middle;
}
.table--editable .field__input {
    padding: 7px 10px;
    font-size: 0.9rem;
    width: 100%;
}
.table--editable .field__input--num {
    text-align: right;
    font-variant-numeric: tabular-nums;
}
.table--editable .linea__num {
    color: var(--c-muted);
    font-weight: 600;
    font-size: 0.85rem;
}
.table--editable .linea__subtotal {
    font-variant-numeric: tabular-nums;
    font-weight: 600;
    white-space: nowrap;
}
.table--editable .linea__remove {
    font-size: 1.3rem;
    line-height: 1;
    padding: 2px 10px;
    color: var(--c-danger);
}
.table--editable .linea__remove:hover {
    background: var(--c-danger-50);
    color: var(--c-danger);
}

/* ---------- Caja de totales ---------- */
.totals-box {
    background: var(--c-surface-2);
    border: 1px solid var(--c-border);
    border-radius: var(--r-md);
    padding: var(--sp-4);
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
    align-self: end;
}
.totals-box__row {
    display: flex;
    justify-content: space-between;
    gap: var(--sp-4);
    color: var(--c-ink-2);
    font-size: 0.95rem;
}
.totals-box__row strong { font-variant-numeric: tabular-nums; color: var(--c-ink); }
.totals-box__row--total {
    border-top: 1px solid var(--c-border);
    padding-top: var(--sp-3);
    font-size: 1.1rem;
    color: var(--c-ink);
}
.totals-box__row--total strong {
    font-family: var(--font-serif);
    font-size: 1.4rem;
    color: var(--c-accent-700);
}
.totals-box--show { max-width: 360px; margin-left: auto; margin-top: var(--sp-4); }

/* ---------- Show albaran ---------- */
.show-field {
    margin: 4px 0 0;
    font-weight: 600;
    color: var(--c-ink);
}

/* ---------- Ranking (top proveedores) ---------- */
.ranking {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
}
.ranking__item {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    padding: var(--sp-3);
    background: var(--c-surface-2);
    border: 1px solid var(--c-border);
    border-radius: var(--r-md);
}
.ranking__pos {
    flex: 0 0 auto;
    width: 32px; height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--c-accent);
    color: #fff;
    font-family: var(--font-serif);
    font-weight: 700;
    border-radius: var(--r-pill);
}
.ranking__body { display: flex; flex-direction: column; flex: 1 1 auto; min-width: 0; }
.ranking__name { color: var(--c-ink); font-weight: 600; }
.ranking__name:hover { color: var(--c-accent-700); }
.ranking__hint { color: var(--c-muted); font-size: 0.78rem; }
.ranking__amount {
    font-variant-numeric: tabular-nums;
    color: var(--c-accent-700);
    font-family: var(--font-serif);
    font-size: 1.1rem;
}
