/* ACEITUNAS VEGA — Estilos globales */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@700;800&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  --verde:        #2d5a27;
  --verde-med:    #3d7a35;
  --verde-claro:  #e8f0e6;
  --verde-suave:  #f2f7f1;
  --dorado:       #b8860b;
  --dorado-claro: #fdf6e3;
  --rojo:         #c0392b;
  --rojo-claro:   #fdecea;
  --amarillo:     #d4a017;
  --amarillo-cl:  #fef9ec;
  --naranja:      #e67e22;
  --naranja-cl:   #fef0e6;
  --azul:         #2471a3;
  --azul-claro:   #eaf4fc;
  --texto:        #1a2e18;
  --texto-med:    #4a5e48;
  --texto-suave:  #7a8e78;
  --borde:        #d4dfd2;
  --fondo:        #f5f8f4;
  --blanco:       #ffffff;
  --sidebar-w:    230px;
  --radio:        10px;
  --radio-lg:     14px;
  --sombra:       0 1px 8px rgba(45,90,39,.07);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--fondo);color:var(--texto);min-height:100vh;font-size:14px;line-height:1.6}
a{color:var(--verde-med);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- SIDEBAR ---- */
.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:var(--verde);display:flex;flex-direction:column;z-index:200}
.sidebar-logo{padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.12)}
.sidebar-logo .marca{font-family:'DM Sans',sans-serif;font-size:17px;font-weight:700;color:#fff;line-height:1.25;letter-spacing:-.3px}
.sidebar-logo .sub{font-size:10px;color:rgba(255,255,255,.45);margin-top:2px;letter-spacing:.05em}
.sidebar-nav{flex:1;overflow-y:auto;padding:10px 0}
.nav-sep{font-size:9px;color:rgba(255,255,255,.3);letter-spacing:.1em;text-transform:uppercase;padding:14px 20px 4px}
.nav-a{display:flex;align-items:center;gap:10px;padding:9px 20px;color:rgba(255,255,255,.72);font-size:13px;border-left:3px solid transparent;transition:all .15s;cursor:pointer;text-decoration:none}
.nav-a:hover{color:#fff;background:rgba(255,255,255,.07);text-decoration:none}
.nav-a.activo{color:#fff;background:rgba(255,255,255,.11);border-left-color:#a8d5a2;font-weight:500}
.nav-a svg{width:16px;height:16px;flex-shrink:0}
.sidebar-foot{padding:14px 20px;border-top:1px solid rgba(255,255,255,.1);font-size:11px;color:rgba(255,255,255,.35)}

/* ---- MAIN ---- */
.main{margin-left:var(--sidebar-w);min-height:100vh}
.topbar{background:var(--blanco);border-bottom:1px solid var(--borde);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.topbar-left h1{font-family:'DM Sans',sans-serif;font-size:18px;font-weight:700;color:var(--verde);letter-spacing:-.3px}
.topbar-left p{font-size:12px;color:var(--texto-suave)}
.topbar-right{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--texto-med)}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--verde-claro);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--verde)}
.contenido{padding:24px 28px}

