:root{
  --paper:#F3F5EF;
  --paper-card:#FFFFFF;
  --ink:#171717;
  --ink-soft:#5E645D;
  --green:#83B620;
  --green-2:#96C62C;
  --green-dark:#1E9C43;
  --green-soft:#EEF5D9;
  --black:#111111;
  --rule:rgba(17,17,17,.10);
  --display:'Montserrat',system-ui,sans-serif;
  --body:'Montserrat',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);background:#E4E8DC;color:var(--ink);font-size:16px;-webkit-font-smoothing:antialiased}
:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.btn{font-family:var(--body);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:12px 20px;border-radius:12px;border:none;cursor:pointer;text-decoration:none;display:inline-block;transition:transform .15s ease,background .2s ease,color .2s ease,border-color .2s ease}
.btn:hover{transform:translateY(-1px)}
.btn-ox,.btn-green{background:var(--green);color:#fff;box-shadow:0 14px 26px -18px rgba(131,182,32,.9)}
.btn-ox:hover,.btn-green:hover{background:var(--green-2)}
.btn-gold{background:var(--black);color:#fff}
.btn-gold:hover{background:#000}
.btn-ghost{background:none;border:1px solid var(--rule);color:var(--ink)}
.btn-ghost:hover{border-color:var(--green);color:var(--green-dark)}
.pseal{border-radius:14px;display:grid;place-items:center;background:linear-gradient(180deg,var(--green-2),var(--green));color:#fff;font-family:var(--display);font-weight:800;box-shadow:inset 0 1px 0 rgba(255,255,255,.24),0 10px 20px -14px rgba(131,182,32,.8)}
.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(70% 60% at 50% 0,rgba(131,182,32,.42),transparent 55%),linear-gradient(180deg,#DDE6C8,#E4E8DC);padding:24px}
.login-card{background:var(--paper-card);border-radius:18px;padding:42px 38px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:14px;box-shadow:0 30px 60px -28px rgba(0,0,0,.22);text-align:center;border:1px solid rgba(255,255,255,.7)}
.login-card .pseal{width:64px;height:64px;font-size:1.3rem;margin:0 auto 6px}
.login-card h1{font-family:var(--display);font-weight:800;font-size:1.5rem;letter-spacing:-.03em}
.login-card .sub{font-size:.92rem;color:var(--ink-soft);margin-bottom:8px}
.login-card label{text-align:left;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);display:flex;flex-direction:column;gap:8px}
.login-card input{font-family:var(--body);font-size:1rem;padding:12px 13px;border:1px solid var(--rule);border-radius:12px;background:#fff}
.login-card .btn{margin-top:6px}
.login-card .back{font-size:.78rem;font-weight:700;letter-spacing:.03em;color:var(--ink-soft);text-decoration:none;margin-top:6px}
.alert.err{background:#F7E3DD;color:#8C3A2D;font-size:.86rem;padding:10px 12px;border-radius:10px}
.adminbar{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;background:var(--black);color:#fff;position:sticky;top:0;z-index:30}
.adminbar .brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-size:1.05rem;font-weight:800;letter-spacing:-.02em}
.pseal.sm{width:34px;height:34px;font-size:.8rem}
.bar-actions{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.ghostlink{background:none;border:none;color:rgba(255,255,255,.86);font-family:var(--body);font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;text-decoration:none}
.ghostlink:hover{color:var(--green-2)}
.tabs{display:flex;gap:4px;background:#1A1A1A;padding:0 24px;position:sticky;top:64px;z-index:25;overflow-x:auto;border-bottom:1px solid rgba(255,255,255,.06)}
.tab{background:none;border:none;color:rgba(255,255,255,.7);font-family:var(--body);font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:14px 16px;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap}
.tab:hover{color:#fff}
.tab.on{color:var(--green-2);border-bottom-color:var(--green-2)}
.admin-main{max-width:980px;margin:0 auto;padding:34px 24px 80px;position:relative}
.panel{display:none}.panel.on{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:14px;flex-wrap:wrap}
.panel-head h2{font-family:var(--display);font-weight:800;font-size:1.7rem;letter-spacing:-.03em}
.list{width:100%;border-collapse:collapse;background:var(--paper-card);border-radius:16px;overflow:hidden;box-shadow:0 18px 38px -30px rgba(0,0,0,.25)}
.list th{text-align:left;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);padding:14px 16px;border-bottom:1px solid var(--rule)}
.list td{padding:14px 16px;border-bottom:1px solid var(--rule);font-size:.94rem;vertical-align:middle}
.list tr:last-child td{border-bottom:none}
.t-title{font-family:var(--display);font-weight:700;font-size:1.02rem;letter-spacing:-.02em}
.t-photo{width:64px}
.t-photo img{width:44px;height:44px;object-fit:cover;border-radius:8px;border:1px solid var(--rule);background:#fff}
.t-photo span{color:var(--ink-soft)}
.badge{font-size:.64rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.badge.pub{background:var(--green-soft);color:var(--green-dark)}
.badge.draft{background:#ECEFE5;color:var(--ink-soft)}
.row-actions{text-align:right;white-space:nowrap}
.mini{background:none;border:1px solid var(--rule);border-radius:10px;font-family:var(--body);font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:7px 10px;cursor:pointer;margin-left:6px;color:var(--ink)}
.mini.edit:hover{border-color:var(--green);color:var(--green-dark)}
.mini.del:hover{border-color:#a33;color:#a33}
.empty{margin-top:18px;color:var(--ink-soft);font-style:italic}
.form{display:flex;flex-direction:column;gap:16px;max-width:680px}
.form label{display:flex;flex-direction:column;gap:8px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.form input,.form textarea{font-family:var(--body);font-size:1rem;color:var(--ink);padding:12px 13px;border:1px solid var(--rule);border-radius:12px;background:#fff;width:100%}
.form textarea{resize:vertical;line-height:1.6}
.form textarea.mono{font-family:var(--body);font-size:.95rem}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:560px){.form .two{grid-template-columns:1fr}}
.form .btn{align-self:flex-start;margin-top:4px}
.form-sub{font-family:var(--display);font-weight:800;font-size:1.2rem;margin-bottom:4px;letter-spacing:-.02em}
.check{flex-direction:row !important;align-items:center;gap:10px !important;text-transform:none;letter-spacing:0;font-size:.92rem;font-family:var(--body);color:var(--ink)}
.check input{width:auto}
.md-label .lbl{display:block}
.md-label em{font-style:normal;text-transform:none;letter-spacing:0;color:var(--ink-soft)}
.md-label code{font-family:var(--body);font-size:.86em;background:var(--green-soft);padding:2px 6px;border-radius:6px;text-transform:none;letter-spacing:0}
.current-photo{display:grid;grid-template-columns:96px 1fr;gap:14px;align-items:center;background:var(--paper-card);border:1px solid var(--rule);border-radius:14px;padding:12px;box-shadow:0 12px 24px -22px rgba(0,0,0,.2)}
.current-photo img{width:96px;height:96px;object-fit:cover;border-radius:10px;background:#fff;border:1px solid var(--rule)}
.current-photo .check{margin:0}
@media (max-width:560px){.current-photo{grid-template-columns:1fr}.current-photo img{width:100%;height:auto;aspect-ratio:1/1}}
.svc-list{display:flex;flex-direction:column;gap:12px}
.svc-row{display:grid;grid-template-columns:1fr 2fr auto;gap:12px;align-items:center;background:var(--paper-card);padding:12px;border-radius:14px;border:1px solid var(--rule)}
.svc-row input{font-family:var(--body);font-size:.95rem;padding:10px 11px;border:1px solid var(--rule);border-radius:10px;background:#fff}
.svc-row .drag{font-family:var(--display);font-weight:800;color:var(--green)}
.svc-row .rm{background:none;border:1px solid var(--rule);border-radius:10px;cursor:pointer;color:var(--ink-soft);width:34px;height:34px;font-size:1rem}
.svc-row .rm:hover{border-color:#a33;color:#a33}
@media (max-width:560px){.svc-row{grid-template-columns:1fr;}}
.modal{position:fixed;inset:0;background:rgba(17,17,17,.55);display:none;align-items:flex-start;justify-content:center;padding:30px 16px;z-index:60;overflow-y:auto}
.modal.show{display:flex}
.modal-card{background:var(--paper);border-radius:18px;width:100%;max-width:680px;box-shadow:0 30px 70px -30px rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.7)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--rule)}
.modal-head h3{font-family:var(--display);font-weight:800;font-size:1.3rem;letter-spacing:-.03em}
.x{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--ink-soft)}
.modal form{padding:22px}
.modal-foot{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}
.modal-foot .btn{align-self:auto;margin:0}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--black);color:#fff;font-family:var(--body);font-size:.82rem;font-weight:700;letter-spacing:.06em;padding:13px 22px;border-radius:12px;opacity:0;transition:.3s;z-index:80;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.bad{background:#8C3A2D}

/* Segunda ronda: cierre visual Verde */
.adminbar{background:radial-gradient(80% 70% at 92% 0,rgba(131,182,32,.30),transparent 45%),var(--black)}
.login-page{background:radial-gradient(70% 50% at 50% 0,rgba(131,182,32,.55),transparent 58%),linear-gradient(180deg,#EAF1DC,#E4E8DC)}
.list,.modal-card,.login-card{border-top:4px solid var(--green)}
.form input:focus,.form textarea:focus,.login-card input:focus{border-color:rgba(131,182,32,.65);box-shadow:0 0 0 4px rgba(131,182,32,.12);outline:none}
.t-photo img{box-shadow:0 8px 18px -14px rgba(17,17,17,.35)}
.modal-head{background:linear-gradient(90deg,rgba(131,182,32,.12),transparent)}
.ghostlink[href*="manual-identidad"]{color:var(--green-2)}
