/* ============================================================================
   DeCA — Pretium Gestion · App shell (slice 1, cimientos)
   Usa SIEMPRE los tokens de tokens.css. No hardcodear colores/medidas aqui.
   Layout fiel al diseno: sidebar 248/68px + topbar 56px + contenido max 1280px.
   ============================================================================ */

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    line-height: var(--lh-body);
}

a { color: var(--color-primary-600); }

.visually-hidden {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

.skip-link {
    position: absolute; left: -999px; top: 0; z-index: var(--z-toast);
    background: var(--color-primary-600); color: var(--color-text-invert);
    padding: var(--sp-2) var(--sp-4); border-radius: 0 0 var(--r-md) 0;
}
.skip-link:focus { left: 0; }

/* ---- Estructura ---- */
.app-shell { display: flex; min-height: 100vh; }
.app-body { flex: 1; display: flex; flex-direction: column; min-width: 0; }

.app-main {
    flex: 1;
    padding: var(--sp-6);
    max-width: var(--content-max);
    width: 100%;
    margin: 0 auto;
    outline: none;
}

/* ---- Sidebar ---- */
.sidebar {
    width: var(--sidebar-w);
    background: var(--color-primary-700);
    color: var(--color-text-invert);
    display: flex;
    flex-direction: column;
    transition: width var(--dur-base) var(--ease);
    overflow: hidden;
}
.sidebar__brand {
    display: flex; align-items: center; gap: var(--sp-3);
    height: var(--topbar-h); padding: 0 var(--sp-4);
    flex-shrink: 0;
}
.brand-tile {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: var(--r-md);
    background: var(--color-primary-600); color: var(--color-text-invert);
    flex-shrink: 0;
}
.brand-text { font-weight: 600; font-size: var(--fs-h3); white-space: nowrap; }

.sidebar__nav { padding: var(--sp-3) var(--sp-2); overflow-y: auto; }
.nav-group {
    margin: var(--sp-3) var(--sp-2) var(--sp-1);
    font-size: var(--fs-caption); font-weight: var(--fw-label);
    text-transform: uppercase; letter-spacing: .04em;
    color: rgba(255, 255, 255, .55); white-space: nowrap;
}
.nav-list { list-style: none; margin: 0; padding: 0; }
.nav-item {
    display: flex; align-items: center; gap: var(--sp-3);
    padding: var(--sp-2) var(--sp-3); margin-bottom: 2px;
    border-radius: var(--r-md);
    color: rgba(255, 255, 255, .82); text-decoration: none;
    white-space: nowrap;
    transition: background var(--dur-fast) var(--ease);
}
.nav-item:hover { background: rgba(255, 255, 255, .07); color: var(--color-text-invert); }
.nav-item.is-active {
    background: rgba(255, 255, 255, .12); color: var(--color-text-invert);
    box-shadow: inset 3px 0 0 var(--color-accent-600);
}
.nav-item__icon { display: inline-flex; flex-shrink: 0; }

/* Sidebar contraida (68px): solo iconos */
.app-shell.is-collapsed .sidebar { width: 68px; }
.app-shell.is-collapsed .brand-text,
.app-shell.is-collapsed .nav-group,
.app-shell.is-collapsed .nav-item__label { display: none; }
.app-shell.is-collapsed .nav-item { justify-content: center; }
.app-shell.is-collapsed .sidebar__brand { justify-content: center; padding: 0; }

/* ---- Topbar ---- */
.topbar {
    height: var(--topbar-h); flex-shrink: 0;
    display: flex; align-items: center; gap: var(--sp-4);
    padding: 0 var(--sp-5);
    background: var(--color-surface);
    border-bottom: var(--bw-1) solid var(--color-border);
}
.icon-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border: none; border-radius: var(--r-md);
    background: transparent; color: var(--color-text-muted); cursor: pointer;
}
.icon-btn:hover { background: var(--color-surface-2); color: var(--color-text); }

.topbar__search {
    display: flex; align-items: center; gap: var(--sp-2);
    flex: 1; max-width: 420px;
    padding: 0 var(--sp-3); height: 36px;
    background: var(--color-surface-2);
    border: var(--bw-1) solid var(--color-border);
    border-radius: var(--r-md);
    color: var(--color-text-muted);
}
.topbar__search input {
    border: none; background: transparent; outline: none;
    flex: 1; font: inherit; color: var(--color-text);
}
.topbar__right { display: flex; align-items: center; gap: var(--sp-3); margin-left: auto; }