/* ---- ALERTAS ---- */
.alertas{display:flex;flex-direction:column;gap:7px;margin-bottom:20px}
.alerta{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radio);font-size:13px}
.alerta svg{width:16px;height:16px;flex-shrink:0}
.alerta-roja{background:var(--rojo-claro);color:var(--rojo);border:1px solid #f5c6c3}
.alerta-amarilla{background:var(--amarillo-cl);color:#7a5000;border:1px solid #f0dfa0}
.alerta-info{background:var(--azul-claro);color:var(--azul);border:1px solid #b8d9f0}
.alerta-accion{margin-left:auto;font-size:12px;cursor:pointer;opacity:.8;white-space:nowrap}
.alerta-accion:hover{opacity:1}

/* ---- MÉTRICAS ---- */
.metricas{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.metrica{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--radio-lg);padding:18px 20px;position:relative;overflow:hidden;box-shadow:var(--sombra)}
.metrica::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radio-lg) var(--radio-lg) 0 0}
.m-verde::before{background:var(--verde-med)}
.m-dorado::before{background:var(--dorado)}
.m-rojo::before{background:var(--rojo)}
.m-azul::before{background:var(--azul)}
.metrica label{font-size:11px;color:var(--texto-suave);display:block;margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.metrica .val{font-family:'Outfit',sans-serif;font-size:30px;line-height:1;font-weight:800;letter-spacing:-.5px}
.metrica .sub{font-size:11px;color:var(--texto-suave);margin-top:5px}
.badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:2px 7px;border-radius:20px;margin-top:5px;font-weight:500}
.b-verde{background:#e8f5e9;color:#2e7d32}
.b-rojo{background:var(--rojo-claro);color:var(--rojo)}
.b-amarillo{background:var(--amarillo-cl);color:#7a5000}
.b-azul{background:var(--azul-claro);color:var(--azul)}

/* ---- PANELS / CARDS ---- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.card{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--radio-lg);box-shadow:var(--sombra);overflow:hidden}
.card-head{padding:14px 18px 10px;border-bottom:1px solid var(--borde);display:flex;align-items:center;justify-content:space-between}
.card-titulo{font-size:13px;font-weight:500;display:flex;align-items:center;gap:7px}
.card-titulo svg{width:15px;height:15px;color:var(--verde-med)}
.card-link{font-size:12px;color:var(--verde-med)}
.card-link:hover{text-decoration:underline}
.card-body{padding:0}

/* ---- TABLA ---- */
.tabla-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:10px 14px;font-size:11px;font-weight:500;color:var(--texto-suave);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--borde);background:var(--verde-suave)}
td{padding:10px 14px;border-bottom:1px solid #f0f0ef;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafaf9}

/* ---- SEMÁFORO TAGS ---- */
.tag{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;letter-spacing:.03em}
.tag-vencido{background:var(--rojo-claro);color:var(--rojo)}
.tag-hoy{background:var(--amarillo-cl);color:#7a5000}
.tag-naranja{background:var(--naranja-cl);color:var(--naranja)}
.tag-pronto{background:var(--verde-claro);color:var(--verde)}
.tag-cobrado{background:#e8f5e9;color:#2e7d32}
.tag-pendiente{background:var(--azul-claro);color:var(--azul)}
.tag-contado{background:#f3f0ff;color:#5b21b6}
.tag-credito{background:var(--dorado-claro);color:var(--dorado)}
.tag-proceso{background:var(--amarillo-cl);color:#7a5000}
.tag-listo{background:#e8f5e9;color:#2e7d32}

/* ---- FORMULARIOS ---- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid.g3{grid-template-columns:1fr 1fr 1fr}
.form-grid.g1{grid-template-columns:1fr}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:12px;font-weight:500;color:var(--texto-med)}
.field input,.field select,.field textarea{padding:9px 12px;border:1px solid var(--borde);border-radius:var(--radio);font-family:inherit;font-size:13px;color:var(--texto);background:var(--blanco);transition:border .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--verde-med)}
.field textarea{resize:vertical;min-height:70px}
.field .hint{font-size:11px;color:var(--texto-suave)}

/* ---- BOTONES ---- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radio);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s}
.btn svg{width:15px;height:15px}
.btn-primary{background:var(--verde);color:#fff}
.btn-primary:hover{background:var(--verde-med)}
.btn-secondary{background:var(--blanco);color:var(--texto);border:1px solid var(--borde)}
.btn-secondary:hover{background:var(--verde-suave)}
.btn-danger{background:var(--rojo-claro);color:var(--rojo);border:1px solid #f5c6c3}
.btn-danger:hover{background:#f5c6c3}
.btn-dorado{background:var(--dorado);color:#fff}
.btn-dorado:hover{background:#a07808}
.btn-sm{padding:5px 12px;font-size:12px}
.btns{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ---- BARRA DE PROGRESO ---- */
.barra-f{height:8px;background:var(--verde-claro);border-radius:10px;overflow:hidden}
.barra-r{height:100%;border-radius:10px;transition:width .8s ease}
.barra-verde{background:var(--verde-med)}
.barra-dorado{background:var(--dorado)}
.barra-rojo{background:var(--rojo)}

/* ---- MODAL ---- */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:500;align-items:center;justify-content:center}
.modal-bg.open{display:flex}
.modal{background:var(--blanco);border-radius:var(--radio-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px rgba(0,0,0,.18)}
.modal-head{padding:18px 22px 14px;border-bottom:1px solid var(--borde);display:flex;align-items:center;justify-content:space-between}
.modal-head h2{font-family:'DM Sans',sans-serif;font-size:16px;font-weight:700;color:var(--verde)}
.modal-close{background:none;border:none;cursor:pointer;color:var(--texto-suave);font-size:20px;line-height:1;padding:2px}
.modal-body{padding:20px 22px}
.modal-foot{padding:14px 22px;border-top:1px solid var(--borde);display:flex;justify-content:flex-end;gap:10px}

/* ---- STOCK ITEMS (panel) ---- */
.stock-row{padding:12px 18px;border-bottom:1px solid var(--fondo)}
.stock-row:last-child{border-bottom:none}
.stock-lbl{display:flex;justify-content:space-between;margin-bottom:5px;font-size:13px}

/* ---- ACTIVIDAD ---- */
.act-item{display:flex;align-items:flex-start;gap:10px;padding:10px 18px;border-bottom:1px solid var(--fondo)}
.act-item:last-child{border-bottom:none}
.act-ico{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.act-ico svg{width:14px;height:14px}
.ico-venta{background:#e3f0fb;color:var(--azul)}
.ico-compra{background:var(--verde-claro);color:var(--verde)}
.ico-cobro{background:#e8f5e9;color:#2e7d32}
.act-txt{flex:1;min-width:0}
.act-txt p{font-size:13px}
.act-txt small{font-size:11px;color:var(--texto-suave)}
.act-monto{font-size:13px;font-weight:500;white-space:nowrap}
.pos{color:var(--verde-med)}.neg{color:var(--rojo)}

/* ---- COBRO ITEMS (panel) ---- */
.cobro-item{display:flex;align-items:center;gap:10px;padding:10px 18px;border-bottom:1px solid var(--fondo)}
.cobro-item:last-child{border-bottom:none}
.cobro-ini{width:30px;height:30px;border-radius:50%;background:var(--verde-claro);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--verde);flex-shrink:0}
.cobro-ini.r{background:var(--rojo-claro);color:var(--rojo)}
.cobro-ini.a{background:var(--amarillo-cl);color:#7a5000}
.cobro-info{flex:1;min-width:0}
.cobro-info strong{font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cobro-info small{font-size:11px;color:var(--texto-suave)}
.cobro-right{text-align:right}
.cobro-right strong{font-size:13px;display:block}

/* ---- CRÉDITO BANCO (panel) ---- */
.credito-nums{display:flex;justify-content:space-between;margin-bottom:12px}
.cnum label{font-size:11px;color:var(--texto-suave);display:block;text-transform:uppercase;letter-spacing:.04em}
.cnum .v{font-family:'Outfit',sans-serif;font-size:20px;font-weight:800;letter-spacing:-.3px}
.prox-cuota{background:var(--amarillo-cl);border:1px solid #f0dfa0;border-radius:var(--radio);padding:10px 14px;display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.prox-cuota .pc-l label{font-size:11px;color:#7a5000}
.prox-cuota .pc-l strong{font-size:13px;color:#5a4000}
.prox-cuota .pc-r{text-align:right}
.prox-cuota .pc-r strong{font-family:'Outfit',sans-serif;font-size:17px;font-weight:800;color:#5a4000}
.prox-cuota .pc-r small{font-size:11px;color:#8a6800}

/* ---- LOGIN ---- */
.login-bg{min-height:100vh;background:var(--verde);display:flex;align-items:center;justify-content:center}
.login-box{background:var(--blanco);border-radius:var(--radio-lg);padding:36px 40px;width:100%;max-width:380px;box-shadow:0 8px 40px rgba(0,0,0,.2)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo h1{font-family:'Outfit',sans-serif;font-size:28px;font-weight:800;color:var(--verde);letter-spacing:-.5px}
.login-logo p{font-size:13px;color:var(--texto-suave);margin-top:4px}
.login-box .field{margin-bottom:14px}
.login-box .btn-primary{width:100%;justify-content:center;padding:11px}
.login-error{background:var(--rojo-claro);color:var(--rojo);padding:9px 12px;border-radius:var(--radio);font-size:13px;margin-bottom:14px;border:1px solid #f5c6c3}

/* ---- PÁGINA INTERIOR HEADER ---- */
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.page-head h2{font-family:'Outfit',sans-serif;font-size:22px;font-weight:800;color:var(--verde);letter-spacing:-.3px}
.filtros{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--radio-lg);padding:14px 18px;margin-bottom:18px;display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;box-shadow:var(--sombra)}
.filtros .field{flex:1;min-width:160px}

/* ---- MÉTRICAS MÓDULOS (compras/ventas/stock) ---- */
.mod-metricas{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}
.mod-metrica{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--radio-lg);padding:16px 20px;box-shadow:var(--sombra);position:relative;overflow:hidden}
.mod-metrica::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radio-lg) var(--radio-lg) 0 0}
.mm-verde::before{background:var(--verde-med)}
.mm-dorado::before{background:var(--dorado)}
.mm-rojo::before{background:var(--rojo)}
.mm-azul::before{background:var(--azul)}
.mod-metrica label{font-size:10px;color:var(--texto-suave);display:block;margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.mod-metrica .mval{font-family:'Outfit',sans-serif;font-size:28px;font-weight:800;line-height:1;letter-spacing:-.5px}
.mod-metrica .msub{font-size:11px;color:var(--texto-suave);margin-top:5px}

/* ---- VACÍO ---- */
.empty{text-align:center;padding:40px 20px;color:var(--texto-suave)}
.empty svg{width:40px;height:40px;margin:0 auto 10px;display:block;opacity:.3}

/* ---- FLASH ---- */
.flash{position:fixed;bottom:24px;right:24px;z-index:999;padding:12px 18px;border-radius:var(--radio);font-size:13px;font-weight:500;box-shadow:0 4px 20px rgba(0,0,0,.15);animation:flashIn .3s ease}
.flash-ok{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}
.flash-err{background:var(--rojo-claro);color:var(--rojo);border:1px solid #f5c6c3}
@keyframes flashIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ---- REPORTES ---- */
.reporte-filtros{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--radio-lg);padding:14px 18px;margin-bottom:18px;display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.kpi{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--radio-lg);padding:16px 18px;text-align:center;box-shadow:var(--sombra)}
.kpi label{font-size:11px;color:var(--texto-suave);display:block;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}
.kpi .v{font-family:'Outfit',sans-serif;font-size:28px;font-weight:800;letter-spacing:-.5px}

@media(max-width:1100px){
  .metricas{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr 1fr}
}
@media(max-width:700px){
  .sidebar{display:none}
  .main{margin-left:0}
  .metricas{grid-template-columns:1fr}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}
