/* DoGroup · Control de Gastos v2.0 */
:root{
  --brand:#2563eb;--brand2:#7c3aed;--ok:#10b981;--warn:#f59e0b;--bad:#ef4444;
  --bg:#f1f5f9;--card:#fff;--sidebar:#0f172a;--sidebar2:#1e293b;
  --text:#0f172a;--text2:#475569;--text3:#94a3b8;--border:#e2e8f0;--border2:#cbd5e1;
  --radius:12px;--radius-sm:8px;--radius-lg:16px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow:0 4px 12px rgba(0,0,0,.1);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;}

/* SIDEBAR */
.sidebar{width:260px;background:var(--sidebar);color:#cbd5e1;display:flex;flex-direction:column;overflow:hidden;}
@media(min-width:992px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:1040;}}
.sidebar-brand{display:flex;align-items:center;gap:12px;padding:20px 18px;border-bottom:1px solid rgba(255,255,255,.06);background:rgba(0,0,0,.2);}
.sidebar-logo{width:44px;height:44px;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;flex-shrink:0;box-shadow:0 4px 14px rgba(37,99,235,.4);}
.sidebar-title{font-weight:700;color:#f1f5f9;font-size:.95rem;line-height:1.2;}
.sidebar-subtitle{color:#475569;font-size:.7rem;margin-top:2px;}
.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px;}
.sidebar-nav::-webkit-scrollbar{width:4px;}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:4px;}
.side-section{font-size:.65rem;text-transform:uppercase;color:#475569;padding:14px 10px 5px;letter-spacing:.08em;font-weight:700;}
.side-list{list-style:none;padding:0;margin:0;}
.side-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:#94a3b8;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .15s ease;margin-bottom:2px;}
.side-link:hover{background:rgba(255,255,255,.07);color:#f1f5f9;}
.side-link.active{background:rgba(37,99,235,.2);color:#60a5fa;}
.side-link.active .side-icon{color:#3b82f6;}
.side-icon{font-size:1rem;width:20px;text-align:center;flex-shrink:0;}
.side-link-danger:hover{background:rgba(239,68,68,.1);color:#fca5a5;}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:14px;border-top:1px solid rgba(255,255,255,.06);background:rgba(0,0,0,.15);}
.user-name{font-size:.82rem;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-rol-label{font-size:.7rem;color:#64748b;margin-top:1px;}

/* TOPBAR MÓVIL */
.mobile-topbar{display:flex;align-items:center;gap:4px;padding:10px 14px;background:var(--sidebar);border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:1030;}
.mobile-brand{flex:1;font-weight:700;color:#f1f5f9;font-size:.95rem;display:flex;align-items:center;gap:8px;}
.mobile-brand i{color:#3b82f6;}
.btn-burger{background:none;border:none;color:#94a3b8;font-size:1.35rem;padding:6px;border-radius:8px;cursor:pointer;transition:background .15s,color .15s;text-decoration:none;display:flex;align-items:center;}
.btn-burger:hover{background:rgba(255,255,255,.08);color:#f1f5f9;}

/* MAIN */
.main-content{min-height:100vh;}
@media(min-width:992px){.main-content{margin-left:260px;}}

/* SALDO BOX */
.saldo-box{background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:var(--radius-lg);padding:22px 24px;color:#fff;position:relative;overflow:hidden;}
.saldo-box::after{content:'';position:absolute;top:-30px;right:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none;}
.saldo-box .label{font-size:.78rem;opacity:.8;font-weight:500;text-transform:uppercase;letter-spacing:.06em;}
.saldo-box .monto{font-size:2.1rem;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-top:4px;}

/* KPI */
.kpi{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);}
.kpi .lbl{font-size:.72rem;color:var(--text2);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;}
.kpi .val{font-size:1.4rem;font-weight:800;color:var(--text);letter-spacing:-.02em;}

/* CARDS */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);}
.card-header{padding:13px 18px;border-bottom:1px solid var(--border);font-weight:600;font-size:.9rem;background:transparent;border-radius:var(--radius) var(--radius) 0 0;}
.card-body{padding:18px;}

/* BADGES ESTADO */
.estado{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:.72rem;font-weight:700;}
.estado.registrado{background:#eff6ff;color:#1d4ed8;}
.estado.enviado_supervisor,.estado.enviado_jefe{background:#fefce8;color:#854d0e;}
.estado.aprobado_supervisor,.estado.aprobado_jefe{background:#ecfdf5;color:#065f46;}
.estado.rechazado_supervisor,.estado.rechazado_jefe,.estado.rechazado{background:#fef2f2;color:#991b1b;}
.estado.enviado_gerente,.estado.enviado_validador{background:#f0f9ff;color:#0c4a6e;}
.estado.validado{background:#f0fdf4;color:#15803d;}
.estado.borrador{background:#f8fafc;color:#64748b;}

/* BADGE ROL */
.rol-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;}

/* PROGRESS */
.prog-bg{height:8px;border-radius:8px;background:#e2e8f0;overflow:hidden;}
.prog-fill{height:100%;border-radius:8px;transition:width .5s ease;}
.prog-ok{background:linear-gradient(90deg,#10b981,#34d399);}
.prog-warn{background:linear-gradient(90deg,#f59e0b,#fbbf24);}
.prog-bad{background:linear-gradient(90deg,#ef4444,#f87171);}

/* FORMULARIOS */
.form-label{font-size:.8rem;font-weight:600;color:var(--text2);margin-bottom:5px;display:block;}
.form-control,.form-select{border:1.5px solid var(--border2);border-radius:var(--radius-sm);padding:10px 14px;font-size:.9rem;color:var(--text);background:var(--card);transition:border-color .2s,box-shadow .2s;width:100%;}
.form-control:focus,.form-select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(37,99,235,.12);outline:none;}
.input-clp{font-weight:600;}

/* BOTONES */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .15s;text-decoration:none;}
.btn:active{transform:scale(.98);}
.btn-primary{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;}
.btn-primary:hover{opacity:.9;color:#fff;}
.btn-secondary{background:var(--bg);color:var(--text2);border:1.5px solid var(--border2);}
.btn-secondary:hover{background:var(--border);color:var(--text);}
.btn-danger{background:#fee2e2;color:#991b1b;border:1.5px solid #fecaca;}
.btn-danger:hover{background:#fecaca;}
.btn-success{background:#d1fae5;color:#065f46;border:1.5px solid #a7f3d0;}
.btn-success:hover{background:#a7f3d0;}
.btn-warning{background:#fef3c7;color:#92400e;border:1.5px solid #fde68a;}
.btn-warning:hover{background:#fde68a;}
.btn-sm{padding:6px 12px;font-size:.8rem;}
.btn-lg{padding:13px 22px;font-size:1rem;}
.btn-icon{width:36px;height:36px;padding:0;justify-content:center;}

/* TABLA */
.table-wrap{overflow-x:auto;}
.data-table{width:100%;border-collapse:collapse;font-size:.875rem;}
.data-table th{padding:10px 14px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text2);border-bottom:2px solid var(--border);white-space:nowrap;background:var(--bg);}
.data-table td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle;}
.data-table tbody tr:hover{background:#f8fafc;}
.data-table tbody tr:last-child td{border-bottom:none;}

/* ALERTAS */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:16px;display:flex;align-items:center;gap:10px;border:1px solid transparent;}
.alert-success{background:#d1fae5;border-color:#a7f3d0;color:#065f46;}
.alert-danger{background:#fee2e2;border-color:#fecaca;color:#991b1b;}
.alert-warning{background:#fef3c7;border-color:#fde68a;color:#92400e;}
.alert-info{background:#e0f2fe;border-color:#bae6fd;color:#075985;}
.alert-close{margin-left:auto;background:none;border:none;cursor:pointer;opacity:.5;font-size:1rem;padding:0;}
.alert-close:hover{opacity:1;}

/* GASTO CARD */
.gasto-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;gap:12px;transition:box-shadow .15s;border-left:4px solid var(--border);}
.gasto-card:hover{box-shadow:var(--shadow);}
.gasto-card.estado-ok{border-left-color:#10b981;}
.gasto-card.estado-warn{border-left-color:#f59e0b;}
.gasto-card.estado-bad{border-left-color:#ef4444;}
.gasto-card.estado-info{border-left-color:#3b82f6;}
.cat-dot{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}

/* TECNICO CARD */
.tecnico-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;transition:transform .15s,box-shadow .15s;}
.tecnico-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);}

/* OBRA BADGE */
.obra-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;}

/* FAB */
.fab{position:fixed;bottom:24px;right:20px;width:56px;height:56px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 8px 24px rgba(37,99,235,.4);z-index:1000;text-decoration:none;transition:transform .2s,box-shadow .2s;}
.fab:hover{transform:scale(1.08);box-shadow:0 12px 32px rgba(37,99,235,.5);color:#fff;}

/* TOAST */
.toast-stack{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;}
.toast-item{background:#0f172a;color:#f1f5f9;padding:12px 18px;border-radius:12px;font-size:.875rem;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.2);pointer-events:all;animation:fadeIn .3s ease both;max-width:320px;}
.toast-item.ok{background:#065f46;}.toast-item.err{background:#991b1b;}.toast-item.warn{background:#854d0e;}

/* ANIMACIONES */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .3s ease both;}
@keyframes spin{to{transform:rotate(360deg)}}

/* JERARQUÍA VISUAL */
.hier-line{display:flex;align-items:center;gap:8px;padding:10px 0;}
.hier-arrow{color:var(--text3);font-size:.9rem;}

/* RESPONSIVE */
@media(max-width:575px){
  .saldo-box .monto{font-size:1.7rem;}
  .kpi .val{font-size:1.2rem;}
  .main-content .container-fluid{padding:12px!important;}
}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:6px;}
@supports(padding:env(safe-area-inset-bottom)){.mobile-topbar{padding-top:max(10px,env(safe-area-inset-top));}.main-content{padding-bottom:env(safe-area-inset-bottom);}}