.lang-switch { display: flex; align-items: center; gap: var(--sp-2); color: var(--color-text-muted); }
.lang-switch select {
    border: var(--bw-1) solid var(--color-border-strong);
    border-radius: var(--r-md); background: var(--color-surface);
    color: var(--color-text); font: inherit; padding: var(--sp-1) var(--sp-2);
}

.account-avatar {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: var(--r-pill);
    background: var(--color-primary-600); color: var(--color-text-invert);
    font-weight: 600; font-size: var(--fs-label);
}

/* ---- Foco accesible (AA) ---- */
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, [tabindex]:focus-visible {
    outline: none; box-shadow: var(--sh-focus);
    border-radius: var(--r-sm);
}

/* ---- Contenido ---- */
.page-header { margin-bottom: var(--sp-5); }
.page-title { font-size: var(--fs-h1); line-height: var(--lh-h1); font-weight: var(--fw-h1); margin: 0; }
.page-subtitle { color: var(--color-text-muted); margin: var(--sp-1) 0 0; }

.card {
    background: var(--color-surface);
    border: var(--bw-1) solid var(--color-border);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
    padding: var(--sp-5);
    margin-bottom: var(--sp-4);
}

.mono { font-family: var(--font-mono); font-size: var(--fs-mono); }
.text-muted { color: var(--color-text-muted); }

/* ---- Barra de cuota ---- */
.quota-label { margin: 0 0 var(--sp-2); font-weight: var(--fw-label); }
.quota-bar {
    height: 8px; border-radius: var(--r-pill);
    background: var(--color-surface-3); overflow: hidden;
}
.quota-bar__fill {
    display: block; height: 100%;
    background: var(--color-accent-600);
    transition: width var(--dur-base) var(--ease);
}
.quota-bar__fill.is-warn { background: var(--color-warning); }
.quota-bar__fill.is-full { background: var(--color-danger); }

/* ============================================================================
   Autenticacion (split: panel de marca + tarjeta)
   ============================================================================ */
.auth-split { display: flex; min-height: 100vh; }
.auth-panel {
    width: 40%; max-width: 480px;
    background: var(--color-primary-700); color: var(--color-text-invert);
    padding: var(--sp-8); display: flex; flex-direction: column;
}
.auth-panel__brand { display: flex; align-items: center; gap: var(--sp-3); }
.auth-panel__name { font-size: var(--fs-h2); font-weight: 600; }
.auth-panel__tagline { margin-top: var(--sp-4); color: rgba(255,255,255,.82); font-size: var(--fs-body-lg); line-height: var(--lh-body-lg); }
.auth-panel__foot { margin-top: auto; opacity: .9; }

.auth-main {
    flex: 1; display: flex; flex-direction: column;
    align-items: center; justify-content: center; padding: var(--sp-6); gap: var(--sp-4);
}
.auth-card {
    width: 100%; max-width: 420px;
    background: var(--color-surface); border: var(--bw-1) solid var(--color-border);
    border-radius: var(--r-lg); box-shadow: var(--sh-md); padding: var(--sp-7);
}
.auth-title { font-size: var(--fs-h1); line-height: var(--lh-h1); font-weight: var(--fw-h1); margin: 0 0 var(--sp-2); }
.auth-sub { color: var(--color-text-muted); margin: 0 0 var(--sp-5); }
.auth-form { display: flex; flex-direction: column; gap: var(--sp-4); }
.auth-links { display: flex; justify-content: space-between; gap: var(--sp-3); margin-top: var(--sp-4); font-size: var(--fs-label); }
.auth-lang select { border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); background: var(--color-surface); color: var(--color-text); font: inherit; padding: var(--sp-1) var(--sp-2); }

