:root{
  --c0:#080917;--c1:#0e0f27;--c2:#141536;--c3:#191b45;--c4:#1c1e4d;
  --c5:#454764;--c6:#606282;--c7:#8e8fa6;--c8:#bbbcca;--c9:#d2d2db;
  --bg:#f4f4f7;--card:#ffffff;--bgsv:#f8f8fa;
  --tp:#1c1e4d;--ts:#606282;--ti:#ffffff;
  --div:#d2d2db;--bso:#d2d2db;--bst:#8e8fa6;--bfoc:#454764;
  --n100:#e8e8ed;--n200:#d2d2db;
  --err:#a73e3e;--ok:#10815a;--ok-bg:#ccfce3;
  --btn:#1c1e4d;--btn-h:#141536;
  --font:'Inter',-apple-system,sans-serif;
  --mono:'DM Mono',monospace;
  --r2:8px;--r3:12px;--rf:9999px;
  --s2:0 2px 8px rgba(8,9,23,.08);--s4:0 4px 16px rgba(8,9,23,.12);--s5:0 8px 24px rgba(8,9,23,.18);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font);background:var(--bg);color:var(--tp);font-size:14px;min-height:100vh}

/* ── HEADER ── */
.hdr{
  background:linear-gradient(135deg,var(--c3) 0%,var(--c4) 55%,var(--c5) 100%);
  padding:12px 32px;display:flex;align-items:center;justify-content:space-between;
  box-shadow:var(--s5);position:sticky;top:0;z-index:100
}
.hdr-l{display:flex;align-items:center;gap:14px}
.hdr-badge{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:6px;padding:4px 10px;font-size:10px;font-weight:700;
  color:rgba(255,255,255,.85);letter-spacing:.08em;text-transform:uppercase
}
.hdr-title{font-size:14px;font-weight:700;color:#fff;letter-spacing:-.01em}
.hdr-sub{font-size:11px;color:rgba(255,255,255,.6);margin-top:1px}
.hdr-r{display:flex;align-items:center;gap:10px}
.user-chip{
  display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);border-radius:var(--rf);padding:5px 12px 5px 6px
}
.user-avatar{
  width:26px;height:26px;border-radius:50%;background:var(--c7);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;color:#fff;flex-shrink:0
}
.user-info{display:flex;flex-direction:column;gap:1px}
.user-name{font-size:12px;font-weight:600;color:#fff}
.user-prog{font-size:10px;color:rgba(255,255,255,.6)}
.logout-link{
  font-size:11px;color:rgba(255,255,255,.7);text-decoration:none;
  border:1px solid rgba(255,255,255,.2);border-radius:var(--r2);
  padding:4px 10px;transition:all .15s
}
.logout-link:hover{background:rgba(255,255,255,.1);color:#fff}

main{max-width:860px;margin:0 auto;padding:28px 20px 60px}

.page-hd{margin-bottom:24px}
.page-hd h1{font-size:20px;font-weight:700;color:var(--c4);letter-spacing:-.02em}
.page-hd p{font-size:13px;color:var(--ts);margin-top:4px;line-height:1.5}

/* ── IDENTITY CARD ── */
.id-card{
  background:var(--card);border:1px solid var(--div);border-radius:var(--r3);
  box-shadow:var(--s2);padding:18px 22px;margin-bottom:20px;
  display:grid;grid-template-columns:1fr 1fr;gap:16px
}
.id-field label{font-size:10px;font-weight:700;color:var(--c7);text-transform:uppercase;letter-spacing:.07em;display:block;margin-bottom:5px}
.id-value{
  font-size:13px;font-weight:500;color:var(--tp);
  background:var(--bg);border:1.5px solid var(--n200);border-radius:var(--r2);
  padding:8px 12px;display:flex;align-items:center;gap:8px
}
.id-value .dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.id-lock{font-size:11px;color:var(--c8);margin-left:auto;font-family:var(--mono)}

.sec-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sec-label h2{font-size:11px;font-weight:700;color:var(--c6);text-transform:uppercase;letter-spacing:.08em}
.sec-label span{font-size:11px;color:var(--c8)}

/* ── ENTRY CARD ── */
.entries{display:flex;flex-direction:column;gap:12px}
.entry-card{
  background:var(--card);border:1.5px solid var(--div);border-radius:var(--r3);
  box-shadow:var(--s2);overflow:hidden;transition:box-shadow .2s
}
.entry-card:hover{box-shadow:var(--s4)}
.entry-card.entry-new{border-color:var(--bfoc);box-shadow:0 0 0 3px rgba(69,71,100,.08),var(--s2)}

.entry-hd{
  background:var(--bgsv);border-bottom:1px solid var(--div);
  padding:9px 16px;display:flex;align-items:center;gap:8px
}
.entry-num{
  width:20px;height:20px;border-radius:50%;background:var(--c4);color:#fff;
  font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0
}
.entry-num.new-num{background:var(--bfoc)}
.entry-hd-title{font-size:11px;font-weight:600;color:var(--ts);flex:1}
.entry-remove{
  background:none;border:none;cursor:pointer;color:var(--c8);font-size:16px;
  line-height:1;padding:2px 4px;border-radius:4px;transition:all .15s
}
.entry-remove:hover{background:var(--n100);color:var(--err)}

.entry-body{padding:16px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.entry-body .span2{grid-column:1/-1}

.field{display:flex;flex-direction:column;gap:5px}
.field.hidden{display:none}
.field label{font-size:10px;font-weight:700;color:var(--c6);text-transform:uppercase;letter-spacing:.06em}
.field label .req{color:var(--err);margin-left:2px}
.field input,.field select{
  font-family:var(--font);font-size:13px;font-weight:500;
  padding:8px 12px;border:1.5px solid var(--bso);border-radius:var(--r2);
  background:#fff;color:var(--tp);outline:none;transition:border-color .15s;width:100%
}
.field input::placeholder{color:var(--c8)}
.field input:focus,.field select:focus{border-color:var(--bfoc);box-shadow:0 0 0 3px rgba(69,71,100,.1)}
.field input.invalid,.field select.invalid{border-color:var(--err);box-shadow:0 0 0 3px rgba(167,62,62,.1)}
.field select{appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M5 7L0 2h10z' fill='%23606282'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;padding-right:28px
}

.amount-wrap{position:relative}
.amount-wrap .prefix{
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
  font-size:13px;font-weight:600;color:var(--ts)
}
.amount-wrap input{padding-left:26px}

.other-toggle{display:none;margin-top:6px}
.other-toggle.show{display:flex}

.add-row{
  display:flex;align-items:center;gap:10px;
  background:var(--card);border:1.5px dashed var(--div);border-radius:var(--r3);
  padding:14px 20px;cursor:pointer;transition:all .2s;
  color:var(--ts);font-family:var(--font);font-size:13px;font-weight:600;width:100%
}
.add-row:hover{border-color:var(--bfoc);background:#f0f0f8;color:var(--c4)}
.add-icon{
  width:30px;height:30px;border-radius:50%;background:var(--c4);color:#fff;
  font-size:18px;font-weight:300;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .2s
}
.add-row:hover .add-icon{background:var(--bfoc)}

.submit-bar{
  margin-top:24px;display:flex;align-items:center;justify-content:space-between;
  background:var(--card);border:1px solid var(--div);border-radius:var(--r3);
  padding:14px 20px;box-shadow:var(--s2)
}
.submit-info{font-size:12px;color:var(--ts)}
.submit-info strong{color:var(--tp);font-weight:700}
.submit-actions{display:flex;gap:10px;align-items:center}
.btn-cancel{
  font-family:var(--font);font-size:13px;font-weight:500;background:none;
  border:1.5px solid var(--div);border-radius:var(--r2);padding:8px 18px;
  cursor:pointer;color:var(--ts);transition:all .15s
}
.btn-cancel:hover{background:var(--bg);border-color:var(--bst);color:var(--tp)}
.btn-submit{
  font-family:var(--font);font-size:13px;font-weight:700;
  background:var(--btn);border:none;border-radius:var(--r2);
  padding:9px 24px;cursor:pointer;color:#fff;transition:background .15s;
  display:flex;align-items:center;gap:8px
}
.btn-submit:hover{background:var(--btn-h)}
.btn-submit:disabled{opacity:.6;cursor:not-allowed}
.btn-submit svg{width:14px;height:14px}

.val-msg{
  display:flex;align-items:center;gap:8px;padding:10px 14px;
  border-radius:var(--r2);font-size:12px;font-weight:500;margin-top:10px;
  background:var(--ok-bg);color:var(--ok);display:none
}
.val-msg.show{display:flex}
.val-msg.err{background:#fce8e8;color:var(--err)}
.val-msg svg{flex-shrink:0}

.info-banner{
  background:rgba(28,30,77,.05);border:1px solid rgba(28,30,77,.12);
  border-radius:var(--r2);padding:10px 14px;margin-bottom:20px;
  display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--c5);line-height:1.5
}
.info-banner svg{flex-shrink:0;margin-top:1px}

.counter{
  background:var(--c4);color:#fff;font-size:10px;font-weight:700;
  padding:2px 8px;border-radius:var(--rf);margin-left:6px
}

@media(max-width:600px){
  .entry-body{grid-template-columns:1fr}
  .id-card{grid-template-columns:1fr}
  .submit-bar{flex-direction:column;gap:12px;align-items:flex-start}
}

/* ── LOGIN SCREEN ── */
.login-screen{
  min-height:100vh;background:linear-gradient(145deg,var(--c2) 0%,var(--c4) 50%,var(--c5) 100%);
  display:flex;align-items:center;justify-content:center;padding:20px
}
.login-box{
  background:#fff;border-radius:16px;box-shadow:0 24px 64px rgba(8,9,23,.35);
  padding:40px 40px 36px;width:100%;max-width:420px
}
.login-logo-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:28px}
.login-goes-badge{
  background:var(--c4);color:#fff;font-size:11px;font-weight:800;
  letter-spacing:.1em;padding:6px 14px;border-radius:8px;text-transform:uppercase
}
.login-divider{width:1px;height:24px;background:var(--n200)}
.login-tagline{font-size:11px;color:var(--ts);font-weight:500}
.login-title{font-size:22px;font-weight:800;color:var(--c4);letter-spacing:-.03em;text-align:center;margin-bottom:6px}
.login-sub{font-size:13px;color:var(--ts);text-align:center;line-height:1.5;margin-bottom:28px}
.login-error{
  background:#fce8e8;border:1px solid #f0c4c4;color:var(--err);
  border-radius:var(--r2);padding:10px 14px;margin-bottom:18px;
  font-size:12px;font-weight:500;display:flex;align-items:center;gap:8px
}
.login-error svg{flex-shrink:0}
.google-btn{
  width:100%;font-family:var(--font);font-size:14px;font-weight:600;
  background:#fff;color:#3c4043;border:1.5px solid #dadce0;border-radius:var(--r2);
  padding:12px;cursor:pointer;transition:box-shadow .15s, background .15s;
  text-decoration:none;display:flex;align-items:center;justify-content:center;gap:12px;
  margin-bottom:16px
}
.google-btn:hover{box-shadow:0 1px 3px rgba(60,64,67,.3);background:#f8f9fa}
.google-btn svg{width:18px;height:18px;flex-shrink:0}
.login-footer{text-align:center;font-size:11px;color:var(--c8);line-height:1.6}
.login-footer strong{color:var(--ts)}

/* ── MODAL DE CONFIRMACIÓN ── */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(8,9,23,.55);
  display:none;align-items:center;justify-content:center;
  z-index:500;padding:20px;animation:fadeIn .15s ease-out
}
.modal-backdrop.show{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-box{
  background:#fff;border-radius:14px;box-shadow:0 24px 64px rgba(8,9,23,.45);
  width:100%;max-width:520px;max-height:80vh;display:flex;flex-direction:column;
  animation:popIn .18s ease-out
}
@keyframes popIn{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}
.modal-hd{
  padding:20px 24px 14px;border-bottom:1px solid var(--div);
  display:flex;align-items:center;gap:12px
}
.modal-icon{
  width:36px;height:36px;border-radius:50%;background:#fff7e6;
  border:1.5px solid #f0c75a;
  display:flex;align-items:center;justify-content:center;flex-shrink:0
}
.modal-title{font-size:15px;font-weight:700;color:var(--tp);letter-spacing:-.01em}
.modal-sub{font-size:12px;color:var(--ts);margin-top:2px;line-height:1.4}
.modal-body{padding:14px 24px 8px;overflow-y:auto;flex:1}
.modal-body p{font-size:13px;color:var(--c5);line-height:1.5;margin-bottom:10px}
.conflict-list{
  display:flex;flex-direction:column;gap:8px;margin-top:8px
}
.conflict-row{
  background:var(--bgsv);border:1px solid var(--div);border-radius:var(--r2);
  padding:10px 12px;font-size:12px
}
.conflict-row .ckey{font-weight:700;color:var(--tp);margin-bottom:3px}
.conflict-row .cmeta{color:var(--ts);font-family:var(--mono);font-size:11px}
.conflict-row .cmeta strong{color:var(--c4)}
.modal-actions{
  padding:14px 24px 20px;display:flex;gap:10px;justify-content:flex-end;
  border-top:1px solid var(--div)
}
.modal-actions .btn-cancel{padding:9px 20px}
.modal-actions .btn-confirm{
  font-family:var(--font);font-size:13px;font-weight:700;
  background:#a73e3e;border:none;border-radius:var(--r2);
  padding:9px 20px;cursor:pointer;color:#fff;transition:background .15s
}
.modal-actions .btn-confirm:hover{background:#8a3232}
