/* ══════════════════════════════════════════════
   Recrops Manager — Admin Panel CSS
══════════════════════════════════════════════ */
:root{
  --cp:#2e7d32;--cpl:#4caf50;--cpp:#e8f5e9;
  --cd:#1a2a3a;--cg:#546e7a;--cl:#cfd8dc;
  --cbg:#f0f4f0;--cw:#ffffff;--ca:#f57f17;
  --cr:#c62828;--cb:#1565c0;--cpurple:#6a1b9a;
  --r:8px;--fn:'Barlow',sans-serif;--fc:'Barlow Condensed',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fn);background:var(--cbg);color:var(--cd);min-height:100vh}

/* ── LOADING ── */
#adm-loading{
  position:fixed;inset:0;
  background:linear-gradient(135deg,#1a2a3a 0%,#0d1f0d 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:9999;gap:10px;
}
#adm-loading .ld-icon{width:52px;height:52px;animation:spin 1.5s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ld-brand{font-family:var(--fc);font-size:1.6rem;font-weight:800;color:#fff;letter-spacing:1px}
.ld-brand span{color:#4caf50}
.ld-sub{font-size:.72rem;font-weight:700;letter-spacing:3px;color:#546e7a;text-transform:uppercase}
.ld-msg{font-size:.78rem;color:#90a4ae;margin-top:6px}

/* ── TOPBAR ── */
.adm-topbar{
  position:sticky;top:0;z-index:300;
  background:#1a2a3a;color:#fff;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;height:52px;gap:12px;
  box-shadow:0 2px 12px rgba(0,0,0,.4);
}
.atb-left{display:flex;align-items:center;gap:8px;flex-shrink:0}
.atb-brand{font-family:var(--fc);font-size:1.05rem;font-weight:700;color:#fff}
.atb-brand strong{color:#4caf50}
.atb-badge{background:#6a1b9a;color:#fff;font-size:.6rem;font-weight:800;
  padding:2px 7px;border-radius:20px;letter-spacing:1px;text-transform:uppercase}
.atb-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.atb-logout{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:#90a4ae;padding:5px 12px;border-radius:6px;cursor:pointer;
  font-family:var(--fn);font-size:.78rem;transition:all .2s}
.atb-logout:hover{background:rgba(198,40,40,.3);color:#fff;border-color:#c62828}

/* ── BODY LAYOUT (sidebar + main) ── */
.adm-body{
  display:flex;
  height:calc(100vh - 52px);
  overflow:hidden;
}

/* ── SIDEBAR ── */
.adm-sidebar{
  width:220px;flex-shrink:0;
  background:#1a2a3a;
  display:flex;flex-direction:column;justify-content:space-between;
  overflow-y:auto;
  border-right:1px solid rgba(255,255,255,.07);
}
.adm-sb-nav{display:flex;flex-direction:column;padding:10px 0}
.adm-sb-btn{
  display:flex;align-items:center;gap:12px;
  width:100%;padding:10px 16px;
  background:none;border:none;border-radius:0;
  color:rgba(255,255,255,.75);cursor:pointer;
  font-size:.875rem;font-family:var(--fn);font-weight:500;
  text-align:left;transition:background .15s,color .15s;
  white-space:nowrap;
}
.adm-sb-btn:hover{background:rgba(255,255,255,.07);color:#fff}
.adm-sb-btn.active{
  background:rgba(76,175,80,.15);color:#4caf50;
  border-right:3px solid #4caf50;
}
.sb-icon{font-size:1rem;width:22px;text-align:center;flex-shrink:0}
.sb-label{flex:1}
.adm-sb-logout{
  margin:10px 12px 16px;padding:9px 12px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:8px;color:rgba(255,255,255,.75);
  cursor:pointer;font-size:.83rem;font-family:var(--fn);font-weight:600;
  transition:background .15s;text-align:left;
}
.adm-sb-logout:hover{background:rgba(198,40,40,.3);color:#fff}

/* ── MAIN LAYOUT ── */
.adm-main{flex:1;overflow-y:auto;padding:20px 20px 40px}
.adm-page{display:none}
.adm-page.active{display:block}
.adm-section-title{
  font-family:var(--fc);font-size:1rem;font-weight:800;
  letter-spacing:1px;text-transform:uppercase;color:var(--cd);
  margin-bottom:14px;
}
.adm-row{display:flex;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.flex-1{flex:1;min-width:220px}
.flex-2{flex:2;min-width:260px}
.flex-3{flex:3;min-width:300px}

/* ── CARDS ── */
.adm-card{
  background:var(--cw);border-radius:var(--r);
  box-shadow:0 2px 12px rgba(0,0,0,.07);
  padding:16px;margin-bottom:14px;
}
.adm-card-hdr{
  font-family:var(--fc);font-size:.82rem;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;color:var(--cg);
  margin-bottom:12px;
}

/* ── KPI GRID ── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:14px}
.kpi-card{
  background:var(--cw);border-radius:var(--r);
  box-shadow:0 2px 10px rgba(0,0,0,.07);
  padding:16px 14px;text-align:center;
  border-top:3px solid var(--cl);
  transition:transform .15s;
}
.kpi-card:hover{transform:translateY(-2px)}
.kpi-card.kpi-green{border-top-color:var(--cp)}
.kpi-icon{font-size:1.4rem;margin-bottom:4px}
.kpi-val{font-family:var(--fc);font-size:1.8rem;font-weight:900;color:var(--cd);line-height:1.1}
.kpi-lbl{font-size:.7rem;color:var(--cg);font-weight:600;margin-top:2px}

/* ── TABLES ── */
.adm-table{width:100%;border-collapse:collapse;font-size:.82rem}
.adm-table th{
  background:#f5f7fa;color:var(--cg);font-weight:700;
  padding:9px 10px;text-align:left;
  border-bottom:2px solid var(--cl);white-space:nowrap;
  font-family:var(--fc);font-size:.78rem;letter-spacing:.5px;text-transform:uppercase;
}
.adm-table td{padding:9px 10px;border-bottom:1px solid var(--cl);vertical-align:middle}
.adm-table tbody tr:hover{background:#f9fbf9}
.adm-table tbody tr:last-child td{border-bottom:none}

/* ── BADGES ── */
.plan-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.68rem;font-weight:800;letter-spacing:.5px;text-transform:uppercase}
.plan-trial{background:#fff3e0;color:#e65100}
.plan-individual{background:#e3f2fd;color:#1565c0}
.plan-empresa{background:#e8f5e9;color:#2e7d32}
.status-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.68rem;font-weight:700}
.status-active{background:#e8f5e9;color:#2e7d32}
.status-trial{background:#fff3e0;color:#e65100}
.status-expired{background:#ffebee;color:#c62828}
.status-suspended{background:#f3e5f5;color:#6a1b9a}
.role-badge{display:inline-block;padding:2px 7px;border-radius:20px;font-size:.66rem;font-weight:700}
.role-dueno{background:#f3e5f5;color:#6a1b9a}
.role-supervisor{background:#e3f2fd;color:#1565c0}
.role-planificacion{background:#e0f2f1;color:#00695c}
.role-piloto{background:#e8f5e9;color:#2e7d32}
.role-super_admin{background:#1a2a3a;color:#4caf50}

/* ── FORM ELEMENTS ── */
.adm-input{
  width:100%;padding:8px 10px;border:1px solid var(--cl);
  border-radius:6px;font-family:var(--fn);font-size:.83rem;
  background:#fff;color:var(--cd);outline:none;transition:border .2s;
}
.adm-input:focus{border-color:var(--cp);box-shadow:0 0 0 2px rgba(46,125,50,.12)}
select.adm-input{cursor:pointer}
textarea.adm-input{min-height:70px}

/* ── BUTTONS ── */
.adm-btn{
  padding:8px 16px;border-radius:6px;border:1px solid var(--cl);
  font-family:var(--fn);font-size:.83rem;font-weight:600;
  cursor:pointer;background:#fff;color:var(--cd);transition:all .2s;
}
.adm-btn:hover{background:#f5f5f5}
.adm-btn-primary{background:var(--cp);color:#fff;border-color:var(--cp)}
.adm-btn-primary:hover{background:#1b5e20}
.adm-btn-sm{padding:5px 10px;border-radius:5px;border:1px solid var(--cl);
  font-family:var(--fn);font-size:.76rem;font-weight:600;cursor:pointer;background:#fff;
  color:var(--cd);transition:all .15s;white-space:nowrap}
.adm-btn-sm:hover{background:#f0f0f0}
.adm-btn-green{background:var(--cp)!important;color:#fff!important;border-color:var(--cp)!important}
.adm-btn-orange{background:#e65100!important;color:#fff!important;border-color:#e65100!important}
.adm-btn-red{background:#c62828!important;color:#fff!important;border-color:#c62828!important}
.adm-btn-icon{padding:5px 10px;border-radius:5px;border:1px solid var(--cl);
  background:#fff;cursor:pointer;font-size:.8rem;transition:all .15s}
.adm-btn-icon:hover{background:#f0f4ff;border-color:var(--cb)}

/* ── MODAL ── */
.adm-modal-ov{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);
  z-index:800;align-items:center;justify-content:center;padding:16px;
}
.adm-modal-ov.open{display:flex}
.adm-modal{
  background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.2);
  width:100%;max-width:620px;max-height:92vh;overflow-y:auto;
}
.adm-modal-hdr{
  background:#1a2a3a;color:#fff;padding:12px 16px;
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--fc);font-size:.9rem;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  border-radius:12px 12px 0 0;position:sticky;top:0;
}
.adm-modal-hdr button{background:transparent;border:none;color:#90a4ae;
  font-size:1.2rem;cursor:pointer;line-height:1}
.adm-modal-hdr button:hover{color:#fff}
.adm-modal-body{padding:20px}
.adm-field{margin-bottom:14px}
.adm-field label{display:block;font-size:.75rem;font-weight:700;
  color:var(--cg);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}
.adm-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:500px){.adm-field-row{grid-template-columns:1fr}}

/* ── TOAST ── */
#adm-toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:#1a2a3a;color:#fff;padding:10px 20px;border-radius:8px;
  font-size:.83rem;font-weight:600;z-index:9000;
  opacity:0;pointer-events:none;transition:opacity .3s;white-space:nowrap;
}
#adm-toast.show{opacity:1}

/* ── DASH LISTS ── */
.dash-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 0;border-bottom:1px solid var(--cl);gap:10px;flex-wrap:wrap;
}
.dash-row:last-child{border-bottom:none}
.dash-co{font-weight:600;font-size:.84rem}
.dash-meta{font-size:.75rem;color:var(--cg)}

/* ── HAMBURGER MENU TOGGLE ── */
.adm-menu-tog{display:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;
  width:34px;height:34px;background:none;border:none;cursor:pointer;padding:4px;
  border-radius:6px;margin-right:6px;flex-shrink:0}
.adm-menu-tog:hover{background:rgba(255,255,255,.12)}
.adm-tog-bar{display:block;width:20px;height:2px;background:#fff;border-radius:2px;
  transition:transform .22s,opacity .22s}
.adm-menu-tog.open .adm-tog-bar:nth-child(1){transform:translateY(6px) rotate(45deg)}
.adm-menu-tog.open .adm-tog-bar:nth-child(2){opacity:0}
.adm-menu-tog.open .adm-tog-bar:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ── MOBILE MENU OVERLAY ── */
.adm-mobile-menu{display:none;position:fixed;inset:0;z-index:1200;
  background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.adm-mobile-menu.open{display:flex}
.adm-mm-inner{position:absolute;top:0;left:0;bottom:0;width:min(280px,85vw);
  background:#1a2a3a;display:flex;flex-direction:column;
  animation:admSlideIn .22s ease-out}
@keyframes admSlideIn{from{transform:translateX(-100%)}to{transform:translateX(0)}}
.adm-mm-header{display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.12);min-height:52px}
.adm-mm-user{color:#90a4ae;font-size:.72rem;max-width:140px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adm-mm-close{background:none;border:none;color:#fff;font-size:1.1rem;cursor:pointer;
  padding:4px 8px;border-radius:4px;opacity:.7}
.adm-mm-close:hover{opacity:1;background:rgba(255,255,255,.12)}
.adm-mm-tabs{flex:1;overflow-y:auto;padding:8px 0}
.adm-mm-btn{display:flex;align-items:center;gap:12px;width:100%;padding:11px 18px;
  background:none;border:none;color:rgba(255,255,255,.85);cursor:pointer;
  font-size:.9rem;font-family:var(--fc);font-weight:600;text-align:left;
  transition:background .15s}
.adm-mm-btn:hover,.adm-mm-btn.active{background:rgba(255,255,255,.1);color:#fff}
.adm-mm-btn.active{border-left:3px solid #4caf50;padding-left:15px}
.adm-mm-btn span:first-child{font-size:1.1rem;width:24px;text-align:center}
.adm-mm-logout{margin:10px 14px 18px;padding:10px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.15);border-radius:8px;color:rgba(255,255,255,.8);
  cursor:pointer;font-size:.85rem;font-family:var(--fc);font-weight:600;transition:background .15s}
.adm-mm-logout:hover{background:rgba(198,40,40,.3);color:#fff}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .adm-sidebar{display:none}
  .adm-menu-tog{display:flex}
  .adm-main{padding:12px 10px 40px}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .adm-row{flex-direction:column}
  .flex-1,.flex-2,.flex-3{flex:none;width:100%}
}
.tog{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}
.tog input{opacity:0;width:0;height:0}
.tog-slider{position:absolute;cursor:pointer;inset:0;background:#444;border-radius:20px;transition:.2s}
.tog-slider:before{content:'';position:absolute;width:14px;height:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}
.tog input:checked+.tog-slider{background:#2e7d32}
.tog input:checked+.tog-slider:before{transform:translateX(16px)}

/* Analytics sub-tabs */
.anal-tab-btn{background:transparent;border:1px solid #263545;color:#90a4ae;padding:5px 12px;border-radius:6px;cursor:pointer;font-size:.78rem;font-weight:600;transition:all .15s}
.anal-tab-btn:hover{background:#263545;color:#fff}
.anal-tab-btn.active{background:rgba(76,175,80,.15);border-color:#4caf50;color:#4caf50}
/* ── TOOLTIPS ── */
.tip{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;font-size:.6rem;font-weight:700;color:#4caf50;cursor:default;position:relative;vertical-align:middle;margin-left:3px;flex-shrink:0;user-select:none;line-height:1}
.tip::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:#1a2a3a;color:#fff;font-size:.72rem;font-weight:400;line-height:1.45;padding:6px 10px;border-radius:7px;white-space:normal;max-width:240px;width:max-content;pointer-events:none;opacity:0;transition:opacity .15s;z-index:9999;text-transform:none;letter-spacing:0;box-shadow:0 3px 12px rgba(0,0,0,.35)}
.tip:hover::after,.tip.tip-open::after{opacity:1}
@media(max-width:768px){.tip::after{left:auto;right:0;transform:none;max-width:200px}}