.form-field { display: flex; flex-direction: column; gap: var(--sp-1); }
.form-label { font-size: var(--fs-label); font-weight: var(--fw-label); color: var(--color-text); }
.form-hint { font-size: var(--fs-caption); color: var(--color-text-muted); }
.form-field input, .form-field select {
    font: inherit; color: var(--color-text);
    padding: var(--sp-2) var(--sp-3);
    border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md);
    background: var(--color-surface);
}
.form-field input.is-error { border-color: var(--color-danger); }
.form-check { display: flex; align-items: flex-start; gap: var(--sp-2); font-size: var(--fs-label); color: var(--color-text-muted); }
.form-check input { margin-top: 2px; }
.form-alert { padding: var(--sp-3); border-radius: var(--r-md); font-size: var(--fs-label); margin-bottom: var(--sp-4); }
.form-alert--error { background: var(--color-danger-bg); color: var(--color-danger); border: var(--bw-1) solid var(--color-danger); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
    font: inherit; font-weight: 600; cursor: pointer;
    padding: var(--sp-3) var(--sp-5); border-radius: var(--r-md); border: var(--bw-1) solid transparent;
    text-decoration: none; }
.btn--accent { background: var(--color-accent-600); color: var(--color-on-accent); }
.btn--accent:hover { background: var(--color-accent-700); }
.btn--primary { background: var(--color-primary-600); color: var(--color-text-invert); }
.btn--primary:hover { background: var(--color-primary-700); }
.btn--block { width: 100%; }

@media (max-width: 768px) { .auth-panel { display: none; } }

/* ---- Responsive: sidebar oculta en movil ---- */
@media (max-width: 768px) {
    .sidebar { position: fixed; z-index: var(--z-sticky); height: 100%; transform: translateX(-100%); }
    .app-shell.is-mobile-open .sidebar { transform: translateX(0); }
}

/* ============================================================================
   crud-maestro (Slice 3): nav entidades + tabla + formulario lateral
   ============================================================================ */
.maestros {
    display: grid;
    grid-template-columns: 200px minmax(0, 1fr) 0;
    gap: var(--sp-5);
    align-items: start;
}
/* El formulario lateral ocupa columna propia cuando esta abierto (escritorio). */
.maestros.is-form-open { grid-template-columns: 200px minmax(0, 1fr) 340px; }

/* ---- Nav de entidades ---- */
.maestros__entities ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.entity-tab {
    display: flex; align-items: center; gap: var(--sp-3);
    padding: var(--sp-2) var(--sp-3); border-radius: var(--r-md);
    color: var(--color-text-muted); text-decoration: none;
    font-size: var(--fs-label); font-weight: var(--fw-label);
    transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.entity-tab:hover { background: var(--color-surface-2); color: var(--color-text); }
.entity-tab.is-active { background: var(--color-primary-100); color: var(--color-primary-700); }
.entity-tab__icon { display: inline-flex; flex-shrink: 0; }

/* ---- Toolbar (busqueda + filtro + nuevo) ---- */
.maestros__toolbar { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-4); flex-wrap: wrap; }
.maestros__filters { display: flex; align-items: center; gap: var(--sp-2); flex: 1; min-width: 0; }
.field-search {
    display: flex; align-items: center; gap: var(--sp-2);
    padding: 0 var(--sp-3); height: 36px;
    background: var(--color-surface); border: var(--bw-1) solid var(--color-border-strong);
    border-radius: var(--r-md); color: var(--color-text-muted); flex: 1; min-width: 140px;
}
.field-search input { border: none; outline: none; background: transparent; flex: 1; font: inherit; color: var(--color-text); min-width: 0; }
.maestros__filters select {
    height: 36px; border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md);
    background: var(--color-surface); color: var(--color-text); font: inherit; padding: 0 var(--sp-2);
}

/* ---- Botones auxiliares ---- */
.btn--ghost { background: var(--color-surface); color: var(--color-text); border-color: var(--color-border-strong); }
.btn--ghost:hover { background: var(--color-surface-2); }
.icon-btn--sm { width: 30px; height: 30px; }
.icon-btn--danger:hover { background: var(--color-danger-bg); color: var(--color-danger); }
.inline-form { display: inline; }

/* ---- Tabla de datos ---- */
.table-wrap { padding: 0; overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; font-size: var(--fs-body); }
.data-table th, .data-table td { text-align: left; padding: var(--sp-3) var(--sp-4); border-bottom: var(--bw-1) solid var(--color-border); }
.data-table th {
    font-size: var(--fs-caption); font-weight: var(--fw-label); text-transform: uppercase;
    letter-spacing: .04em; color: var(--color-text-muted); background: var(--color-surface-2);
    position: sticky; top: 0;
}
.data-table tbody tr:hover { background: var(--color-surface-2); }
.data-table tbody tr.is-editing { background: var(--color-primary-050); box-shadow: inset 3px 0 0 var(--color-primary-600); }
.data-table tr:last-child td { border-bottom: none; }
.col-actions { text-align: right; white-space: nowrap; }
.text-subtle { color: var(--color-text-muted); }

