/* ═══════════════════════════════════════════════════════════════════
   RUV · Orden de Verificación
   Look & feel consistente con OfertaCANADEVI:
   Apple HIG + Bootstrap 5.3, amarillo CANADEVI #F5B335 como acento,
   navbar dark glass, esquinas redondeadas grandes, sombras sutiles.
═══════════════════════════════════════════════════════════════════ */

:root {
  /* Marca CANADEVI */
  --can-yellow:        #F5B335;
  --can-yellow-hover:  #E0A020;
  --can-yellow-tint:   #FFF5DC;
  --can-yellow-border: rgba(245, 179, 53, 0.45);

  /* Sistema neutro Apple */
  --apple-bg:          #F5F5F7;
  --apple-surface:     #FFFFFF;
  --apple-surface-2:   #FAFAFC;
  --apple-text:        #1D1D1F;
  --apple-text-2:      #424245;
  --apple-text-3:      #6E6E73;
  --apple-text-4:      #86868B;
  --apple-separator:   #D2D2D7;
  --apple-separator-2: #E8E8ED;
  --apple-fill:        #F2F2F7;

  /* Estados */
  --apple-blue:        #007AFF;
  --apple-green:       #34C759;
  --apple-red:         #FF3B30;
  --apple-orange:      #FF9500;
  --ruv-green:         #00853E;

  --shadow-xs: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04), 0 2px 6px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.06), 0 1px 3px rgba(0,0,0,0.04);
  --shadow-lg: 0 12px 32px rgba(0,0,0,0.10), 0 4px 12px rgba(0,0,0,0.05);

  --radius-sm: 8px; --radius-md: 12px; --radius-lg: 16px; --radius-pill: 980px;

  --bs-body-bg: var(--apple-bg);
  --bs-body-color: var(--apple-text);
  --bs-border-color: var(--apple-separator);
  --bs-border-radius: var(--radius-md);
  --bs-border-radius-lg: var(--radius-lg);
  --bs-border-radius-sm: var(--radius-sm);
}

