
:root{
  --bg:#f3f4f6;
  --panel:#ffffff;
  --panel-2:#f9fafb;
  --text:#111827;
  --muted:#6b7280;
  --border:#e5e7eb;
  --primary:#111827;
  --primary-2:#374151;
  --accent:#2563eb;
  --danger:#dc2626;
  --warning:#f59e0b;
  --success:#059669;
  --shadow:0 10px 30px rgba(17,24,39,.08);
  --radius:18px;
  --nav-h:72px;
  --side-w:260px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  background:linear-gradient(180deg,#eef2ff 0%,#f8fafc 18%,#f3f4f6 100%);
  color:var(--text);
}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
a{text-decoration:none;color:inherit}

#app{min-height:100vh}
.shell{
  display:flex;
  min-height:100vh;
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom));
}
.sidebar{
  display:none;
}
.main{
  flex:1;
  width:100%;
  padding:16px 16px 100px;
}
.topbar{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:flex-start;
  justify-content:space-between;
  margin-bottom:16px;
}
.brand{
  display:flex;
  gap:12px;
  align-items:center;
}
.brand-mark{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,#111827,#4b5563);
  color:white;font-weight:800;
  box-shadow:var(--shadow);
}
.brand h1{
  margin:0;
  font-size:1.35rem;
  line-height:1.1;
}
.brand .sub{
  color:var(--muted);
  font-size:.92rem;
  margin-top:2px;
}
.status-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.8);
  border:1px solid var(--border);
  box-shadow:0 6px 18px rgba(17,24,39,.04);
  font-size:.9rem;
  color:var(--muted);
}
.status-dot{
  width:9px;height:9px;border-radius:999px;background:var(--success);
}
.status-offline .status-dot{background:var(--warning)}
.status-offline{color:#92400e}

.grid{
  display:grid;
  gap:14px;
}
.grid.cols-2{grid-template-columns:1fr}
.grid.cols-3{grid-template-columns:1fr}
.card{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(229,231,235,.9);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
  backdrop-filter:blur(8px);
}
.card h2,.card h3,.card p{margin-top:0}
.card-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:12px;
}
.muted{color:var(--muted)}
.kpi{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.kpi-item{
  padding:14px;
  border-radius:16px;
  background:linear-gradient(180deg,#fff,#f9fafb);
  border:1px solid var(--border);
}
.kpi-item .label{color:var(--muted);font-size:.86rem}
.kpi-item .value{font-size:1.2rem;font-weight:700;margin-top:4px}
.quick-actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.quick-btn,.nav-btn,.icon-btn,.ghost-btn,.primary-btn,.danger-btn,.secondary-btn{
  border:0;
  border-radius:16px;
  padding:12px 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  transition:.15s transform,.15s opacity,.15s background;
}
.quick-btn,.nav-btn{
  background:#fff;
  border:1px solid var(--border);
  color:var(--text);
}
.quick-btn:hover,.nav-btn:hover,.icon-btn:hover,.ghost-btn:hover,.primary-btn:hover,.danger-btn:hover,.secondary-btn:hover{
  transform:translateY(-1px);
}
.primary-btn{background:var(--primary);color:#fff}
.secondary-btn{background:#e5e7eb;color:#111827}
.ghost-btn{background:transparent;border:1px solid var(--border);color:var(--text)}
.danger-btn{background:var(--danger);color:#fff}
.icon-btn{
  width:40px;height:40px;padding:0;border:1px solid var(--border);background:#fff;
}
.toolbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px;
}
.toolbar .left,.toolbar .right{
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;
}
.input, select, textarea{
  width:100%;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  border-radius:14px;
  padding:12px 14px;
  outline:none;
}
input:focus,select:focus,textarea:focus{
  border-color:#93c5fd;
  box-shadow:0 0 0 4px rgba(59,130,246,.12);
}
textarea{min-height:120px;resize:vertical}
.list{
  display:grid;
  gap:10px;
}
.item{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:14px;
  border-radius:16px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,#fff,#fafafa);
}
.item:hover{border-color:#d1d5db}
.item-main{min-width:0}
.item-title{
  font-weight:700;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.item-meta{
  margin-top:6px;
  color:var(--muted);
  font-size:.92rem;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 10px;
  border-radius:999px;
  background:#eef2ff;
  color:#3730a3;
  font-size:.82rem;
}
.badge.warn{background:#fff7ed;color:#9a3412}
.badge.soft{background:#f3f4f6;color:#374151}
.actions{
  display:flex;
  gap:8px;
  flex-shrink:0;
}
.table-wrap{
  overflow:auto;
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
}
table{
  width:100%;
  border-collapse:collapse;
  min-width:720px;
}
th,td{
  padding:12px 14px;
  text-align:left;
  border-bottom:1px solid var(--border);
  vertical-align:top;
}
th{
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--muted);
  background:#f9fafb;
}
tr:last-child td{border-bottom:0}
.small{font-size:.88rem}
.section-title{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:12px;
}
.section-title h2{margin:0}
.floating{
  position:fixed;
  right:16px;
  bottom:calc(var(--nav-h) + 20px);
  z-index:20;
  width:56px;height:56px;
  border-radius:999px;
  box-shadow:0 16px 30px rgba(17,24,39,.24);
}
.nav{
  position:fixed;
  left:0;right:0;bottom:0;
  height:calc(var(--nav-h) + env(safe-area-inset-bottom));
  padding:10px 10px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-top:1px solid var(--border);
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:8px;
  z-index:30;
}
.nav-btn{
  flex-direction:column;
  gap:4px;
  padding:10px 8px;
  border-radius:14px;
  font-size:.78rem;
}
.nav-btn.active{
  background:var(--primary);
  color:#fff;
}
.nav-icon{
  font-size:1.1rem;
  line-height:1;
}
.page{display:none}
.page.active{display:block}
.helper{
  color:var(--muted);
  font-size:.88rem;
}
.filters{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.chips{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.chip{
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  border-radius:999px;
  padding:10px 14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.chip.active{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}
.form-grid{
  display:grid;
  gap:12px;
}
.form-grid.cols-2{grid-template-columns:1fr}
.form-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
  margin-top:16px;
}
.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(17,24,39,.55);
  display:none;
  place-items:center;
  padding:16px;
  z-index:50;
}
.modal-backdrop.open{display:grid}
.modal{
  width:min(920px,100%);
  max-height:min(92vh,900px);
  overflow:auto;
  background:#fff;
  border-radius:24px;
  box-shadow:0 30px 80px rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.4);
}
.modal-header{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  padding:18px 18px 0;
}
.modal-body{padding:18px}
.modal-title{margin:0}
#toast-root{
  position:fixed;
  left:50%;
  bottom:calc(var(--nav-h) + 18px);
  transform:translateX(-50%);
  display:grid;
  gap:8px;
  z-index:80;
  pointer-events:none;
}
.toast{
  pointer-events:auto;
  min-width:min(92vw,420px);
  background:#111827;
  color:#fff;
  border-radius:14px;
  padding:12px 14px;
  box-shadow:0 18px 40px rgba(0,0,0,.25);
  display:flex;
  align-items:flex-start;
  gap:10px;
}
.toast.success{background:#065f46}
.toast.error{background:#991b1b}
.toast.info{background:#1f2937}
.toast .close{
  margin-left:auto;
  border:0;
  background:transparent;
  color:inherit;
  font-size:1.1rem;
}
.empty{
  padding:24px;
  text-align:center;
  color:var(--muted);
  border:1px dashed var(--border);
  border-radius:18px;
  background:rgba(255,255,255,.6);
}
.sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.kbd{
  font-size:.8rem;
  padding:2px 7px;
  border:1px solid var(--border);
  border-bottom-width:2px;
  border-radius:8px;
  background:#fff;
}
.offline-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.offline-icon{
  width:18px;height:18px;
}
.badge-danger{
  background:#fef2f2;
  color:#991b1b;
}
.badge-success{
  background:#ecfdf5;
  color:#047857;
}
.badge-info{
  background:#eff6ff;
  color:#1d4ed8;
}
.progress{
  height:10px;
  border-radius:999px;
  background:#e5e7eb;
  overflow:hidden;
}
.progress > span{
  display:block;
  height:100%;
  background:linear-gradient(90deg,#2563eb,#4f46e5);
}

.dashboard-grid {
  display: flex;
  flex-direction: column; /* Apila las tarjetas */
  gap: 14px;
}

.card-resumen { order: 1; }
.card-alertas { order: 2; }
.card-movimientos { order: 3; }

/* === MOVEMENT PAGE IMPROVEMENTS === */
.movement-layout {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.movement-main {
  flex: 1;
}

.movement-sidebar {
  display: none;
}

/* Type selector chips mejorados */
.movement-type-selector {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}

.movement-type-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 12px 10px;
  border-radius: 16px;
  border: 2px solid var(--border);
  background: white;
  cursor: pointer;
  transition: all 0.2s;
}

.movement-type-chip:hover {
  transform: translateY(-2px);
  border-color: var(--primary);
  box-shadow: 0 8px 20px rgba(17, 24, 39, 0.08);
}

.movement-type-chip.active {
  background: var(--primary);
  border-color: var(--primary);
  color: white;
  box-shadow: 0 8px 20px rgba(17, 24, 39, 0.15);
}

.chip-icon {
  font-size: 1.5rem;
  line-height: 1;
}

.chip-label {
  font-weight: 600;
  font-size: 0.88rem;
}

/* Form sections */
.movement-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.form-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.form-section-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  padding-bottom: 8px;
  border-bottom: 2px solid var(--border);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.form-actions-enhanced {
  margin-top: 8px;
}

.primary-btn-large {
  width: 100%;
  padding: 16px 20px;
  font-size: 1.05rem;
  font-weight: 600;
  gap: 10px;
}

/* Sidebar info card */
.movement-info-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.movement-info-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  font-size: 1.8rem;
  margin-bottom: 4px;
}

.movement-info-title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
}

.movement-info-description {
  margin: 0;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.5;
}

.movement-help-section {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.movement-help-title {
  margin: 0 0 12px 0;
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--muted);
}

.movement-help-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.movement-help-list li {
  font-size: 0.92rem;
  line-height: 1.4;
  color: var(--text);
}

/* Stats card */
.movement-stats-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.stats-card-title {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--muted);
}

.stats-items {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.stat-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border-radius: 12px;
  background: linear-gradient(180deg, #fff, #fafafa);
  border: 1px solid var(--border);
}

.stat-icon {
  font-size: 1.5rem;
  line-height: 1;
}

.stat-label {
  font-size: 0.85rem;
  color: var(--muted);
}

.stat-value {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--text);
}

.dashboard-footer {
  margin-top: 20px;
  padding: 16px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--muted);
  font-size: 0.85rem;    
}


.footer-copyright {
  margin: 0;
  font-weight: 600;
}

.footer-contact-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 4px 0;
}

.footer-link {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--text);
  font-weight: 500;
  transition: all 0.2s ease;
  padding: 4px 8px;
  border-radius: 8px;
}

.footer-link:hover {
  opacity: 0.8;
  color: var(--primary-color, #2563eb);
}


.footer-link svg {
  stroke: var(--muted);
  transition: stroke 0.2s ease;
}


.footer-link.whatsapp:hover {
  color: #25D366;
  background: rgba(37, 211, 102, 0.1);
}

.footer-link.whatsapp:hover svg {
  stroke: #25D366;
}

.footer-link:not(.whatsapp):hover {
  color: var(--accent);
  background: rgba(37, 99, 235, 0.1);
}

.footer-link:not(.whatsapp):hover svg {
  stroke: var(--accent);
}

.footer-copyright strong {
  color: var(--text);
}

/* Radio button personalizado */
.select-radio {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--border);
  background: white;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  transition: all 0.2s;
}



/* Contenido de la opción */
.select-option-content {
  flex: 1;
  min-width: 0;
}

.select-option-label {
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1.3;
  margin-bottom: 2px;
}

.select-option-meta {
  font-size: 0.82rem;
  color: var(--muted);
}

/* Input oculto (almacena el valor real) */
.select-hidden-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

/* Placeholder cuando no hay selección */
.select-placeholder {
  color: var(--muted);
  font-size: 0.9rem;
  padding: 12px;
  text-align: center;
  border: 1px dashed var(--border);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.5);
}

/* Contenedor del dropdown personalizado */
.custom-dropdown {
  position: relative;
  width: 100%;
}

/* Botón trigger del dropdown */
.dropdown-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border: 2px solid var(--border);
  border-radius: 14px;
  background: white;
  color: var(--text);
  cursor: pointer;
  transition: all 0.2s;
  text-align: left;
  font-size: 0.95rem;
}

.dropdown-trigger:hover {
  border-color: #93c5fd;
  background: #eff6ff;
}

.dropdown-trigger:focus {
  outline: none;
  border-color: #93c5fd;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

/* Texto del dropdown */
.dropdown-text {
  flex: 1;
  color: var(--muted);
}

.dropdown-text.selected {
  color: var(--text);
  font-weight: 600;
}

/* Flecha del dropdown */
.dropdown-arrow {
  font-size: 0.8rem;
  color: var(--muted);
  transition: transform 0.2s;
}

/* Panel flotante del dropdown */
.dropdown-panel {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  background: white;
  border: 2px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 10px 40px rgba(17, 24, 39, 0.15);
  z-index: 100;
  max-height: 320px;
  overflow-y: auto;
  animation: dropdownSlideDown 0.2s ease-out;
}

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

/* Contenedor de opciones */
.dropdown-options {
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Cada opción del dropdown */
.dropdown-option-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 2px solid transparent;
  background: white;
  cursor: pointer;
  transition: all 0.2s;
}

.dropdown-option-card:hover {
  background: #eff6ff;
  border-color: #93c5fd;
}

.dropdown-option-card.selected {
  border-color: var(--primary);
  background: var(--primary);
  color: white;
}

.dropdown-option-card.selected .select-option-meta {
  color: rgba(255, 255, 255, 0.8);
}

.dropdown-option-card.selected .select-radio {
  border-color: white;
  background: white;
}

.dropdown-option-card.selected .select-radio::after {
  content: '';
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--primary);
}

/* Ocultar el select original en móvil */
@media (max-width: 899px) {
  .hide-on-mobile {
    display: none !important;
  }
}

@media (min-width: 900px){
  .shell{
    padding-bottom:0;
  }
  .sidebar{
    display:flex;
    width:var(--side-w);
    flex-direction:column;
    gap:12px;
    padding:18px;
    border-right:1px solid var(--border);
    background:rgba(255,255,255,.84);
    backdrop-filter:blur(10px);
    position:sticky;
    top:0;
    height:100vh;
  }
  .main{
    padding:22px 24px 24px;
  }
  .nav{
    display:none;
  }
  .grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .filters{grid-template-columns:repeat(3,minmax(0,1fr))}
  .form-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .quick-actions{grid-template-columns:repeat(4,minmax(0,1fr))}
  
  .dashboard-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto auto; /* Define dos filas */
    gap: 14px;
  }

  .card-resumen {
    grid-column: 1;
    grid-row: 1;
    order: unset;
  }

  .card-alertas {
    grid-column: 1;
    grid-row: 2;
    order: unset;
    margin-top: 0 !important;
  }

  .card-movimientos {
    grid-column: 2;
    grid-row: 1 / span 2; /* Ocupa fila 1 y 2 */
    order: unset;
  }

  .movement-layout {
    flex-direction: row;
    gap: 20px;
  }

  .movement-main {
    flex: 1;
    min-width: 0;
  }

  .movement-sidebar {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 340px;
    flex-shrink: 0;
  }

  .form-row {
    grid-template-columns: repeat(2, 1fr);
  }

  .movement-type-selector {
    gap: 16px;
  }

  .movement-type-chip {
    padding: 14px 12px;
  }

  .chip-icon {
    font-size: 1.8rem;
  }
 
}
