/* ══════════════════════════════════════════════════════════════
   _components.css · AgroRadar Soluciones — Componentes de mockup
   Importar junto con _base.css en cada micro-landing
══════════════════════════════════════════════════════════════ */

/* ── PHONE FRAME ── */
.phone-frame{width:200px;border-radius:24px;overflow:hidden;
  box-shadow:0 18px 52px rgba(0,0,0,.22),0 4px 12px rgba(0,0,0,.10),
             0 0 0 1px rgba(0,0,0,.08);background:var(--surf);flex-shrink:0}
.phone-bar{height:38px;background:var(--gxdk);display:flex;align-items:center;
  justify-content:center;flex-shrink:0}
.phone-logo{font-size:11px;font-weight:800;color:rgba(255,255,255,.92);letter-spacing:.1em}
.phone-body{padding:1rem;display:flex;flex-direction:column;gap:.6rem}
.phone-section-title{font-size:13px;font-weight:800;color:var(--tx);margin-bottom:.25rem}
.phone-date{font-size:11px;color:var(--tx3);font-weight:500}

/* ── PHONE FIELD ── */
.pf{background:var(--bg);border:1px solid var(--bd2);border-radius:7px;padding:.45rem .625rem}
.pf-label{font-size:10px;font-weight:700;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.pf-val{font-size:13px;color:var(--tx);font-weight:500}

/* ── PHONE BUTTON ── */
.ph-btn{background:var(--g);color:#fff;border:none;border-radius:7px;
  padding:.55rem;font-size:13px;font-weight:700;width:100%;text-align:center;
  cursor:pointer;display:block}
.ph-btn-s{background:var(--bg);color:var(--tx2);border:1px solid var(--bd2);border-radius:7px;
  padding:.45rem;font-size:12px;font-weight:600;width:100%;text-align:center;cursor:pointer}

/* ── ASISTENCIA BUTTONS (nómina) ── */
.asis-row{display:flex;align-items:center;justify-content:space-between;
  padding:.4rem 0;border-bottom:1px solid var(--bd)}
.asis-row:last-child{border-bottom:none}
.asis-name{font-size:12px;font-weight:600;color:var(--tx);flex:1}
.asis-btns{display:flex;gap:4px}
.asis-btn{font-size:10px;font-weight:700;padding:3px 7px;border-radius:5px;
  cursor:pointer;border:none;transition:opacity .1s}
.asis-btn-p{background:var(--glt);color:var(--gdk)}
.asis-btn-f{background:var(--rlt);color:var(--r)}
.asis-btn-m{background:var(--alt);color:var(--adk)}
.asis-btn.active-p{background:var(--g);color:#fff}
.asis-btn.active-f{background:var(--rmd);color:#fff}
.asis-btn.active-m{background:var(--a);color:#fff}

/* ── TABLE MOCK ── */
.tmock{width:100%}
.tmock-hdr{display:grid;padding:.4rem .5rem;
  font-size:11px;font-weight:700;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.05em;
  border-bottom:2px solid var(--bd2);margin-bottom:.25rem}
.tmock-row{display:grid;align-items:center;padding:.45rem .5rem;
  border-radius:6px;font-size:12px;color:var(--tx2);
  border-bottom:1px solid var(--bd)}
.tmock-row:last-child{border-bottom:none}
.tmock-row:hover{background:var(--bg)}
.tmock-name{font-weight:700;color:var(--tx);font-size:13px}
.tmock-sub{font-size:11px;color:var(--tx3);font-weight:500}
.tmock-num{font-variant-numeric:tabular-nums;font-weight:600}

/* ── KPI CARDS ── */
.kpi-row{display:grid;gap:.5rem}
.kpi{background:var(--bg);border-radius:8px;padding:.625rem .75rem;border:1px solid var(--bd)}
.kpi-val{font-size:22px;font-weight:800;color:var(--tx);
  font-variant-numeric:tabular-nums;line-height:1}
.kpi-lbl{font-size:11px;color:var(--tx3);font-weight:700;margin-top:3px;
  text-transform:uppercase;letter-spacing:.04em}
.kpi-sub{font-size:11px;color:var(--tx3);margin-top:2px}

/* ── PROGRESS BAR ── */
.prog-wrap{margin-bottom:.625rem}
.prog-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}
.prog-name{font-size:13px;font-weight:700;color:var(--tx)}
.prog-pct{font-size:12px;font-weight:700}
.prog-sub{font-size:11px;color:var(--tx3);margin-bottom:.3rem;font-weight:500}
.prog-track{height:7px;background:#D4DAD4;border-radius:4px;overflow:hidden}
.prog-fill{height:100%;border-radius:4px}

/* ── BADGE ROW ── */
.smb{font-size:11px;font-weight:700;padding:3px 7px;border-radius:4px;flex-shrink:0;white-space:nowrap}
.smb-g{background:#C8EAD8;color:var(--gdk)}
.smb-a{background:#F0DFC0;color:var(--adk)}
.smb-r{background:#F2D4D4;color:var(--r)}
.smb-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}

/* ── SEMÁFORO ── */
.semaforo{display:inline-flex;align-items:center;gap:.35rem;
  font-size:12px;font-weight:700}
.semaforo-dot{width:8px;height:8px;border-radius:50%}
.sem-ok .semaforo-dot{background:var(--g)}
.sem-ok{color:var(--gdk)}
.sem-warn .semaforo-dot{background:var(--a)}
.sem-warn{color:var(--adk)}
.sem-alert .semaforo-dot{background:var(--rmd)}
.sem-alert{color:var(--r)}

/* ── CHART BARS (horizontal) ── */
.chart-bar-wrap{display:flex;flex-direction:column;gap:5px}
.cb{display:flex;align-items:center;gap:.5rem}
.cb-lbl{font-size:12px;color:var(--tx3);width:36px;text-align:right;
  flex-shrink:0;font-weight:500}
.cb-track{flex:1;height:7px;background:#D8DDD8;border-radius:4px;overflow:hidden}
.cb-fill{height:100%;border-radius:4px;background:var(--g)}
.cb-val{font-size:12px;color:var(--tx3);width:36px;font-weight:600;
  font-variant-numeric:tabular-nums}

/* ── EXPORT BUTTON ── */
.export-btn{display:inline-flex;align-items:center;gap:.5rem;
  background:var(--bg);border:1.5px solid var(--bd2);border-radius:var(--ra);
  padding:.55rem 1rem;font-size:13px;font-weight:700;color:var(--tx2);
  cursor:pointer;transition:background .15s,border-color .15s}
.export-btn:hover{background:var(--glt);border-color:var(--g);color:var(--gdk)}

/* ── TIMELINE ── */
.timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:1.4rem}
.timeline::before{content:'';position:absolute;left:.52rem;top:4px;bottom:4px;
  width:2px;background:linear-gradient(to bottom,var(--g),rgba(29,158,117,.15));
  border-radius:2px}
.tl-item{display:flex;align-items:flex-start;gap:.6rem;padding:.35rem 0;position:relative}
.tl-dot{position:absolute;left:-1.25rem;top:.4rem;width:10px;height:10px;
  border-radius:50%;border:2px solid #fff;flex-shrink:0}
.tl-dot-g{background:var(--g);box-shadow:0 0 0 2px var(--g)}
.tl-dot-a{background:var(--a);box-shadow:0 0 0 2px var(--a)}
.tl-dot-r{background:var(--rmd);box-shadow:0 0 0 2px var(--rmd)}
.tl-main{font-size:13px;font-weight:600;color:var(--tx)}
.tl-sub{font-size:11px;color:var(--tx3)}
.tl-sub-warn{font-size:11px;color:var(--a);font-weight:600}
.tl-sub-alert{font-size:11px;color:var(--r);font-weight:600}

/* ── INVENTORY TABLE ── */
.inv-cols-4{grid-template-columns:1.5fr .7fr .7fr .8fr}
.inv-cols-3{grid-template-columns:1.6fr 1fr .9fr}
.stock-ok{color:var(--gdk);font-weight:700}
.stock-low{color:var(--r);font-weight:700}
.stock-warn{color:var(--a);font-weight:700}

/* ── DASHBOARD SECTION LABEL ── */
.dash-label{font-size:11px;color:var(--tx3);font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}

/* ── EXPORT ACTIONS BAR ── */
.export-bar{display:flex;align-items:center;justify-content:flex-end;
  gap:.5rem;margin-top:.875rem;padding-top:.875rem;border-top:1px solid var(--bd)}
.export-btn-pdf{display:inline-flex;align-items:center;gap:.4rem;
  background:#FEF2F2;border:1.5px solid #E8AAAA;border-radius:var(--ra);
  padding:.45rem .875rem;font-size:12px;font-weight:700;color:#A32D2D;
  cursor:pointer;transition:background .15s}
.export-btn-pdf:hover{background:#F7DCDC}
.export-btn-xl{display:inline-flex;align-items:center;gap:.4rem;
  background:#EDF7ED;border:1.5px solid #A5D6A7;border-radius:var(--ra);
  padding:.45rem .875rem;font-size:12px;font-weight:700;color:#2E7D32;
  cursor:pointer;transition:background .15s}
.export-btn-xl:hover{background:#C8E6C9}