.state-dot { display: inline-block; width: 8px; height: 8px; border-radius: var(--r-pill); margin-right: var(--sp-2); vertical-align: middle; }
.state-dot.is-on { background: var(--color-success); }
.state-dot.is-off { background: var(--color-text-subtle); }

/* ---- Estado vacio ---- */
.empty-state { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--sp-3); padding: var(--sp-9) var(--sp-5); color: var(--color-text-muted); }
.empty-state svg { color: var(--color-text-subtle); }
.empty-state__title { font-size: var(--fs-h3); font-weight: var(--fw-h3); margin: 0; color: var(--color-text); }
.empty-state__text { margin: 0; max-width: 360px; }

/* ---- Formulario lateral (pegajoso) ---- */
.maestros__form {
    position: sticky; top: var(--sp-5);
    background: var(--color-surface); border: var(--bw-1) solid var(--color-border);
    border-radius: var(--r-lg); box-shadow: var(--sh-sm);
    padding: var(--sp-5); display: none;
}
.maestros.is-form-open .maestros__form { display: block; }
.maestros__form-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-4); }
.maestros__form-title { font-size: var(--fs-h3); font-weight: var(--fw-h3); margin: 0; }
.maestros__form-body { display: flex; flex-direction: column; gap: var(--sp-4); }
.maestros__form-note { margin: 0; }
.maestros__form-actions { display: flex; gap: var(--sp-3); justify-content: flex-end; margin-top: var(--sp-2); }
.form-error { color: var(--color-danger); font-size: var(--fs-caption); margin: 0; }
.req { color: var(--color-danger); }
.form-field select.is-error { border-color: var(--color-danger); }
.form-check--toggle { align-items: center; }

.maestros__backdrop { display: none; }

/* ---- Toast (exito) ---- */
.toast {
    position: fixed; left: 50%; bottom: var(--sp-5); transform: translateX(-50%);
    background: var(--color-primary-700); color: var(--color-text-invert);
    padding: var(--sp-3) var(--sp-5); border-radius: var(--r-md); box-shadow: var(--sh-lg);
    z-index: var(--z-toast); font-size: var(--fs-label); font-weight: var(--fw-label);
    animation: toast-in var(--dur-base) var(--ease);
}
@keyframes toast-in { from { opacity: 0; transform: translate(-50%, 8px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* ---- Responsive: <=1024 nav superior; <=768 formulario en drawer ---- */
@media (max-width: 1024px) {
    .maestros, .maestros.is-form-open { grid-template-columns: 1fr; }
    .maestros__entities ul { flex-direction: row; flex-wrap: wrap; }
    .maestros__form { position: static; }
}
@media (max-width: 768px) {
    .maestros__form {
        position: fixed; top: 0; right: 0; bottom: 0; width: min(360px, 92vw);
        border-radius: 0; z-index: var(--z-modal); overflow-y: auto;
        transform: translateX(100%); transition: transform var(--dur-base) var(--ease);
        display: block;
    }
    .maestros.is-form-open .maestros__form { transform: translateX(0); }
    .maestros.is-form-open .maestros__backdrop {
        display: block; position: fixed; inset: 0; background: rgba(20,32,40,.45);
        z-index: var(--z-backdrop);
    }
}

/* ============================================================================
   DeCA: listado, form-deca y detalle (Slice 4)
   ============================================================================ */

/* ---- Badges de estado de documento (badge solido, texto blanco; AA) ---- */
.badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: var(--r-pill); font-size: var(--fs-caption); font-weight: 600; color: #fff; white-space: nowrap; }
.badge--borrador   { background: var(--state-borrador); }
.badge--emitido    { background: var(--state-emitido); }
.badge--modificado { background: var(--state-modificado); }
.badge--anulado    { background: var(--state-anulado); }
.badge--sustituido { background: var(--state-sustituido); }
.badge--expirado   { background: var(--state-expirado); }

/* ---- Toolbar del listado ---- */
.deca-toolbar { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-4); flex-wrap: wrap; }
.deca-filters { display: flex; align-items: center; gap: var(--sp-2); flex: 1; min-width: 0; flex-wrap: wrap; }
.deca-filters select { height: 36px; border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); background: var(--color-surface); color: var(--color-text); font: inherit; padding: 0 var(--sp-2); }
.deca-toolbar__new { display: flex; gap: var(--sp-2); }
.deca-count { color: var(--color-text-muted); font-size: var(--fs-label); margin: 0 0 var(--sp-3); }
.data-table--clickable tbody tr { cursor: pointer; }

/* ---- Banner "rellena desde tus datos" ---- */
.deca-banner { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-4); background: var(--color-primary-050); border: var(--bw-1) solid var(--color-primary-100); border-radius: var(--r-lg); }
.deca-banner__text { display: flex; flex-direction: column; gap: 2px; font-size: var(--fs-label); }
.deca-banner__text span { color: var(--color-text-muted); }

