/* ============================================================
   base.css — Variables, reset, tipografía y utilidades
   Paleta: blanco, rojo Valle (#e63312), negro, grises
   Estilo: Material Design minimalista
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap');

:root {
  /* ---- Paleta principal ---------------------------------- */
  --rojo:             #e63312;
  --rojo-oscuro:      #c42a0e;
  --rojo-claro:       #fdecea;
  --rojo-hover:       rgba(230, 51, 18, .08);

  --negro:            #212121;
  --gris-900:         #212121;
  --gris-800:         #424242;
  --gris-700:         #616161;
  --gris-600:         #757575;
  --gris-400:         #bdbdbd;
  --gris-300:         #e0e0e0;
  --gris-200:         #eeeeee;
  --gris-100:         #f5f5f5;
  --gris-50:          #fafafa;
  --blanco:           #ffffff;

  /* ---- Colores semánticos (aliases) --------------------- */
  --color-primary:        var(--rojo);
  --color-primary-dark:   var(--rojo-oscuro);
  --color-primary-light:  var(--rojo-claro);
  --color-primary-hover:  var(--rojo-hover);

  --color-text:           var(--gris-900);
  --color-text-secondary: var(--gris-600);
  --color-border:         var(--gris-300);
  --color-divider:        var(--gris-200);
  --color-bg:             var(--gris-100);
  --color-surface:        var(--blanco);
  --color-surface-alt:    var(--gris-50);

  /* ---- Colores de estado -------------------------------- */
  --color-ok:             #2e7d32;
  --color-ok-bg:          #e8f5e9;
  --color-ok-border:      #a5d6a7;
  --color-error:          var(--rojo);
  --color-error-bg:       var(--rojo-claro);
  --color-error-border:   #ffab9f;
  --color-warning:        #e65100;
  --color-warning-bg:     #fff3e0;
  --color-warning-border: #ffcc80;
  --color-info:           #1565c0;
  --color-info-bg:        #e3f2fd;
  --color-info-border:    #90caf9;

  /* ---- Colores etiquetas / badges ----------------------- */
  --color-tag-blue:       #1565c0;
  --color-tag-blue-bg:    #e3f2fd;
  --color-tag-green:      #2e7d32;
  --color-tag-green-bg:   #e8f5e9;
  --color-tag-orange:     #e65100;
  --color-tag-orange-bg:  #fff3e0;
  --color-tag-purple:     #6a1b9a;
  --color-tag-purple-bg:  #f3e5f5;
  --color-tag-grey:       var(--gris-700);
  --color-tag-grey-bg:    var(--gris-200);

  /* ---- Sidebar ----------------------------------------- */
  --sidebar-bg:           var(--blanco);
  --sidebar-text:         var(--gris-700);
  --sidebar-text-active:  var(--rojo);
  --sidebar-active-bg:    var(--rojo-hover);
  --sidebar-active-bar:   var(--rojo);
  --sidebar-width:        240px;
  --sidebar-border:       var(--gris-200);

  /* ---- Tipografía -------------------------------------- */
  --font-base:    'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-size-xs: .75rem;    /* 12px */
  --font-size-sm: .875rem;   /* 14px */
  --font-size-md: 1rem;      /* 16px */
  --font-size-lg: 1.125rem;  /* 18px */
  --font-size-xl: 1.25rem;   /* 20px */
  --font-size-2xl:1.5rem;    /* 24px */
  --font-size-3xl:1.875rem;  /* 30px */

  /* ---- Espaciado (base 4px) ---------------------------- */
  --sp-1:  .25rem;   /* 4px  */
  --sp-2:  .5rem;    /* 8px  */
  --sp-3:  .75rem;   /* 12px */
  --sp-4:  1rem;     /* 16px */
  --sp-5:  1.25rem;  /* 20px */
  --sp-6:  1.5rem;   /* 24px */
  --sp-8:  2rem;     /* 32px */
  --sp-10: 2.5rem;   /* 40px */
  --sp-12: 3rem;     /* 48px */

  /* ---- Bordes ------------------------------------------ */
  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  12px;
  --radius-xl:  16px;
  --radius-full:9999px;

  /* ---- Sombras Material Design ------------------------- */
  --shadow-1:  0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.08);
  --shadow-2:  0 3px 6px rgba(0,0,0,.10), 0 2px 4px rgba(0,0,0,.07);
  --shadow-3:  0 10px 20px rgba(0,0,0,.08), 0 3px 6px rgba(0,0,0,.06);
  --shadow-4:  0 15px 25px rgba(0,0,0,.08), 0 5px 10px rgba(0,0,0,.05);

  /* ---- Transiciones ------------------------------------ */
  --transition-fast:   120ms cubic-bezier(.4,0,.2,1);
  --transition:        200ms cubic-bezier(.4,0,.2,1);
  --transition-slow:   300ms cubic-bezier(.4,0,.2,1);

  /* ---- Layout ------------------------------------------ */
  --topbar-height: 64px;
}

