:root{
  --bg:#0a0e16; --bg2:#0d1320; --card:#121a2a; --card2:#172134; --card3:#1d2942;
  --line:#22304a; --line2:#2c3c5a;
  --txt:#eaf1fb; --mut:#90a4c4; --mut2:#64799a;
  --acc:#3b82f6; --acc2:#60a5fa; --acc3:#93c5fd;
  --ok:#26d07c; --okbg:#0c2a1c; --warn:#f5a623; --warnbg:#2a1e08;
  --danger:#ef4444; --gold:#e0b64a; --violet:#8b5cf6;
  --shadow:0 14px 50px rgba(0,0,0,.5); --shadow-s:0 6px 20px rgba(0,0,0,.35);
  --r:18px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;background:var(--bg);color:var(--txt);
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Inter,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{min-height:100vh;position:relative;overflow-x:hidden}
.bg-grid{position:fixed;inset:0;z-index:-1;
  background:
   radial-gradient(900px 500px at 80% -10%, rgba(59,130,246,.16), transparent 60%),
   radial-gradient(700px 500px at 0% 0%, rgba(139,92,246,.12), transparent 55%),
   linear-gradient(180deg,#0a0e16,#0a0f1a 50%,#090d15);
}
a{color:var(--acc2);text-decoration:none}
button{font:inherit;cursor:pointer;color:inherit}
::-webkit-scrollbar{height:8px;width:8px}
::-webkit-scrollbar-thumb{background:#26344e;background:#26344e;border-radius:8px}

/* ---------- topbar ---------- */
.topbar{position:sticky;top:0;z-index:30;display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:13px 18px;padding-top:max(13px,env(safe-area-inset-top));
  background:rgba(10,14,22,.78);backdrop-filter:saturate(140%) blur(16px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.logo{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff;flex-shrink:0;
  background:linear-gradient(135deg,#2563eb,#60a5fa);box-shadow:0 8px 22px rgba(59,130,246,.45)}
.brand-txt{min-width:0}
.brand-txt h1{font-size:15.5px;margin:0;font-weight:750;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-txt span{font-size:11px;color:var(--mut);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.iconbtn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--card);display:grid;place-items:center;color:var(--mut);transition:.2s}
.iconbtn:hover{color:var(--txt);border-color:var(--acc)}
.iconbtn.spin svg{animation:spin .7s linear}
@keyframes spin{to{transform:rotate(360deg)}}
.ghost{background:linear-gradient(135deg,#2563eb,#3b82f6);border:0;color:#fff;padding:9px 14px;border-radius:10px;font-size:12.5px;font-weight:650;box-shadow:0 6px 18px rgba(59,130,246,.4)}

/* ---------- tabs ---------- */
.tabs{display:flex;gap:6px;padding:14px 18px 4px;max-width:1180px;margin:0 auto;width:100%}
.tab{flex:0 0 auto;padding:9px 16px;border-radius:11px;border:1px solid transparent;background:transparent;color:var(--mut);font-weight:650;font-size:13.5px;transition:.18s}
.tab:hover{color:var(--txt)}
.tab.active{background:var(--card);border-color:var(--line2);color:var(--txt);box-shadow:var(--shadow-s)}

main{max-width:1180px;margin:0 auto;padding:14px 18px 70px;width:100%}

/* ---------- cards ---------- */
.card{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-s)}
.fade{animation:fade .4s ease both}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- RESUMEN ---------- */
.summary-top{display:grid;grid-template-columns:300px 1fr;gap:16px;margin-bottom:16px}
.ringcard{padding:22px;display:flex;flex-direction:column;align-items:center;gap:6px;background:
  radial-gradient(120% 80% at 50% 0%, rgba(59,130,246,.14), transparent 60%), linear-gradient(180deg,var(--card),var(--card2))}
.ring-wrap{position:relative;width:200px;height:200px}
.ring-wrap svg{transform:rotate(-90deg)}
.ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}
.ring-pct{font-size:40px;font-weight:820;letter-spacing:-1px;line-height:1}
.ring-lbl{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.7px;font-weight:650}
.ring-sub{font-size:12.5px;color:var(--mut);text-align:center}

.kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-content:start}
.kpi{padding:16px 18px;display:flex;flex-direction:column;gap:5px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--acc)}
.kpi.k-pend::before{background:var(--acc)} .kpi.k-cert::before{background:var(--ok)}
.kpi.k-rest::before{background:var(--warn)} .kpi.k-next::before{background:var(--violet)}
.kpi-label{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.6px;font-weight:650}
.kpi-val{font-size:25px;font-weight:800;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.kpi.k-cert .kpi-val{color:var(--ok)} .kpi.k-rest .kpi-val{color:var(--warn)} .kpi.k-next .kpi-val{color:var(--acc3)}
.kpi-sub{font-size:11px;color:var(--mut)}

/* chart */
.chartcard{padding:20px 18px 14px;margin-bottom:16px}
.chart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;flex-wrap:wrap;gap:8px}
.chart-head h3{margin:0;font-size:15px;font-weight:700}
.legend{display:flex;gap:14px;font-size:11.5px;color:var(--mut)}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.chart{width:100%;height:230px;display:block;overflow:visible}
.chart .barbg{fill:rgba(255,255,255,.04)}
.chart text{fill:var(--mut);font-size:10px;font-family:inherit}
.chart .vlabel{fill:var(--txt);font-weight:700;font-size:10.5px}

.phasecard{padding:6px 4px}
.phaserow{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--line)}
.phaserow:last-child{border-bottom:0}
.phaserow .pm{width:74px;font-weight:700;font-size:13px}
.phaserow.pend .pm{color:var(--acc3)} .phaserow.paid{opacity:.6}
.pbar{flex:1;height:9px;border-radius:6px;background:rgba(255,255,255,.05);overflow:hidden;position:relative}
.pbar>i{position:absolute;left:0;top:0;bottom:0;border-radius:6px;background:linear-gradient(90deg,#1d4ed8,#60a5fa)}
.phaserow.pend .pbar>i{background:linear-gradient(90deg,#26d07c,#1c9e5e)}
.phaserow .pv{width:96px;text-align:right;font-weight:750;font-variant-numeric:tabular-nums;font-size:13.5px}
.phaserow .pc{width:42px;text-align:right;font-size:11px;color:var(--mut)}

.section-title{font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.8px;font-weight:700;margin:18px 4px 10px}

/* ---------- month nav ---------- */
.months{display:flex;gap:9px;overflow-x:auto;padding:2px 2px 14px;scrollbar-width:none}
.months::-webkit-scrollbar{display:none}
.mbtn{flex:0 0 auto;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:11px 14px;color:var(--mut);font-weight:700;font-size:13px;display:flex;flex-direction:column;gap:3px;align-items:flex-start;min-width:104px;transition:.18s}
.mbtn small{font-size:9.5px;font-weight:700;letter-spacing:.5px;opacity:.85;text-transform:uppercase}
.mbtn .amt{font-size:12.5px;font-weight:750}
.mbtn.pending{border-color:#274063}
.mbtn.pending .amt{color:var(--ok)}
.mbtn.paid{opacity:.5}
.mbtn.active{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border-color:transparent;box-shadow:0 10px 26px rgba(59,130,246,.45)}
.mbtn.active .amt,.mbtn.active small{color:#fff;opacity:1}

/* ---------- month detail ---------- */
.mhead{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin:8px 2px 16px;flex-wrap:wrap}
.mhead h2{margin:0 0 6px;font-size:23px;font-weight:820;letter-spacing:-.4px}
.tag{font-size:10.5px;font-weight:750;padding:4px 11px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.tag.pending{background:#0f2942;color:var(--acc3);border:1px solid #1e3a5f}
.tag.paid{background:#192234;color:var(--mut);border:1px solid var(--line)}
.mtotals{display:flex;gap:20px;flex-wrap:wrap}
.mtotal{text-align:right}
.mtotal b{display:block;font-size:19px;font-variant-numeric:tabular-nums;font-weight:800}
.mtotal span{font-size:10.5px;color:var(--mut)}

.tasklist{display:grid;gap:12px}
.task{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:15px;overflow:hidden;transition:border-color .2s, transform .2s}
.task:hover{border-color:var(--line2)}
.task.hecho{border-color:#1c6b43}
.task.parcial{border-color:#7c5a16}
.task.deferred{border-color:#5b4596;background:linear-gradient(180deg,#18142a,#141026)}
.chip.carry{color:#c4b5fd;border-color:#3f2f6b}
.deferrow{padding:0 16px 14px}
.btn.defer{width:100%;justify-content:center;border-color:#3f2f6b;color:#c4b5fd;background:#16112a}
.btn.defer:hover{border-color:var(--violet);background:#1c1636}
.deferbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 16px 14px;padding:11px 14px;border:1px solid #3f2f6b;background:#16112a;border-radius:11px;font-size:13px;color:#cdbcf7}
.deferbar b{color:#fff;font-weight:750}
.task-main{display:flex;align-items:center;gap:13px;padding:14px 16px}
.code{font-size:11px;font-weight:820;color:var(--acc3);background:#0e1a2c;border:1px solid #233a59;border:1px solid #233a59;border-radius:9px;padding:6px 7px;min-width:44px;text-align:center;letter-spacing:.3px}
.task.extra .code{color:var(--gold);border-color:#574613;background:#211b08}
.tinfo{flex:1;min-width:0}
.tname{font-weight:700;font-size:14.5px;line-height:1.28}
.tmeta{font-size:11px;color:var(--mut);margin-top:5px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.chip{font-size:10.5px;padding:3px 8px;border-radius:14px;background:#0e1a2c;border:1px solid var(--line);color:var(--mut)}
.chip.cam{color:var(--acc3);border-color:#233a59}
.chip.gold{color:var(--gold);border-color:#574613}
.tright{text-align:right;flex-shrink:0}
.tplan{font-size:11.5px;color:var(--mut2);text-decoration:line-through;font-variant-numeric:tabular-nums}
.tpay{font-size:18px;font-weight:820;font-variant-numeric:tabular-nums;letter-spacing:-.3px}
.tpay.ok{color:var(--ok)} .tpay.warn{color:var(--warn)} .tpay.zero{color:var(--mut2)}

.statusrow{display:flex;gap:9px;padding:0 16px 14px;flex-wrap:wrap;align-items:center}
.seg{display:flex;background:#0d1726;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.seg button{background:transparent;border:0;color:var(--mut);padding:9px 13px;font-size:12.5px;font-weight:650;transition:.15s}
.seg button[data-v=hecho].on{background:linear-gradient(135deg,#179e5b,#26d07c);color:#06210f}
.seg button[data-v=parcial].on{background:linear-gradient(135deg,#c8851a,#f5a623);color:#241500}
.seg button[data-v=pendiente].on{background:#26344e;color:var(--txt)}
.pct{display:flex;align-items:center;gap:9px;flex:1;min-width:170px}
.pct input[type=range]{flex:1;accent-color:var(--warn);height:5px}
.pct b{font-size:13px;min-width:44px;text-align:right;font-variant-numeric:tabular-nums;color:var(--warn)}
.tbtns{display:flex;gap:8px;margin-left:auto}
.btn{border:1px solid var(--line);background:#0e1a2c;color:var(--txt);padding:9px 13px;border-radius:11px;font-size:12.5px;font-weight:650;display:inline-flex;gap:7px;align-items:center;transition:.15s}
.btn.cam{border-color:#233a59;color:var(--acc3)}
.btn:hover{border-color:var(--acc);transform:translateY(-1px)}
.btn.sm{padding:7px 11px;font-size:11.5px}
.primary{background:linear-gradient(135deg,#2563eb,#3b82f6);border-color:transparent;color:#fff;box-shadow:0 6px 18px rgba(59,130,246,.35)}

.thumbs{display:flex;gap:8px;padding:0 16px 14px;overflow-x:auto;scrollbar-width:none}
.thumbs::-webkit-scrollbar{display:none}
.thumb{flex:0 0 auto;width:76px;height:76px;border-radius:11px;object-fit:cover;border:1px solid var(--line);cursor:pointer;transition:.15s}
.thumb:hover{border-color:var(--acc)}

.empty{color:var(--mut);text-align:center;padding:40px 20px;border:1px dashed var(--line);border-radius:14px}

.foot{max-width:1180px;margin:0 auto;padding:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:var(--mut2);font-size:11.5px;width:100%}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:60;background:rgba(4,8,14,.84);backdrop-filter:blur(7px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fade .2s}
.modal[hidden]{display:none}
.toast[hidden]{display:none}
.modal-card{background:linear-gradient(180deg,var(--card2),var(--card));border:1px solid var(--line2);border-radius:20px;max-width:700px;width:100%;max-height:90vh;overflow:auto;padding:24px;position:relative;box-shadow:var(--shadow)}
.modal .x{position:absolute;top:14px;right:14px;background:#0e1a2c;border:1px solid var(--line);color:var(--txt);width:34px;height:34px;border-radius:10px;font-size:14px}
.modal h3{margin:2px 0 16px;font-size:18px;padding-right:40px}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;color:var(--mut);margin-bottom:7px;font-weight:650}
.field input,.field textarea{width:100%;background:#0d1726;border:1px solid var(--line);border-radius:11px;color:var(--txt);padding:12px 13px;font-size:16px}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--acc)}
.field textarea{min-height:74px;resize:vertical}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-top:10px}
.gcell{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#0d1726}
.gcell img{width:100%;height:120px;object-fit:cover;display:block;cursor:pointer}
.gcell .gdel{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.65);border:0;color:#fff;width:27px;height:27px;border-radius:8px;font-size:12px}
.gcell .gcap{font-size:10.5px;color:var(--mut);padding:6px 8px}
.row{display:flex;gap:10px;flex-wrap:wrap}
.row .btn{flex:1;justify-content:center}
.hint{font-size:11.5px;color:var(--mut);margin-top:6px}
.lightbox{position:fixed;inset:0;z-index:80;background:rgba(0,0,0,.93);display:flex;align-items:center;justify-content:center;padding:18px;animation:fade .2s}
.lightbox img{max-width:100%;max-height:92vh;border-radius:12px;box-shadow:var(--shadow)}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:linear-gradient(135deg,#16233a,#0e1a2c);border:1px solid var(--acc);color:var(--txt);padding:12px 20px;border-radius:13px;z-index:90;font-size:13.5px;box-shadow:var(--shadow);animation:fade .25s}

@media(max-width:780px){
  .summary-top{grid-template-columns:1fr;gap:12px}
  .ringcard{padding:18px}
  .kpis{grid-template-columns:1fr 1fr}
  .mhead h2{font-size:21px}
  .tbtns{margin-left:0;width:100%}
  .tbtns .btn{flex:1;justify-content:center}
  .brand-txt span{font-size:10px}
}
@media(max-width:430px){ .kpis{grid-template-columns:1fr} }

/* ---------- semáforo ---------- */
.semaforo{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 18px;margin-bottom:16px;flex-wrap:wrap}
.sem-left{display:flex;align-items:center;gap:14px}
.sem-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}
.sem-txt{font-size:16px;font-weight:800;letter-spacing:-.2px}
.sem-sub{font-size:12.5px;color:var(--mut);margin-top:2px}
.sem-right{text-align:right}
.sem-fin{display:block;font-size:13.5px;font-weight:700}
.sem-plan{display:block;font-size:11.5px;color:var(--mut)}

/* ---------- acciones de mes ---------- */
.monthacts{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0 2px 16px;flex-wrap:wrap}
.mabtns{display:flex;gap:9px;flex-wrap:wrap}
.closedbar{font-size:12.5px;color:#cdbcf7;background:#16112a;border:1px solid #3f2f6b;border-radius:11px;padding:9px 13px}
.tag.closed{background:#1c1636;color:#cdbcf7;border:1px solid #3f2f6b}
.task.locked{opacity:.92;border-color:#33405c}
.lockedrow{display:flex;align-items:center;gap:12px;padding:0 16px 14px;flex-wrap:wrap}
.lockchip{font-size:12px;font-weight:700;color:var(--mut);background:#0d1726;border:1px solid var(--line);border-radius:9px;padding:6px 11px}
.lockpay{font-size:13px;color:var(--mut)} .lockpay b{color:var(--ok)}
.lockedrow .btn{margin-left:auto}

/* ---------- firma ---------- */
.sigpad{width:100%;height:160px;background:#0d1726;border:1px dashed var(--line2);border-radius:12px;touch-action:none;display:block}

/* ---------- acta imprimible ---------- */
.actaOverlay{position:fixed;inset:0;z-index:100;background:rgba(4,8,14,.9);overflow:auto;padding:18px}
.acta-toolbar{display:flex;justify-content:flex-end;gap:10px;max-width:820px;margin:0 auto 14px}
.acta{max-width:820px;margin:0 auto;background:#fff;color:#15202b;border-radius:10px;padding:34px 38px;box-shadow:var(--shadow)}
.acta-head{display:flex;align-items:center;gap:16px;border-bottom:2px solid #15202b;padding-bottom:16px;margin-bottom:18px}
.acta-logo{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,#2563eb,#60a5fa);color:#fff;display:grid;place-items:center;font-weight:800;font-size:18px}
.acta-title h1{margin:0 0 4px;font-size:21px;color:#0f1722}
.acta-title div{font-size:12.5px;color:#5a6675}
.acta-table{width:100%;border-collapse:collapse;font-size:12.5px;margin-bottom:14px}
.acta-table th,.acta-table td{padding:7px 9px;border-bottom:1px solid #e2e6ec;text-align:left}
.acta-table th{background:#f2f5f9;color:#3a4654;font-weight:700;text-transform:uppercase;font-size:10.5px;letter-spacing:.4px}
.acta-table td.r,.acta-table th.r{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.acta-table tfoot td{border-top:2px solid #15202b;font-weight:800;background:#f7f9fb}
.acta-total{background:#eef4ff;border:1px solid #c9dbf7;border-radius:9px;padding:12px 14px;font-size:14px;color:#1a3a6b;margin-bottom:18px}
.acta-total b{font-size:18px}
.acta-h{font-size:14px;color:#0f1722;margin:18px 0 10px;border-bottom:1px solid #e2e6ec;padding-bottom:6px}
.acta-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.acta-photos .ap{margin:0;border:1px solid #e2e6ec;border-radius:8px;overflow:hidden}
.acta-photos .ap img{width:100%;height:120px;object-fit:cover;display:block}
.acta-photos figcaption{font-size:9.5px;color:#5a6675;padding:5px 7px;line-height:1.3}
.acta-firma{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:34px}
.acta-sigbox{border-top:1px solid #15202b;padding-top:8px;min-height:70px;display:flex;flex-direction:column;justify-content:flex-end;position:relative}
.acta-sig{position:absolute;bottom:24px;left:10px;max-height:64px;max-width:80%}
.acta-cap{font-size:11px;color:#5a6675}
.acta-foot{margin-top:26px;font-size:10px;color:#8a94a3;border-top:1px solid #e2e6ec;padding-top:10px}

@media print{
  body{background:#fff!important}
  body>*{display:none!important}
  body>.actaOverlay{display:block!important;position:static;background:#fff;padding:0}
  .actaOverlay .no-print{display:none!important}
  .acta{box-shadow:none;max-width:none;border-radius:0;padding:0}
  .acta-photos{grid-template-columns:repeat(3,1fr)}
  .acta-photos .ap{break-inside:avoid}
}
