/* ============================================================
   FRUNORT — Plataforma Agro
   Bricolage Grotesque (display) + Hanken Grotesk (UI)
   Paleta: verde botánico + ámbar mango + papel cálido
   ============================================================ */
:root {
  --bosque: #0E2A20;
  --bosque-2: #143A2C;
  --verde: #1C5340;
  --verde-2: #2F7D5B;
  --verde-vivo: #57a773;
  --mango: #F2A900;
  --mango-dark: #C77F00;
  --mango-soft: #FCEBC4;
  --terracota: #C0492E;
  --paper: #FAF7F0;
  --card: #FFFFFF;
  --ink: #181711;
  --ink-soft: #5C5A50;
  --line: #E7E2D6;
  --line-soft: #F0ECE1;
  --good: #2F7D5B;
  --warn: #C77F00;
  --bad: #C0492E;
  --r: 14px;
  --shadow: 0 1px 2px rgba(20,40,30,.05), 0 8px 28px -18px rgba(20,40,30,.18);
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  background: var(--paper); color: var(--ink); line-height: 1.55;
  -webkit-font-smoothing: antialiased; font-variant-numeric: tabular-nums;
}
.brand-font { font-family: "Bricolage Grotesque", sans-serif; }
a { color: var(--verde); text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
em { font-style: normal; color: var(--mango); }
.muted { color: var(--ink-soft); }
.num { text-align: right; font-variant-numeric: tabular-nums; }

/* =================== LAYOUT (app-shell) =================== */
/* La ventana no scrollea: la barra y el contenido scrollean por separado.
   Así la barra verde SIEMPRE llena la altura completa. */
body.con-sesion { display: flex; height: 100vh; overflow: hidden; }
.sidebar {
  width: 248px; flex: 0 0 248px; background: var(--bosque); color: #cfe3d8;
  display: flex; flex-direction: column; height: 100vh; overflow-y: auto;
}
.marca { display: flex; align-items: center; gap: 11px; padding: 22px 20px 16px;
  color: #fff; border-bottom: 1px solid rgba(255,255,255,.08); }
.marca-hoja { font-size: 24px; color: var(--mango); filter: drop-shadow(0 2px 6px rgba(242,169,0,.4)); }
.marca-txt { font-size: 16px; line-height: 1.05; font-weight: 700; }
.marca-txt b { color: var(--mango); }
.sidebar-empresa { padding: 14px 16px 6px; }
.empresa-form, .empresa-fija {
  display: flex; align-items: center; gap: 10px; background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1); border-radius: 11px; padding: 9px 12px;
}
.empresa-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--c, var(--verde-vivo)); flex: 0 0 auto;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c, var(--verde-vivo)) 28%, transparent); }
.empresa-form select { flex: 1; background: transparent; border: 0; color: #fff; font-family: inherit;
  font-size: 14px; font-weight: 700; cursor: pointer; outline: none; appearance: none; }