/* ==========================================================
   RESET
   ========================================================== */

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

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-base);
  font-size: var(--font-size-md);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}
a:hover { color: var(--color-primary-dark); }

img, svg { display: block; max-width: 100%; }
ul, ol  { list-style: none; }
button, input, select, textarea { font: inherit; }
hr { border: none; border-top: 1px solid var(--color-divider); }

/* ==========================================================
   TIPOGRAFÍA
   ========================================================== */

h1, h2, h3, h4, h5 {
  font-weight: 500;
  line-height: 1.3;
  color: var(--gris-900);
}
h1 { font-size: var(--font-size-3xl); }
h2 { font-size: var(--font-size-2xl); }
h3 { font-size: var(--font-size-xl); }
h4 { font-size: var(--font-size-lg); }

.page-title {
  font-size: var(--font-size-2xl);
  font-weight: 500;
  color: var(--gris-900);
  margin-bottom: var(--sp-6);
}

.section-title {
  font-size: var(--font-size-lg);
  font-weight: 500;
  color: var(--gris-800);
  margin-bottom: var(--sp-4);
}

.text-muted      { color: var(--color-text-secondary) !important; }
.text-primary    { color: var(--color-primary) !important; }
.text-danger     { color: var(--rojo) !important; }

.tr--clickable   { cursor: pointer; }
.tr--clickable:hover { background: var(--gris-50); }
.text-sm         { font-size: var(--font-size-sm); }
.text-xs         { font-size: var(--font-size-xs); }
.text-center     { text-align: center !important; }
.text-left       { text-align: left !important; }
.text-right      { text-align: right !important; }
.font-medium     { font-weight: 500; }
.font-bold       { font-weight: 700; }

/* ==========================================================
   ALERTAS FLASH
   ========================================================== */

.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-md);
  border-left: 4px solid transparent;
  margin-bottom: var(--sp-4);
  font-size: var(--font-size-sm);
  font-weight: 400;
}

.alert--ok {
  background: var(--color-ok-bg);
  border-color: var(--color-ok);
  color: var(--color-ok);
}
.alert--error {
  background: var(--color-error-bg);
  border-color: var(--color-error);
  color: var(--color-error);
}
.alert--info {
  background: var(--color-info-bg);
  border-color: var(--color-info);
  color: var(--color-info);
}
.alert--warning {
  background: var(--color-warning-bg);
  border-color: var(--color-warning);
  color: var(--color-warning);
}

/* ==========================================================
   BOTONES — Material Design
   ========================================================== */

.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: 0 var(--sp-5);
  height: 36px;
  border: none;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  transition:
    background var(--transition-fast),
    box-shadow var(--transition-fast),
    color var(--transition-fast);
  overflow: hidden;
  user-select: none;
}
.btn:focus-visible {
  outline: 3px solid var(--rojo-claro);
  outline-offset: 2px;
}

/* Filled / Primary */
.btn--primary {
  background: var(--color-primary);
  color: #fff;
  box-shadow: var(--shadow-1);
}
.btn--primary:hover {
  background: var(--color-primary-dark);
  box-shadow: var(--shadow-2);
  color: #fff;
}

/* Outlined */
.btn--secondary {
  background: transparent;
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
}
.btn--secondary:hover {
  background: var(--color-primary-hover);
  color: var(--color-primary-dark);
}

/* Ghost / text */
.btn--ghost {
  background: transparent;
  color: var(--gris-700);
  border: 1px solid var(--color-border);
}
.btn--ghost:hover {
  background: var(--gris-100);
  color: var(--gris-900);
}

/* Danger */
.btn--danger {
  background: var(--color-error);
  color: #fff;
  box-shadow: var(--shadow-1);
}
.btn--danger:hover {
  background: var(--rojo-oscuro);
  box-shadow: var(--shadow-2);
  color: #fff;
}

/* Variantes de tamaño */
.btn--sm {
  height: 28px;
  padding: 0 var(--sp-3);
  font-size: var(--font-size-xs);
}
.btn--lg {
  height: 44px;
  padding: 0 var(--sp-8);
  font-size: var(--font-size-md);
}
.btn--block {
  width: 100%;
}
.btn--icon {
  width: 36px;
  padding: 0;
}

/* ==========================================================
   FORMULARIOS — Material Design
   ========================================================== */

.form-group {
  margin-bottom: var(--sp-5);
}