/* ---- Segmented (mercancias / viajeros) ---- */
.segmented { display: inline-flex; padding: 3px; gap: 2px; background: var(--color-surface-2); border: var(--bw-1) solid var(--color-border); border-radius: var(--r-md); margin-bottom: var(--sp-4); }
.segmented__opt { padding: var(--sp-2) var(--sp-5); border-radius: var(--r-sm); text-decoration: none; color: var(--color-text-muted); font-weight: var(--fw-label); font-size: var(--fs-label); }
.segmented__opt.is-active { background: var(--color-surface); color: var(--color-primary-700); box-shadow: var(--sh-sm); }

/* ---- Rejilla form + rail ---- */
.deca-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: var(--sp-5); align-items: start; }
.deca-grid__main { min-width: 0; display: flex; flex-direction: column; gap: var(--sp-4); }
.card-title { font-size: var(--fs-h3); font-weight: var(--fw-h3); margin: 0 0 var(--sp-4); }
.form-alert--info { background: var(--color-info-bg); color: var(--color-info); border: var(--bw-1) solid var(--color-primary-100); }

/* ---- Partes diferenciadas (cargador vs transportista) ---- */
.party-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.party { border: var(--bw-1) solid var(--color-border); border-radius: var(--r-md); padding: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-3); }
.party--t { border-color: #d7e6df; }
.party--c { border-color: #d6e0ea; }
.party__head { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-label); font-weight: 600; text-transform: uppercase; letter-spacing: .02em; }
.party--t .party__head { color: var(--color-accent-700); }
.party--c .party__head { color: var(--color-primary-600); }
.party__auto { margin: 0; color: var(--color-text-muted); font-size: var(--fs-label); }
.party-name { font-weight: 600; }
.party-nif { color: var(--color-text-muted); font-size: var(--fs-label); }
.party-dom { color: var(--color-text-muted); font-size: var(--fs-label); }
.tag { width: 18px; height: 18px; border-radius: 4px; color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; }
.tag--t { background: var(--color-accent-600); } .tag--c { background: var(--color-primary-600); }

/* ---- Filas/campos del formulario ---- */
.form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--sp-4); margin-bottom: var(--sp-4); }
.deca-form .form-field { display: flex; flex-direction: column; gap: var(--sp-1); margin-bottom: var(--sp-3); }
.deca-form textarea, .deca-form input[type="text"], .deca-form input[type="date"], .deca-form select {
    font: inherit; color: var(--color-text); padding: var(--sp-2) var(--sp-3);
    border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); background: var(--color-surface);
}
.deca-form textarea { resize: vertical; }