.empresa-form select option { color: #1d2b24; }
.empresa-corto { color: #fff; font-weight: 700; font-size: 14px; }
.empresa-larga { color: #8faea0; font-size: 11px; }

.sidebar nav { padding: 8px 12px; flex: 1; }
.nav-grupo { font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: #6f8a7e;
  font-weight: 700; margin: 15px 10px 5px; }
.nav-item { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 10px;
  color: #bcd3c8; font-size: 14px; font-weight: 500; transition: .14s; }
.nav-item .ico { color: var(--verde-vivo); font-size: 11px; }
.nav-item:hover { background: rgba(255,255,255,.06); color: #fff; }
.nav-item.activo { background: var(--verde); color: #fff; }
.nav-item.activo .ico { color: var(--mango); }
.nav-item.pendiente { color: #6f8a7e; cursor: default; }
.nav-item.pendiente:hover { background: none; }
.lock { margin-left: auto; font-size: 10px; text-transform: uppercase; letter-spacing: .06em;
  color: #6f8a7e; border: 1px solid rgba(255,255,255,.12); padding: 1px 6px; border-radius: 6px; }
.sidebar-pie { padding: 14px 20px; font-size: 11px; color: #6f8472; border-top: 1px solid rgba(255,255,255,.08); }

.contenido { flex: 1; min-width: 0; height: 100vh; overflow-y: auto; display: flex; flex-direction: column; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: 16px;
  background: rgba(250,247,240,.85); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line); padding: 13px 30px; position: sticky; top: 0; z-index: 6; }
.page-h { font-family: "Bricolage Grotesque", sans-serif; font-size: 22px; font-weight: 700; letter-spacing: -.02em; }
.page-sub { font-size: 12.5px; color: var(--ink-soft); margin-top: 1px; }
.topbar-right { display: flex; align-items: center; }
.userbox { display: flex; align-items: center; gap: 11px; }
.role-badge { display: inline-flex; align-items: center; font-size: 12px; font-weight: 700;
  padding: 6px 12px; border-radius: 999px; }
.badge-owner { background: var(--bosque-2); color: #dff0e7; }
.badge-admin { background: #E7EEF9; color: #26508f; }
.badge-op { background: var(--mango-soft); color: var(--mango-dark); }
.avatar { width: 36px; height: 36px; border-radius: 50%; flex: 0 0 auto;
  background: linear-gradient(135deg, var(--mango), var(--terracota)); color: #fff;
  display: grid; place-items: center; font-weight: 700; font-size: 13px; }
.user-nombre { font-weight: 600; font-size: 14px; }
.user-rol { font-size: 11.5px; color: var(--ink-soft); }
.btn-salir { margin-left: 6px; font-size: 13px; padding: 7px 12px; border: 1px solid var(--line);
  border-radius: 9px; color: var(--ink-soft); background: var(--card); }
.btn-salir:hover { border-color: var(--terracota); color: var(--terracota); }
.contenido-int { padding: 24px 0 60px; }

/* =================== HERO (home empleado) =================== */
.hero { padding: 12px 32px 10px; }
/* Barra de selectores (Campaña/Periodo). Faltaba su definición base -> quedaba pegada. */
.barra-acciones { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin: 8px 32px 24px; }
.hero-eyebrow { text-transform: uppercase; letter-spacing: .14em; font-size: 11.5px; font-weight: 700;
  color: var(--mango-dark); margin-bottom: 6px; }
.hero-titulo { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700;
  font-size: clamp(26px, 3.5vw, 38px); margin: 0; line-height: 1.05; letter-spacing: -.02em; }
.hero-sub { color: var(--ink-soft); margin: 8px 0 0; font-size: 15px; }

/* =================== KPIs =================== */
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; margin: 0 32px 20px; }
.kpi { background: var(--card); border: 1px solid var(--line); border-radius: var(--r); padding: 16px 18px; box-shadow: var(--shadow); }
.kpi .l { font-size: 12.5px; color: var(--ink-soft); display: flex; align-items: center; gap: 6px; }
.kpi .v { font-size: 26px; font-weight: 700; letter-spacing: -.02em; margin-top: 7px; }
.kpi .v.hero { font-family: "Bricolage Grotesque", sans-serif; }
.kpi .d { font-size: 12px; margin-top: 5px; font-weight: 600; }
.up { color: var(--good); } .down { color: var(--bad); } .neu { color: var(--ink-soft); }

/* =================== PANELES / GRÁFICOS =================== */
.cols { display: grid; grid-template-columns: 1.15fr 1fr; gap: 18px; margin: 0 32px 20px; }
.panel { background: var(--card); border: 1px solid var(--line); border-radius: var(--r);
  padding: 18px 20px; box-shadow: var(--shadow); margin: 0 32px 20px; }
.cols .panel { margin: 0; }
.panel h3 { font-family: "Bricolage Grotesque", sans-serif; font-size: 16px; font-weight: 600; }
.panel .ph-sub { font-size: 12px; color: var(--ink-soft); margin-bottom: 14px; margin-top: 2px; }
.legend { display: flex; flex-wrap: wrap; gap: 12px; font-size: 12px; color: var(--ink-soft); margin-bottom: 8px; }
.legend span { display: flex; align-items: center; gap: 5px; }
.dot { width: 9px; height: 9px; border-radius: 3px; }
.chart-wrap { position: relative; width: 100%; }

/* =================== ESTADO DE RESULTADO =================== */
.pl-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 0;
  border-bottom: 1px solid var(--line-soft); font-size: 14px; }
.pl-row.minus .pl-v { color: var(--bad); }
.pl-row.minus .pl-name { color: var(--ink-soft); padding-left: 14px; }
.pl-row.total { font-weight: 700; border-bottom: 2px solid var(--line); font-size: 15px; }
.pl-row.grand { font-weight: 800; color: var(--verde); font-size: 16px; border-bottom: none; }
.pl-pct { font-size: 11.5px; color: #9b988c; width: 54px; text-align: right; }
.pl-v { font-variant-numeric: tabular-nums; width: 130px; text-align: right; font-weight: 600; }

/* =================== TABLAS =================== */
.tbl-tools { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; gap: 12px; flex-wrap: wrap; }
.paginacion { display: flex; justify-content: space-between; align-items: center; gap: 12px;
  margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--line-soft); font-size: 13px; }
/* Botón secundario (acciones no principales: Volver, Cancelar, Traer de SUNAT, pestañas…) */
.btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 15px; border-radius: 10px;
  font-size: 13.5px; font-weight: 600; font-family: inherit; cursor: pointer; text-decoration: none;
  background: var(--card); color: var(--verde); border: 1.5px solid var(--line); }
.btn:hover { border-color: var(--verde-2); background: var(--line-soft); }
/* Acciones por fila (editar / eliminar) */
.col-acc { width: 1%; white-space: nowrap; text-align: right; }
.acciones-fila { display: inline-flex; gap: 6px; align-items: center; }
.btn-mini { display: inline-grid; place-items: center; width: 30px; height: 30px; border-radius: 8px;
  border: 1px solid var(--line); background: var(--card); color: var(--ink-soft); font-size: 14px;
  cursor: pointer; text-decoration: none; font-family: inherit; }
.btn-mini:hover { border-color: var(--verde-2); color: var(--verde); }
.btn-mini-del:hover { border-color: var(--bad); color: var(--bad); }
.btn-txt { width: auto; height: auto; padding: 6px 12px; font-size: 12.5px; font-weight: 600; gap: 4px; }
.btn-pagar { border-color: var(--verde-2); color: var(--verde); }
.btn-pagar:hover { background: var(--verde); color: #fff; border-color: var(--verde); }
.btn-peligro { border-color: var(--bad); color: var(--bad); }
.btn-peligro:hover { background: var(--bad); color: #fff; border-color: var(--bad); }
table.datos { width: 100%; border-collapse: collapse; font-size: 13px; }
table.datos th { text-align: left; font-size: 11px; letter-spacing: .05em; text-transform: uppercase;
  color: #9b988c; font-weight: 700; padding: 0 10px 9px; border-bottom: 1px solid var(--line); white-space: nowrap; }
table.datos td { padding: 11px 10px; border-bottom: 1px solid var(--line-soft); color: var(--ink); white-space: nowrap; }
table.datos tbody tr:hover td { background: #FBFAF5; }
/* Resalta por un instante la fila recién guardada/editada */
@keyframes resaltarFila { 0% { background: #FCEFC7; } 100% { background: transparent; } }
table.datos tbody tr.fila-nueva td { animation: resaltarFila 3s ease-out; }
table.datos tfoot .fila-totales td { border-top: 2px solid var(--line); border-bottom: none;
  background: var(--line-soft); padding-top: 11px; padding-bottom: 11px; font-size: 13.5px; }
.pill { font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 999px; }
.pill.ok { background: #E4F2EA; color: var(--good); }
.pill.pend { background: var(--mango-soft); color: var(--mango-dark); }
.tag { font-size: 10.5px; font-weight: 700; padding: 2px 8px; border-radius: 6px; white-space: nowrap; }
.tag-serv { background: #E2EEF0; color: #1f6b78; }
.tag-mat { background: #EEE7DC; color: #8a6512; }
.empresa-tag { font-size: 10.5px; font-weight: 700; padding: 2px 7px; border-radius: 6px; }
.t-dpm { background: #F3E0DC; color: #9a3a2a; }
.t-fsl { background: #F3E9DC; color: #9a6418; }
.t-frunort { background: #E1EFE7; color: #1f6045; }

/* =================== FORMULARIOS =================== */
.btn-primary { background: var(--verde); color: #fff; padding: 10px 16px; border-radius: 10px;
  font-size: 13.5px; font-weight: 600; display: inline-flex; align-items: center; gap: 7px; border: 0; }
.btn-primary:hover { background: var(--bosque-2); }
.form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; }
.fld label { display: block; font-size: 12.5px; font-weight: 600; color: var(--ink-soft); margin-bottom: 6px; }
.fld input, .fld select { width: 100%; padding: 10px 12px; border: 1.5px solid var(--line); border-radius: 10px;
  font-family: inherit; font-size: 14px; background: #fff; color: var(--ink); }
.fld input:focus, .fld select:focus { outline: none; border-color: var(--verde-2); }
.form-foot { display: flex; align-items: center; gap: 12px; margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--line-soft); }

/* =================== ALERTAS =================== */
.alerta { display: flex; align-items: flex-start; gap: 11px; padding: 11px 14px; border-radius: 10px;
  font-size: 13.5px; margin-bottom: 8px; border: 1px solid var(--line); }
.alerta:last-child { margin-bottom: 0; }
.alerta-ic { font-size: 16px; line-height: 1.3; flex: 0 0 auto; }
.alerta b { font-weight: 700; }
.alerta-bad { background: #f7e4dd; border-color: #e6bcae; color: #8a3322; }
.alerta-warn { background: var(--mango-soft); border-color: #ecd9a6; color: #8a5a12; }
.alerta-ok { background: #E4F2EA; border-color: #bfe0c8; color: #1c5436; }

/* =================== NOTICE =================== */
.notice { display: flex; gap: 13px; background: #F4F8F5; border: 1px solid #DCEAE1; border-radius: var(--r);
  padding: 15px 18px; margin: 0 32px 20px; }
.notice .ic { font-size: 18px; flex: 0 0 auto; }
/* Solo el TÍTULO (b hijo directo del div) es bloque; las negritas dentro del texto quedan en línea. */
.notice > div > b { display: block; font-size: 13.5px; margin-bottom: 3px; color: var(--bosque-2); }
.notice p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.55; }
.notice p b { font-weight: 700; color: var(--ink); }
.notice p i { color: var(--ink-soft); }

/* =================== FLASH =================== */
.flash { margin: 0 32px 18px; padding: 12px 16px; border-radius: 10px; font-size: 14px; }
.flash-error { background: #f7e4dd; color: #8a3322; border: 1px solid #e6bcae; }
.flash-info { background: #e7eee8; color: #214a37; }
.flash-ok { background: #E4F2EA; color: #1c5436; border: 1px solid #bfe0c8; }

/* =================== LOGIN =================== */
body.sin-sesion { min-height: 100vh; display: grid; place-items: center; position: relative;
  background: radial-gradient(120% 120% at 80% -10%, #1C5340 0%, #0E2A20 55%, #0a2018 100%); }
.atmosfera { position: fixed; inset: 0; pointer-events: none;
  background: radial-gradient(40% 50% at 12% 90%, rgba(242,169,0,.22), transparent 70%); }
.contenido-login { position: relative; z-index: 2; width: 100%; max-width: 420px; padding: 22px; }
.login-card { background: var(--card); border-radius: 22px; padding: 38px 34px 28px; box-shadow: 0 30px 80px -30px rgba(0,0,0,.6); }
.login-emblema { font-size: 32px; color: var(--mango); margin-bottom: 10px; filter: drop-shadow(0 3px 8px rgba(242,169,0,.4)); }
.login-titulo { font-family: "Bricolage Grotesque", sans-serif; font-weight: 700; font-size: 28px; letter-spacing: -.02em; }
.login-sub { color: var(--ink-soft); margin: 4px 0 22px; font-size: 14px; }
.login-card label { display: block; font-size: 13px; font-weight: 600; color: #3c4b42; margin-bottom: 14px; }
.login-card input { width: 100%; margin-top: 6px; padding: 12px 13px; font-size: 15px; font-family: inherit;
  border: 1.5px solid var(--line); border-radius: 11px; background: #fff; color: var(--ink); }
.login-card input:focus { outline: none; border-color: var(--mango); }
.login-card button { width: 100%; margin-top: 8px; padding: 13px; font-size: 15px; font-weight: 700; font-family: inherit;
  color: #fff; background: linear-gradient(135deg, var(--verde-2), var(--bosque-2)); border: 0; border-radius: 11px; }
.login-card button:hover { filter: brightness(1.08); }
.login-pie { text-align: center; color: var(--ink-soft); font-size: 12px; margin-top: 20px; }

/* =================== RESPONSIVE =================== */
/* Botón de menú y overlay: ocultos en escritorio, aparecen en móvil. */
.nav-toggle, .nav-overlay { display: none; }

@media (max-width: 880px) {
  /* En móvil/tablet: scroll normal de toda la página y menú lateral deslizable. */
  body.con-sesion { display: block; height: auto; overflow: visible; }
  .contenido { height: auto; overflow: visible; }

  /* Sidebar = cajón que entra desde la izquierda con el botón ☰. */
  .sidebar {
    position: fixed; top: 0; left: 0; bottom: 0; width: 264px; height: 100vh;
    transform: translateX(-100%); transition: transform .25s ease; z-index: 60; box-shadow: 0 0 30px rgba(0,0,0,.25);
  }
  body.nav-open .sidebar { transform: translateX(0); }
  .nav-overlay { display: block; position: fixed; inset: 0; background: rgba(0,0,0,.4);
    opacity: 0; pointer-events: none; transition: opacity .25s; z-index: 55; }
  body.nav-open .nav-overlay { opacity: 1; pointer-events: auto; }
  .nav-toggle {
    display: flex; align-items: center; justify-content: center; position: fixed; top: 10px; left: 10px; z-index: 50;
    width: 44px; height: 44px; border: 1px solid var(--line); border-radius: 11px; background: #fff;
    font-size: 20px; line-height: 1; cursor: pointer; box-shadow: 0 2px 10px rgba(0,0,0,.10);
  }

  .topbar { position: static; padding-left: 66px; flex-wrap: wrap; row-gap: 8px; }
  .cols { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }          /* formularios en una sola columna */
  .kpi-grid { grid-template-columns: 1fr 1fr; }        /* indicadores de a dos */
  .hero-titulo { font-size: 30px; }
  .kpi-grid, .panel, .cols, .notice, .flash, .hero, .barra-acciones, .grupo-titulo, .tabla-wrap { margin-left: 14px; margin-right: 14px; }
}

@media (max-width: 520px) {
  .kpi-grid { grid-template-columns: 1fr; }            /* en celular, indicadores apilados */
  .role-badge { display: none; }                        /* ahorra espacio en la barra superior */
  .userbox-txt { display: none; }
  .kpi-grid, .panel, .cols, .notice, .flash, .hero, .barra-acciones { margin-left: 10px; margin-right: 10px; }
}