.form-label {
  display: block;
  font-size: var(--font-size-xs);
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gris-600);
  margin-bottom: var(--sp-2);
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: var(--sp-3) var(--sp-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
  font-size: var(--font-size-sm);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  -webkit-appearance: none;
  appearance: none;
}
.form-input:hover,
.form-select:hover,
.form-textarea:hover {
  border-color: var(--gris-600);
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(230,51,18,.12);
}
.form-input::placeholder { color: var(--gris-400); }
.form-textarea { resize: vertical; min-height: 88px; }
.form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23757575' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--sp-3) center;
  padding-right: var(--sp-8);
  cursor: pointer;
}

.form-hint {
  font-size: var(--font-size-xs);
  color: var(--gris-600);
  margin-top: var(--sp-1);
}
.form-error {
  font-size: var(--font-size-xs);
  color: var(--color-error);
  margin-top: var(--sp-1);
}

.form-input--error { border-color: var(--color-error); }

/* Grupo inline (label + campo en fila) */
.form-row {
  display: grid;
  gap: var(--sp-4);
}
@media (min-width: 600px) {
  .form-row--2 { grid-template-columns: repeat(2, 1fr); }
  .form-row--3 { grid-template-columns: repeat(3, 1fr); }
}

/* ==========================================================
   TARJETAS — Material Design
   ========================================================== */

.card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-1);
  overflow: hidden;
}

.card__header {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--color-divider);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
}

.card__title {
  font-size: var(--font-size-lg);
  font-weight: 500;
}

.card__body {
  padding: var(--sp-5);
}

.card__footer {
  padding: var(--sp-3) var(--sp-5);
  border-top: 1px solid var(--color-divider);
  background: var(--gris-50);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-2);
}

/* ==========================================================
   TABLA
   ========================================================== */

.table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-1);
}

.table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
  background: var(--color-surface);
}

.table thead th {
  padding: var(--sp-3) var(--sp-4);
  text-align: left;
  font-size: var(--font-size-xs);
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gris-600);
  background: var(--gris-50);
  border-bottom: 2px solid var(--color-divider);
  white-space: nowrap;
}

.table tbody td {
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--color-divider);
  color: var(--color-text);
  vertical-align: middle;
}

.table tbody tr:last-child td {
  border-bottom: none;
}

.table tbody tr {
  transition: background var(--transition-fast);
}
.table tbody tr:hover td {
  background: var(--gris-50);
}

.table--compact thead th,
.table--compact tbody td {
  padding: var(--sp-2) var(--sp-3);
}

/* ==========================================================
   BADGES / CHIPS
   ========================================================== */

.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--sp-2);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 500;
  white-space: nowrap;
  line-height: 1.4;
}

.badge--red      { background: var(--rojo-claro);            color: var(--rojo-oscuro); }
.badge--green    { background: var(--color-ok-bg);           color: var(--color-ok); }
.badge--blue     { background: var(--color-tag-blue-bg);     color: var(--color-tag-blue); }
.badge--orange   { background: var(--color-tag-orange-bg);   color: var(--color-tag-orange); }
.badge--purple   { background: var(--color-tag-purple-bg);   color: var(--color-tag-purple); }
.badge--grey     { background: var(--gris-200);              color: var(--gris-700); }

/* ==========================================================
   ESTADOS DE DOCUMENTOS (pedido, oferta, pipeline)
   ========================================================== */

.estado {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--sp-2);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 500;
  white-space: nowrap;
}

.estado--borrador   { background: var(--gris-200);           color: var(--gris-700); }
.estado--enviado    { background: var(--color-info-bg);      color: var(--color-info); }
.estado--confirmado { background: var(--color-ok-bg);        color: var(--color-ok); }
.estado--aceptado   { background: var(--color-ok-bg);        color: var(--color-ok); }
.estado--rechazado  { background: var(--rojo-claro);         color: var(--rojo-oscuro); }
.estado--cancelado  { background: var(--rojo-claro);         color: var(--rojo-oscuro); }
.estado--caducado   { background: var(--color-warning-bg);   color: var(--color-warning); }
.estado--pendiente  { background: var(--color-warning-bg);   color: var(--color-warning); }
.estado--cobrado    { background: var(--color-ok-bg);        color: var(--color-ok); }
.estado--vencido    { background: var(--rojo-claro);         color: var(--rojo-oscuro); }

/* ==========================================================
   SPINNER
   ========================================================== */

.spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--gris-300);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: spin 600ms linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ==========================================================
   EMPTY STATE
   ========================================================== */

.empty-state {
  text-align: center;
  padding: var(--sp-12) var(--sp-4);
  color: var(--color-text-secondary);
}
.empty-state__icon  { font-size: 3rem; margin-bottom: var(--sp-3); opacity: .4; }
.empty-state__title { font-size: var(--font-size-lg); font-weight: 500; margin-bottom: var(--sp-2); color: var(--gris-700); }
.empty-state__text  { font-size: var(--font-size-sm); }