/* ---- Combobox (popup) ---- */
.combo { position: relative; }
.combo__trigger { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--sp-2); font: inherit; text-align: left; cursor: pointer; padding: var(--sp-2) var(--sp-3); border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); background: var(--color-surface); color: var(--color-text); }
.combo__value.is-placeholder { color: var(--color-text-muted); }
.combo__pop { position: absolute; z-index: var(--z-dropdown); top: calc(100% + 4px); left: 0; right: 0; background: var(--color-surface); border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); box-shadow: var(--sh-md); padding: var(--sp-2); }
.combo__search { width: 100%; font: inherit; padding: var(--sp-2) var(--sp-3); border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-sm); margin-bottom: var(--sp-2); }
.combo__list { list-style: none; margin: 0; padding: 0; max-height: 220px; overflow-y: auto; }
.combo-inline__list { list-style: none; margin: 2px 0 0; padding: var(--sp-1); position: absolute; z-index: var(--z-dropdown); left: 0; right: 0; background: var(--color-surface); border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); box-shadow: var(--sh-md); max-height: 200px; overflow-y: auto; }
.combo__opt { display: flex; flex-direction: column; padding: var(--sp-2) var(--sp-3); border-radius: var(--r-sm); cursor: pointer; }
.combo__opt:hover, .combo__opt:focus { background: var(--color-surface-2); outline: none; }
.combo__sub { font-size: var(--fs-caption); color: var(--color-text-muted); }
.combo__add { display: block; padding: var(--sp-2) var(--sp-3); margin-top: var(--sp-1); font-size: var(--fs-label); border-top: var(--bw-1) solid var(--color-border); }
.combo-inline { position: relative; }
.combo-inline__input { width: 100%; font: inherit; color: var(--color-text); padding: var(--sp-2) var(--sp-3); border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); background: var(--color-surface); }

/* ---- Lineas (repetidor) ---- */
.lines { display: flex; flex-direction: column; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.line-row { border: var(--bw-1) solid var(--color-border); border-radius: var(--r-md); padding: var(--sp-3) var(--sp-4); background: var(--color-surface-2); }
.line-row__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-2); }
.line-row__num { width: 24px; height: 24px; border-radius: var(--r-pill); background: var(--color-primary-600); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: var(--fs-caption); font-weight: 600; font-family: var(--font-mono); }
.line-row__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--sp-3); }
.form-field--wide { grid-column: 1 / -1; }

/* ---- Rail de validacion ---- */
.deca-rail { position: sticky; top: var(--sp-5); }
.deca-rail__card { background: var(--color-surface); border: var(--bw-1) solid var(--color-border); border-radius: var(--r-lg); box-shadow: var(--sh-sm); padding: var(--sp-5); }
.deca-rail__title { font-size: var(--fs-h3); font-weight: var(--fw-h3); margin: 0 0 var(--sp-4); }
.deca-rail__hint { color: var(--color-text-muted); font-size: var(--fs-label); }
.deca-rail__actions { display: flex; flex-direction: column; gap: var(--sp-2); margin-top: var(--sp-4); }
.deca-rail__note { color: var(--color-text-muted); font-size: var(--fs-caption); margin: var(--sp-3) 0 0; }
.checklist { list-style: none; margin: 0 0 var(--sp-3); padding: 0; display: flex; flex-direction: column; gap: var(--sp-2); }
.checklist__item { display: flex; gap: var(--sp-2); align-items: flex-start; font-size: var(--fs-label); }
.checklist__item.is-error { color: var(--color-danger); }
.checklist__item.is-warn { color: var(--color-warning); }
.checklist__item svg { flex: none; margin-top: 1px; }

/* ---- Detalle ---- */
.deca-detail-head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--sp-4); margin-bottom: var(--sp-5); flex-wrap: wrap; }
.deca-detail-id { font-size: 22px; font-weight: 600; color: var(--color-primary-700); }
.deca-detail-meta { display: flex; align-items: center; gap: var(--sp-3); margin-top: var(--sp-2); color: var(--color-text-muted); font-size: var(--fs-label); flex-wrap: wrap; }
.deca-detail-actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.btn[disabled] { opacity: .5; cursor: not-allowed; }
.btn--danger-ghost { color: var(--color-danger); border-color: var(--color-border-strong); background: var(--color-surface); }
.deca-detail-grid { display: grid; grid-template-columns: minmax(0, 1.6fr) 1fr; gap: var(--sp-5); align-items: start; }
.deca-detail-main { display: flex; flex-direction: column; gap: var(--sp-4); min-width: 0; }
.deca-qr { display: flex; gap: var(--sp-4); align-items: center; }
.deca-qr__code { width: 96px; height: 96px; flex: none; border: var(--bw-1) solid var(--color-border); border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; color: var(--color-text-subtle); }
.deca-qr__body { flex: 1; min-width: 0; }
.deca-qr__url { display: flex; gap: var(--sp-2); margin: var(--sp-1) 0; }
.deca-qr__url input { flex: 1; min-width: 0; font: inherit; padding: var(--sp-2) var(--sp-3); border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); background: var(--color-surface-2); }
.detail-facts { display: flex; gap: var(--sp-6); flex-wrap: wrap; margin-top: var(--sp-4); padding-top: var(--sp-3); border-top: var(--bw-1) solid var(--color-border); }
.detail-facts > div { display: flex; flex-direction: column; gap: 2px; font-size: var(--fs-label); }
.trace { list-style: none; margin: 0 0 var(--sp-3); padding: 0; display: flex; flex-direction: column; gap: var(--sp-3); }
.trace li { display: flex; flex-direction: column; gap: 2px; font-size: var(--fs-label); }
.deca-back { display: inline-block; margin-top: var(--sp-3); color: var(--color-primary-600); text-decoration: none; font-size: var(--fs-label); }

