/* ============================================================
   DISEÑO SIMPLE Y LIMPIO — Registro de Ingresos
   ============================================================ */
:root{
  --bg:#f4f6fb;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --border:#e6e9f2;
  --primary:#4f46e5;
  --primary-d:#4338ca;
  --grad:linear-gradient(135deg,#6366f1,#4f46e5);
  --efectivo:#10b981;
  --transferencia:#3b82f6;
  --yape:#7c3aed;
  --plin:#06b6d4;
  --shadow:0 6px 20px rgba(17,24,39,.05);
  --radio:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
.muted{color:var(--muted);font-size:14px}
.oculto{display:none !important}
.pantalla{display:none}
.pantalla.activa{display:block}
@keyframes subir{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ===================== LOGIN ===================== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(135deg,#eef2ff,#f4f6fb)}
.login-card{width:100%;max-width:400px;background:var(--card);border-radius:20px;padding:34px 28px;
  box-shadow:0 12px 40px rgba(79,70,229,.12);text-align:center;animation:subir .4s ease}
.login-logo{font-size:40px;margin-bottom:8px}
.login-card h1{font-size:22px;font-weight:800}
.login-card .muted{margin:6px 0 22px}
.login-card form{text-align:left;display:flex;flex-direction:column}
.login-card label{font-size:13px;font-weight:600;color:var(--muted);margin:8px 0 6px}
.login-card input{border:1.6px solid var(--border);border-radius:12px;padding:13px;font-size:16px;font-family:inherit;background:#fbfbfe;color:var(--text)}
.login-card input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px rgba(99,102,241,.12)}
.login-foot{font-size:12px;color:var(--muted);margin-top:18px}

/* ===================== BOTONES / FEEDBACK ===================== */
.btn-primary{width:100%;margin-top:16px;border:none;border-radius:12px;padding:15px;font-size:16px;font-weight:700;color:#fff;background:var(--grad);cursor:pointer;font-family:inherit;box-shadow:0 8px 18px rgba(79,70,229,.22);transition:transform .12s,box-shadow .12s}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(79,70,229,.28)}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.6;cursor:default;transform:none}
.btn-ancho{max-width:340px;margin:6px auto 0;display:block}
.feedback{font-size:14px;text-align:center;min-height:18px;margin-top:10px;font-weight:600}
.feedback.ok{color:var(--efectivo)}
.feedback.fail{color:#ef4444}

/* ===================== ESTRUCTURA APP ===================== */
.app-shell{display:flex;min-height:100vh}
.sidebar{display:none}
.app-content{flex:1;min-width:0}

.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 22px;position:sticky;top:0;z-index:10;background:rgba(245,247,251,.88);backdrop-filter:blur(10px)}
.topbar-greet h1{font-size:22px;font-weight:800}
.topbar-greet .muted{font-size:13px;margin-top:2px}
.topbar-right{display:flex;align-items:center;gap:10px}
.date-chip{display:flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:9px 14px;font-size:13px;font-weight:600;color:var(--text);box-shadow:var(--shadow);white-space:nowrap}
.rol-chip{font-size:10px;font-weight:700;color:var(--primary-d);background:#eef0ff;padding:1px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px;display:inline-block}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:700;font-size:15px;flex:none}
.icon-btn{border:none;background:#eef0f6;width:36px;height:36px;border-radius:11px;font-size:15px;cursor:pointer;color:var(--muted)}
.icon-btn:hover{background:#fee2e2;color:#ef4444}
.only-mobile{display:none !important}

/* KPIs grandes (estilo panel ejecutivo) */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.kpi-big{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow);display:flex;gap:14px;align-items:flex-start;transition:transform .15s,box-shadow .15s}
.kpi-big:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(17,24,39,.08)}
.kpi-big-ico{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;font-size:22px;flex:none;box-shadow:0 6px 14px rgba(79,70,229,.18)}
.g-indigo{background:linear-gradient(135deg,#6366f1,#4f46e5)}
.g-green{background:linear-gradient(135deg,#34d399,#10b981)}
.g-amber{background:linear-gradient(135deg,#fbbf24,#f59e0b)}
.g-blue{background:linear-gradient(135deg,#60a5fa,#3b82f6)}
.kpi-big-info{min-width:0}
.kpi-big-label{font-size:13px;color:var(--muted);font-weight:500}
.kpi-big-value{font-size:24px;font-weight:800;display:block;margin:3px 0;letter-spacing:-.5px}
.kpi-big-delta{font-size:12px;font-weight:600}
.kpi-big-delta.up{color:#16a34a}
.kpi-big-delta.down{color:#ef4444}
.kpi-big-delta.neutro{color:var(--muted)}

/* Secciones del dashboard a 2 columnas */
.dash-2col{display:grid;grid-template-columns:1fr;gap:16px}
.card-head .small{font-size:12px;font-weight:500}

/* Participación por local (barras de progreso) */
.progreso-lista{display:flex;flex-direction:column;gap:16px}
.progreso-top{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;margin-bottom:6px}
.progreso-bar{height:9px;background:#eef0f6;border-radius:99px;overflow:hidden}
.progreso-bar span{display:block;height:100%;border-radius:99px;transition:width .4s ease}
.progreso-sub{font-size:12px;color:var(--muted);margin-top:4px;display:block}

.app-main{max-width:1100px;margin:0 auto;width:100%;padding:6px 18px 110px}
.vista{display:none;animation:subir .3s ease}
.vista.activa{display:block}
.vista-head{margin:4px 4px 16px}
.vista-head h2{font-size:20px}
.vista-head .muted{margin-top:4px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radio);padding:18px;box-shadow:var(--shadow);margin-bottom:16px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card h3{font-size:14px;font-weight:700}

/* ===================== DASHBOARD ===================== */
.saludo{margin:4px 4px 18px}
.saludo h2{font-size:23px;font-weight:800}
.saludo .muted{margin-top:3px;text-transform:capitalize}

.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:12px}
.stat-text{min-width:0}
.stat-ico{width:38px;height:38px;display:grid;place-items:center;border-radius:11px;background:color-mix(in srgb,var(--c) 14%,#fff);font-size:18px;margin-bottom:10px}
.stat-label{font-size:13px;color:var(--muted);font-weight:500;display:block}
.stat-value{font-size:22px;font-weight:800;display:block;margin-top:2px;letter-spacing:-.5px}
.stat-sub{font-size:12px;color:var(--muted);display:block;margin-top:3px}
.ring{position:relative;width:62px;height:62px;border-radius:50%;flex:none;background:conic-gradient(var(--c) calc(var(--p)*1%),#eceef6 0)}
.ring::after{content:'';position:absolute;inset:7px;border-radius:50%;background:var(--card)}
.ring span{position:absolute;inset:0;display:grid;place-items:center;font-size:13px;font-weight:800;z-index:1;color:var(--c)}

.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.kpi-ico{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;font-size:18px;background:color-mix(in srgb,var(--c) 15%,#fff)}
.kpi-ico.efectivo{--c:var(--efectivo)}.kpi-ico.transferencia{--c:var(--transferencia)}.kpi-ico.yape{--c:var(--yape)}.kpi-ico.plin{--c:var(--plin)}
.kpi-badge{font-size:12px;font-weight:700;color:var(--primary-d);background:#eef0ff;padding:3px 9px;border-radius:999px}
.kpi-label{font-size:13px;color:var(--muted);font-weight:500}
.kpi-amount{font-size:20px;font-weight:800;display:block;margin-top:3px;letter-spacing:-.5px}

.two-col{display:grid;grid-template-columns:1fr;gap:16px}
.locales-lista{display:flex;flex-direction:column;gap:10px}
.local-row{display:flex;align-items:center;gap:12px;padding:11px;border-radius:13px;background:#fafbff;border:1px solid var(--border)}
.local-ico{width:40px;height:40px;display:grid;place-items:center;border-radius:11px;font-size:18px;flex:none;color:#fff}
.local-ico.c0{background:#4f46e5}.local-ico.c1{background:#3b82f6}.local-ico.c2{background:#10b981}.local-ico.c3{background:#f59e0b}
.local-meta{flex:1;min-width:0;line-height:1.3}
.local-meta strong{font-size:14px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.local-meta span{font-size:13px;color:var(--muted)}
.local-share{font-size:13px;font-weight:700;color:var(--primary-d);background:#eef0ff;padding:3px 9px;border-radius:999px}

/* ===================== REGISTRAR ===================== */
.form-ingreso{max-width:640px}
.row2{display:flex;gap:12px}
.field-group{flex:1;display:flex;flex-direction:column;gap:6px;margin-bottom:6px}
.field-group label{font-size:13px;font-weight:600;color:var(--muted)}
.field-group select,.field-group input{border:1.6px solid var(--border);border-radius:12px;padding:13px;font-size:15px;font-family:inherit;background:#fbfbfe;color:var(--text);width:100%}
.field-group select:focus,.field-group input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px rgba(99,102,241,.1)}
.metodos-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0}
.metodo-card{border:1.6px solid var(--border);border-radius:14px;padding:13px;display:flex;flex-direction:column;gap:9px;cursor:text;transition:.15s;background:#fff}
.metodo-card.efectivo{--c:var(--efectivo)}.metodo-card.transferencia{--c:var(--transferencia)}.metodo-card.yape{--c:var(--yape)}.metodo-card.plin{--c:var(--plin)}
.metodo-card:focus-within{border-color:var(--c);box-shadow:0 0 0 4px color-mix(in srgb,var(--c) 14%,transparent)}
.metodo-top{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700}
.metodo-ico{width:30px;height:30px;display:grid;place-items:center;border-radius:9px;background:color-mix(in srgb,var(--c) 15%,#fff);font-size:15px}
.metodo-input{display:flex;align-items:center;border-top:1px solid var(--border);padding-top:9px}
.metodo-input>span{color:var(--muted);font-weight:700;margin-right:6px;font-size:15px}
.metodo-input input{border:none;outline:none;background:transparent;font-size:19px;font-weight:700;width:100%;font-family:inherit;color:var(--text)}
.total-box{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#ecfdf5,#eef2ff);border:1px solid #e3e8ff;border-radius:14px;padding:16px 18px;margin-bottom:16px}
.total-box span{font-weight:600;color:var(--muted)}
.total-box strong{font-size:26px;font-weight:800;color:var(--primary-d)}

/* ===================== REPORTES ===================== */
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:15px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:5px;border-left:4px solid var(--border)}
.kpi span{font-size:12px;color:var(--muted);font-weight:600}
.kpi strong{font-size:19px;font-weight:800}
.kpi.total{grid-column:1 / -1;background:var(--grad);color:#fff;border-left:none}
.kpi.total span{color:rgba(255,255,255,.85)}
.kpi.efectivo{border-left-color:var(--efectivo)}.kpi.transferencia{border-left-color:var(--transferencia)}.kpi.yape{border-left-color:var(--yape)}.kpi.plin{border-left-color:var(--plin)}
canvas{max-width:100%}
.empty{text-align:center;padding:40px 20px;background:var(--card);border:1px solid var(--border);border-radius:var(--radio);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px;align-items:center}
.empty-ico{font-size:38px;margin-bottom:6px}

/* Selector de período (Semanal / Quincenal / Mensual) */
.segment{display:flex;background:#eef0f6;border-radius:12px;padding:4px;gap:4px;margin-bottom:14px}
.seg-btn{flex:1;border:none;background:none;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;color:var(--muted);padding:10px;border-radius:9px;transition:.15s}
.seg-btn:hover{color:var(--text)}
.seg-btn.activa{background:#fff;color:var(--primary-d);box-shadow:0 1px 3px rgba(17,24,39,.1)}
.periodo-nav{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.nav-arrow{width:40px;height:40px;border:1px solid var(--border);background:#fff;border-radius:11px;cursor:pointer;font-size:22px;line-height:1;color:var(--primary-d);font-weight:700;display:grid;place-items:center}
.nav-arrow:hover{background:#eef0ff;border-color:var(--primary)}
.periodo-rango{flex:1;text-align:center;font-weight:700;font-size:15px}
.kpi-delta{font-size:12px;font-weight:700;margin-top:4px;color:rgba(255,255,255,.92)}

/* Pestañas para elegir un local */
.local-tabs{display:flex;gap:8px;overflow-x:auto;margin-bottom:14px;padding-bottom:2px}
.local-tab{flex:none;border:1px solid var(--border);background:#fff;color:var(--muted);font-family:inherit;font-weight:600;font-size:13px;padding:9px 15px;border-radius:999px;cursor:pointer;white-space:nowrap;transition:.15s}
.local-tab:hover{border-color:#cdd3ec;color:var(--text)}
.local-tab.activa{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(79,70,229,.25)}

/* Movilidad en el registro */
.movilidad-box{display:flex;align-items:center;gap:12px;background:#fffbeb;border:1.6px solid #fde68a;border-radius:14px;padding:12px 14px;margin-bottom:16px}
.mov-ico{width:40px;height:40px;display:grid;place-items:center;border-radius:11px;background:#fef3c7;font-size:18px;flex:none}
.mov-text{flex:1;min-width:0;line-height:1.3}
.mov-text strong{font-size:14px;display:block}
.mov-text .muted{font-size:12px}
.mov-input{display:flex;align-items:center;border:1.6px solid #fde68a;border-radius:11px;padding:8px 10px;background:#fff}
.mov-input>span{color:#b45309;font-weight:700;margin-right:6px}
.mov-input input{border:none;outline:none;background:transparent;font-size:17px;font-weight:700;width:90px;font-family:inherit;color:var(--text)}

/* Botones suaves (exportar / guardar) */
.btn-soft{margin-top:10px;width:100%;border:1px solid var(--border);background:#fff;color:var(--primary-d);font-family:inherit;font-weight:700;font-size:14px;padding:12px;border-radius:12px;cursor:pointer;transition:.15s}
.btn-soft:hover{background:#eef0ff;border-color:var(--primary)}
.btn-soft.excel{color:#15803d}
.btn-soft.excel:hover{background:#ecfdf3;border-color:#22c55e}
.acciones-reporte{display:flex;gap:10px;margin-top:10px}
.acciones-reporte .btn-soft{flex:1;margin-top:0;width:auto}

/* Foto del cierre de caja */
.foto-box{margin-bottom:16px}
.foto-head{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:8px}
.foto-drop{display:flex;align-items:center;justify-content:center;text-align:center;border:1.6px dashed #c7cde0;border-radius:14px;padding:18px;color:var(--muted);font-size:14px;font-weight:600;cursor:pointer;background:#fbfbfe;transition:.15s}
.foto-drop:hover{border-color:var(--primary);color:var(--primary-d);background:#f4f5ff}
.foto-preview{position:relative;margin-top:10px;border-radius:14px;overflow:hidden;border:1px solid var(--border)}
.foto-preview img{display:block;width:100%;max-height:240px;object-fit:cover}
.foto-quitar{position:absolute;top:8px;right:8px;border:none;background:rgba(15,23,42,.72);color:#fff;font-weight:700;font-size:12px;padding:6px 10px;border-radius:9px;cursor:pointer}
.foto-quitar:hover{background:#ef4444}

/* KPIs extra (movilidad / neto) y título del reporte */
.kpis-extra{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.kpi.mov{border-left-color:#f59e0b}
.kpi.neto{border-left-color:#0ea5e9}
.reporte-titulo{font-weight:800;font-size:16px;margin:2px 4px 14px;color:var(--text)}

/* Banner del modo demo */
.demo-banner{position:fixed;top:10px;left:50%;transform:translateX(-50%);z-index:60;background:var(--grad);color:#fff;font-size:12px;font-weight:600;padding:8px 16px;border-radius:999px;box-shadow:0 6px 18px rgba(79,70,229,.35);max-width:92vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Pulido: elevación sutil al pasar el cursor */
.stat-card,.kpi-card,.local-row{transition:transform .15s,box-shadow .15s,border-color .15s}
.stat-card:hover,.kpi-card:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(17,24,39,.08)}
.local-row:hover{border-color:#cdd3ec}

/* ===================== NAV INFERIOR (móvil) ===================== */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-top:1px solid var(--border);padding:8px 6px}
.nav-btn{flex:1;border:none;background:none;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;font-weight:600;color:var(--muted);padding:6px 0;border-radius:12px}
.nav-btn .ico{font-size:20px;filter:grayscale(.4)}
.nav-btn.activa{color:var(--primary-d)}
.nav-btn.activa .ico{filter:none}

/* ===================== RESPONSIVE ===================== */
@media(max-width:959px){
  .avatar.only-mobile{display:grid !important}
  .icon-btn.only-mobile{display:grid !important;place-items:center}
  .topbar{padding:14px 16px}
  .topbar-greet h1{font-size:19px}
}
@media(max-width:760px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .kpis-extra{grid-template-columns:1fr}
  .date-chip{display:none}
}
@media(min-width:960px){
  .sidebar{display:flex;flex-direction:column;width:256px;flex:none;background:linear-gradient(180deg,#202d4f 0%,#161f37 100%);color:#cbd5e1;padding:24px 16px;position:sticky;top:0;height:100vh}
  .side-profile{text-align:center;padding:6px 8px 20px;margin-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center;gap:4px}
  .side-avatar{width:64px;height:64px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:800;font-size:26px;border:3px solid rgba(255,255,255,.14);margin-bottom:6px}
  .side-profile strong{color:#fff;font-size:15px}
  .side-email{font-size:12px;color:#8ea0c0;word-break:break-all}
  .side-profile .rol-chip{margin-top:4px;background:rgba(99,102,241,.25);color:#c7d2fe}
  .side-nav{display:flex;flex-direction:column;gap:5px;margin-top:6px}
  .side-link{display:flex;align-items:center;gap:13px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:15px;font-weight:600;color:#aab6d0;padding:13px 15px;border-radius:12px;text-align:left;transition:.15s}
  .side-link .ico{font-size:17px}
  .side-link:hover{background:rgba(255,255,255,.06);color:#fff}
  .side-link.activa{background:#3b82f6;color:#fff;box-shadow:0 8px 18px rgba(59,130,246,.4)}
  .side-logout{margin-top:auto;display:flex;align-items:center;gap:10px;justify-content:center;border:1px solid rgba(255,255,255,.14);background:transparent;color:#aab6d0;padding:12px;border-radius:12px;cursor:pointer;font-family:inherit;font-weight:600;font-size:14px;transition:.15s}
  .side-logout:hover{background:rgba(239,68,68,.18);color:#fff;border-color:transparent}
  .bottom-nav{display:none}
  .app-main{padding:6px 26px 40px}
  .metodos-grid{grid-template-columns:repeat(4,1fr)}
  .kpis{grid-template-columns:repeat(5,1fr)}
  .kpi.total{grid-column:auto}
  .two-col,.dash-2col{grid-template-columns:1.7fr 1fr}
  canvas{max-height:320px}
}