html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
  background-color: var(--apple-bg);
  color: var(--apple-text);
  min-height: 100vh;
  display: flex; flex-direction: column;
  font-family: "SF Pro Text","SF Pro Display",-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size: 15px; line-height: 1.5; letter-spacing: -0.01em;
  font-feature-settings: "ss01","cv11";
}
h1,h2,h3,h4,h5,h6,.navbar-brand,.card-title{
  font-family:"SF Pro Display",-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",sans-serif;
  font-weight:600;letter-spacing:-0.022em;color:var(--apple-text);
}
:focus-visible{outline:none;box-shadow:0 0 0 4px rgba(0,122,255,.22);border-radius:var(--radius-sm)}
.monospace{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.muted{color:var(--apple-text-3)}

/* ── NAVBAR ── */
.navbar { padding-top:.65rem; padding-bottom:.65rem; }
.bg-canadevi {
  background-color: rgba(29,29,31,0.85) !important;
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 1px 0 rgba(0,0,0,0.04);
}
.bg-canadevi-yellow {
  background-color: var(--apple-surface) !important;
  border-bottom: 1px solid var(--apple-separator) !important;
}
.bg-canadevi-yellow small, .bg-canadevi-yellow .text-dark { color: var(--apple-text-3) !important; font-weight: 500; }
.bg-canadevi-yellow i { color: var(--can-yellow) !important; }
.user-chip{
  display:inline-flex;align-items:center;gap:6px;font-size:.78rem;color:#fff;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius-pill);padding:4px 12px;
}

/* ── BOTONES (pill Apple) ── */
.btn {
  border-radius: var(--radius-pill);
  font-weight: 590; letter-spacing: -0.01em;
  padding: .55rem 1.25rem;
  transition: transform .12s, box-shadow .2s, background-color .2s, border-color .2s, color .2s;
  border-width: 1px;
}
.btn:active { transform: scale(0.97); }
.btn-sm { padding: .35rem .95rem; font-size: .82rem; }
.btn-canadevi, .btn-ruv {
  background: linear-gradient(180deg, #F8C055 0%, var(--can-yellow) 100%);
  color: #1D1D1F !important;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 1px 2px rgba(245,179,53,0.25), inset 0 1px 0 rgba(255,255,255,0.4);
  font-weight: 600;
}
.btn-canadevi:hover, .btn-canadevi:focus {
  background: linear-gradient(180deg, #F5B335 0%, #E0A020 100%);
  color: #1D1D1F;
  box-shadow: 0 4px 12px rgba(245,179,53,0.35), inset 0 1px 0 rgba(255,255,255,0.4);
}
.btn-canadevi:disabled { opacity: .55; }
.btn-outline-light {
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.18);
  color: #F5F5F7;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.btn-outline-light:hover { background: rgba(255,255,255,0.22); color:#fff; border-color: rgba(255,255,255,0.28); }

/* Compatibility — my old custom button classes now map to canadevi style */
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  background: linear-gradient(180deg, #F8C055 0%, var(--can-yellow) 100%);
  color: #1D1D1F;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: var(--radius-pill);
  box-shadow: 0 1px 2px rgba(245,179,53,0.25), inset 0 1px 0 rgba(255,255,255,0.4);
  font-weight: 600;
  padding: .55rem 1.25rem;font-size:.9rem;text-decoration:none;
}
.btn-primary:hover{
  background:linear-gradient(180deg,#F5B335 0%,#E0A020 100%);
  color:#1D1D1F;text-decoration:none;
  box-shadow: 0 4px 12px rgba(245,179,53,0.35), inset 0 1px 0 rgba(255,255,255,0.4);
}
.btn-primary:disabled{opacity:.55;cursor:not-allowed}
.btn-sec{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  background:var(--apple-surface);color:var(--apple-text);
  border:1px solid var(--apple-separator);border-radius:var(--radius-pill);
  padding:.45rem 1rem;font-weight:500;font-size:.85rem;cursor:pointer;text-decoration:none;
  box-shadow: var(--shadow-xs);
}
.btn-sec:hover{background:var(--apple-fill);color:var(--apple-text);text-decoration:none;box-shadow:var(--shadow-sm)}
.btn-green{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  background:linear-gradient(180deg,#3FD96F 0%,var(--apple-green) 100%);color:#fff;font-weight:600;
  border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-pill);padding:.55rem 1.25rem;font-size:.9rem;
  box-shadow: 0 1px 2px rgba(52,199,89,0.25), inset 0 1px 0 rgba(255,255,255,0.4);
}
.btn-green:hover{background:linear-gradient(180deg,#34C759 0%,#28A745 100%);color:#fff}

button{appearance:none;-webkit-appearance:none;font-family:inherit}

/* ── STEPPER / Wizard horizontal ──
   Círculos numerados con conector horizontal y label debajo.
   El conector está dentro de cada .step (centrado en el círculo) y se
   extiende horizontalmente; el último paso lo oculta para que la línea
   termine en el último círculo. */
.stepper{
  background:var(--apple-surface);border-bottom:1px solid var(--apple-separator);
  padding: 26px 24px 22px;
  display:flex;align-items:flex-start;justify-content:space-between;gap:0;
  box-shadow: var(--shadow-xs);overflow-x:auto;
}
.step{
  position:relative;flex:1 1 0;min-width:90px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  text-decoration:none;color:var(--apple-text-3);
  background:transparent;border:none;font-family:inherit;cursor:pointer;
  padding:0 4px;
}
.step:hover{text-decoration:none}
.step-line{
  position:absolute;top:18px;left:50%;right:-50%;height:1px;
  background:var(--apple-separator);z-index:0;
}
.step-line.is-last{display:none}

.step-circle{
  position:relative;z-index:1;
  width:38px;height:38px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--apple-surface);
  border:1.5px solid var(--apple-separator);
  color:var(--apple-text-3);font-weight:600;font-size:.95rem;
  font-variant-numeric:tabular-nums;
  transition:background-color .2s, border-color .2s, color .2s, box-shadow .2s, transform .12s;
}
.step:hover .step-circle{border-color:#BDBDC4;color:var(--apple-text-2)}

.step-label{
  font-size:.78rem;font-weight:500;color:var(--apple-text-3);
  text-align:center;line-height:1.25;max-width:120px;
  transition:color .2s, font-weight .2s;
}

/* Paso completado → verde Apple, check */
.step.done .step-circle{
  background:var(--apple-green);border-color:var(--apple-green);color:#fff;
}
.step.done .step-line{background:var(--apple-green)}
.step.done .step-label{color:var(--apple-text-2)}

/* Paso activo → amarillo CANADEVI con halo */
.step.active .step-circle{
  background:linear-gradient(180deg,#F8C055 0%,var(--can-yellow) 100%);
  border-color:var(--can-yellow-hover);color:#1D1D1F;
  box-shadow:0 0 0 5px rgba(245,179,53,.18), 0 2px 6px rgba(245,179,53,.35);
  transform:translateY(-1px);
}
.step.active .step-label{color:var(--apple-text);font-weight:700}

@media (max-width:880px){
  .stepper{padding:18px 12px 16px}
  .step{min-width:72px}
  .step-circle{width:32px;height:32px;font-size:.82rem}
  .step-line{top:15px}
  .step-label{font-size:.7rem;max-width:84px}
}

/* ── FORM area ── */
.form-scroll{flex:1;background:var(--apple-bg)}
.form-wrap{max-width:1180px;margin:0 auto;padding:24px 24px 32px}
.form-card{
  background:var(--apple-surface);border:1px solid var(--apple-separator-2);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px 26px;margin-bottom:18px;
}
.form-card-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.form-card-head i{font-size:1.6rem;color:var(--can-yellow);margin-top:2px}
.form-card-head h3{margin:0;font-size:1.15rem;font-weight:600;color:var(--apple-text)}
.form-card-head p{margin:2px 0 0;color:var(--apple-text-3);font-size:.85rem}

.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px 16px}
.form-grid .field.col-2{grid-column:span 2}
.form-grid .field.col-3{grid-column:span 3}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-weight:500;font-size:.85rem;color:var(--apple-text-2);margin-bottom:.1rem}
.ctl{
  width:100%;background:var(--apple-surface);border:1px solid var(--apple-separator);
  border-radius:var(--radius-md);padding:.55rem .85rem;font-size:.95rem;color:var(--apple-text);
  font-family:inherit;transition:border-color .15s, box-shadow .15s;
}
.ctl:hover{border-color:#BDBDC4}
.ctl:focus{outline:none;border-color:var(--can-yellow);box-shadow:0 0 0 4px rgba(245,179,53,.18)}
.ctl[readonly]{background:var(--apple-fill);color:var(--apple-text-2)}

.form-actions{
  display:flex;justify-content:space-between;gap:10px;margin-top:24px;padding-top:18px;
  border-top:1px solid var(--apple-separator-2);
}

/* ── TABLAS ── */
.tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.tbl th{
  text-align:left;padding:10px 12px;background:var(--apple-surface-2);color:var(--apple-text-2);
  font-weight:600;font-size:.76rem;text-transform:uppercase;letter-spacing:.04em;
  border-bottom:1px solid var(--apple-separator);
}
.tbl td{padding:10px 12px;border-bottom:1px solid var(--apple-separator-2);color:var(--apple-text)}
.tbl tr:hover td{background:var(--apple-surface-2)}
.tbl-scroll{max-height:480px;overflow-y:auto;border:1px solid var(--apple-separator-2);border-radius:var(--radius-md);background:var(--apple-surface)}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:5px;border-radius:var(--radius-pill);padding:3px 10px;font-size:.72rem;font-weight:600}
.badge-ok{background:rgba(52,199,89,.12);color:#1f8a3a;border:1px solid rgba(52,199,89,.3)}
.badge-warn{background:var(--can-yellow-tint);color:#8a6200;border:1px solid var(--can-yellow-border)}
.badge-info{background:rgba(0,122,255,.12);color:#0050a8;border:1px solid rgba(0,122,255,.3)}
.badge-err{background:rgba(255,59,48,.1);color:#a3271f;border:1px solid rgba(255,59,48,.3)}
.badge-neutral{background:var(--apple-fill);color:var(--apple-text-2);border:1px solid var(--apple-separator)}

/* ── DOC cards ── */
.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.doc-card{
  border:1px solid var(--apple-separator-2);border-radius:var(--radius-md);padding:14px 16px;
  background:var(--apple-surface);display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-xs);
}
.doc-card.cargado{border-color:rgba(52,199,89,.45);background:rgba(52,199,89,.04)}
.doc-card .doc-name{font-weight:600;font-size:.9rem;color:var(--apple-text);display:flex;align-items:center;gap:8px}
.doc-card .doc-name i{color:var(--can-yellow)}
.doc-card.cargado .doc-name{color:#1f8a3a}
.doc-card.cargado .doc-name i{color:var(--apple-green)}
.doc-meta{font-size:.78rem;color:var(--apple-text-3)}
.doc-actions{display:flex;gap:6px;align-items:center;margin-top:auto}
.doc-actions .ctl{flex:1;font-size:.82rem;padding:5px 10px}

/* ── Ponderación ── */
.pond-row{
  display:grid;grid-template-columns:1fr 120px;gap:12px;align-items:center;padding:9px 0;
  border-bottom:1px solid var(--apple-separator-2);
}
.pond-row label{font-size:.88rem;color:var(--apple-text)}
.pond-row .ctl{text-align:right;font-variant-numeric:tabular-nums}
.pond-total{
  display:flex;justify-content:space-between;align-items:center;margin-top:14px;
  padding:12px 16px;background:var(--apple-fill);border-radius:var(--radius-md);
  border:1px solid var(--apple-separator-2);
}
.pond-total .total-val{font-size:1.25rem;font-weight:700}
.pond-total.ok .total-val{color:var(--apple-green)}
.pond-total.bad .total-val{color:var(--apple-red)}

/* ── LOGIN ── */
.login-bg{
  flex:1;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 30% 20%, rgba(245,179,53,.20) 0%, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(0,122,255,.15) 0%, transparent 50%),
    #1D1D1F;
  padding:32px;min-height:100vh;
}
.login-card{
  background:var(--apple-surface);border-radius:var(--radius-lg);
  box-shadow:0 24px 60px rgba(0,0,0,.3), 0 8px 20px rgba(0,0,0,.15);
  padding:38px 42px;max-width:440px;width:100%;
}
.login-card h1{margin:0 0 6px;font-size:1.4rem;font-weight:700}
.login-card .sub{color:var(--apple-text-3);font-size:.88rem;margin-bottom:24px}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.login-logo i{font-size:2rem;color:var(--can-yellow)}

/* ── Summary stats ── */
.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:14px}
.summary .stat{
  background:var(--apple-surface);padding:14px 16px;border-radius:var(--radius-md);
  border:1px solid var(--apple-separator-2);box-shadow:var(--shadow-xs);
}
.summary .stat .lbl{font-size:.72rem;color:var(--apple-text-3);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.summary .stat .val{font-size:1.4rem;font-weight:700;margin-top:4px;letter-spacing:-.02em}
.summary .stat .val.guinda{color:var(--can-yellow-hover)}
.summary .stat .val.green{color:var(--apple-green)}

/* ── Banners ── */
.banner{
  padding:14px 18px;border-radius:var(--radius-md);margin-bottom:16px;
  display:flex;align-items:flex-start;gap:12px;font-size:.9rem;
}
.banner i{font-size:1.15rem;margin-top:1px}
.banner-info{background:rgba(0,122,255,.06);color:#0050a8;border:1px solid rgba(0,122,255,.2)}
.banner-warn{background:var(--can-yellow-tint);color:#7a5500;border:1px solid var(--can-yellow-border)}
.banner-ok{background:rgba(52,199,89,.06);color:#1f6f33;border:1px solid rgba(52,199,89,.25)}
.banner-err{background:rgba(255,59,48,.06);color:#a3271f;border:1px solid rgba(255,59,48,.25)}

.checkbox-row{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer;user-select:none}

/* ── FOOTER ── */
.footer-canadevi{
  background:var(--apple-surface);border-top:1px solid var(--apple-separator);
  color:var(--apple-text-3);
}
.footer-canadevi small{color:var(--apple-text-3) !important}

@media (max-width:880px){
  .form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .form-grid .field.col-2,.form-grid .field.col-3{grid-column:span 2}
}
@media (max-width:560px){
  .form-grid{grid-template-columns:1fr}
  .form-grid .field.col-2,.form-grid .field.col-3{grid-column:span 1}
}