/* ---- Responsive ---- */
@media (max-width: 1024px) {
    .deca-grid, .deca-detail-grid { grid-template-columns: 1fr; }
    .deca-rail { position: static; }
}
@media (max-width: 768px) {
    .party-grid { grid-template-columns: 1fr; }
}

/* ---- Vista publica de inspeccion (Slice 5): movil primero ---- */
.pub-body { background: var(--color-bg); min-height: 100vh; }
.pub-wrap { max-width: 420px; margin: 0 auto; padding: var(--sp-6) var(--sp-4) var(--sp-8); display: flex; flex-direction: column; gap: var(--sp-5); min-height: 100vh; box-sizing: border-box; }
.pub-brand { display: flex; align-items: center; gap: var(--sp-2); color: var(--color-primary-600); }
.pub-brand__name { font-weight: 600; font-size: var(--fs-h3); letter-spacing: .02em; }
.pub-card { background: var(--color-surface); border: var(--bw-1) solid var(--color-border); border-radius: var(--r-xl); padding: var(--sp-6) var(--sp-5); box-shadow: var(--sh-sm); display: flex; flex-direction: column; gap: var(--sp-4); }
.pub-card--neutral { text-align: center; }
.pub-eyebrow { margin: 0; font-size: var(--fs-caption); font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--color-text-muted); }
.pub-state { display: flex; justify-content: flex-start; }
.pub-card--neutral .pub-state { justify-content: center; }
.pub-state__badge { font-size: var(--fs-body); padding: 6px 16px; }
.pub-note { margin: 0; font-size: var(--fs-label); line-height: 1.5; }
.pub-note--warn { color: var(--color-warning); }
.pub-note--danger { color: var(--color-danger); }
.pub-note--muted { color: var(--color-text-muted); }
.pub-facts { margin: 0; display: flex; flex-direction: column; gap: var(--sp-3); }
.pub-facts div { display: flex; flex-direction: column; gap: 2px; }
.pub-facts dt { font-size: var(--fs-caption); color: var(--color-text-subtle); text-transform: uppercase; letter-spacing: .04em; }
.pub-facts dd { margin: 0; font-size: var(--fs-body-lg); color: var(--color-text); }
.pub-download { min-height: 52px; font-size: var(--fs-body-lg); }
.pub-legal { margin: 0; font-size: var(--fs-caption); color: var(--color-text-subtle); line-height: 1.5; }
.pub-foot { margin-top: auto; display: flex; justify-content: center; opacity: .8; }

/* ---- Modal de enviar al conductor (Slice 5) ---- */
.modal { width: min(440px, calc(100vw - var(--sp-6))); border: var(--bw-1) solid var(--color-border); border-radius: var(--r-xl); padding: var(--sp-5); box-shadow: var(--sh-lg); color: var(--color-text); background: var(--color-surface); }
.modal::backdrop { background: rgba(20, 58, 82, .45); }
.modal__x { display: flex; justify-content: flex-end; margin: calc(var(--sp-3) * -1) calc(var(--sp-3) * -1) 0 0; }
.modal__x .btn { padding: var(--sp-1) var(--sp-2); font-size: var(--fs-h2); line-height: 1; }
.modal__form { display: flex; flex-direction: column; gap: var(--sp-2); margin-top: var(--sp-3); }
.field-label { font-size: var(--fs-label); font-weight: 500; color: var(--color-text-muted); }
.input { font: inherit; padding: var(--sp-2) var(--sp-3); border: var(--bw-1) solid var(--color-border-strong); border-radius: var(--r-md); background: var(--color-surface); color: var(--color-text); width: 100%; box-sizing: border-box; }
.input:focus-visible { outline: 3px solid var(--color-focus-ring); outline-offset: 1px; }
.modal__divider { display: flex; align-items: center; text-align: center; gap: var(--sp-2); color: var(--color-text-subtle); font-size: var(--fs-caption); margin: var(--sp-4) 0 var(--sp-2); }
.modal__divider::before, .modal__divider::after { content: ""; flex: 1; height: 1px; background: var(--color-border); }
.btn--danger { background: var(--color-danger); border-color: var(--color-danger); color: #fff; }

/* ---- Modificacion / anulacion (Slice 6) ---- */
.modify-methods { border: var(--bw-1) solid var(--color-border); border-radius: var(--r-md); padding: var(--sp-3); margin-bottom: var(--sp-3); }
.modify-methods legend { padding: 0 var(--sp-1); }
.radio-row { display: flex; gap: var(--sp-2); align-items: flex-start; padding: var(--sp-2) 0; cursor: pointer; }
.radio-row input { margin-top: 3px; }
.version-timeline { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--sp-3); }
.version-item { border-left: 2px solid var(--color-border-strong); padding-left: var(--sp-3); }
.version-item.is-current { border-left-color: var(--color-accent-600); }
.version-item__head { display: flex; align-items: center; gap: var(--sp-2); }
.version-item__meta { font-size: var(--fs-caption); color: var(--color-text-muted); margin-top: 2px; }
.version-item__reason { font-size: var(--fs-caption); color: var(--color-text); margin-top: var(--sp-1); }
.version-item__date { font-size: var(--fs-caption); color: var(--color-text-subtle); margin-top: 2px; }

/* ============================================================================
   Slice 7 — Suscripcion y pago Redsys (planes, pagos, retorno)
   ============================================================================ */
.page-note { margin-top: var(--sp-4); font-size: var(--fs-caption); color: var(--color-text-muted); }
.btn--sm { padding: 4px 10px; font-size: var(--fs-caption); }
.cell-actions { text-align: right; white-space: nowrap; }
.cell-actions .inline-form { display: inline-block; margin-left: var(--sp-2); }

/* Rejilla de planes */
.plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--sp-4); margin-top: var(--sp-4); }
.plan-card { display: flex; flex-direction: column; gap: var(--sp-3); }
.plan-card--current { border-color: var(--color-accent-600); box-shadow: 0 0 0 1px var(--color-accent-600); }
.plan-card__price { margin: 0; font-size: var(--fs-body); color: var(--color-text-muted); }
.plan-card__price strong { font-size: var(--fs-h2); color: var(--color-text); }
.plan-card__period { display: inline-block; margin-left: 4px; }
.plan-card__feats { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--sp-2); font-size: var(--fs-label); color: var(--color-text); }
.plan-card__feats li { padding-left: var(--sp-4); position: relative; }
.plan-card__feats li::before { content: ""; position: absolute; left: 0; top: .5em; width: 8px; height: 8px; border-radius: 2px; background: var(--color-accent-600); }
.plan-card .btn, .plan-card .badge { margin-top: auto; }

/* Pago: retorno y redireccion (layout publico) */
.pub-card__title { margin: 0; font-size: var(--fs-h2); font-weight: var(--fw-h1, 600); color: var(--color-text); }
.pub-card__lead { margin: 0; font-size: var(--fs-body); color: var(--color-text-muted); line-height: 1.5; }
.pub-actions { display: flex; flex-direction: column; gap: var(--sp-3); margin-top: var(--sp-2); }
.pub-badge { align-self: center; font-size: var(--fs-caption); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; padding: 4px 14px; border-radius: 999px; }
.pub-badge--success { background: var(--color-primary-100); color: var(--color-primary-700); }
.pub-badge--warning { background: var(--color-info-bg); color: var(--color-info); }
.pub-badge--danger { background: var(--color-danger-bg); color: var(--color-danger); }

/* ---- Banner de modo soporte (impersonacion Pretium, Slice 9b) ------------ */
.support-banner {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 28px; background: #5b4f9e; color: #fff; font-size: 13px;
}
.support-banner__text { flex: 1; }
.support-banner__exit {
    height: 30px; padding: 0 13px; border-radius: 7px;
    border: 1px solid rgba(255,255,255,.5); background: transparent; color: #fff;
    font: inherit; font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap;
}
.support-banner__exit:hover { background: rgba(255,255,255,.12); }

/* ---- Movimiento reducido (a11y) ----------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}
