*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);color:var(--text);background:var(--paper);line-height:1.55;font-size:15px}
a{color:inherit;text-decoration:none}

/* ---------- Wordmark ---------- */
.wordmark{font-family:var(--font-serif);font-weight:600;font-size:2rem;letter-spacing:-.01em;line-height:1}
.wordmark--sm{font-size:1.35rem}
.wordmark__dot{color:var(--brass)}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;height:46px;padding:0 1.25rem;
  border-radius:var(--radius-sm);font-weight:500;font-size:.95rem;cursor:pointer;border:1px solid transparent;
  transition:background .15s,border-color .15s,transform .05s;width:100%}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--ink);color:#fff}
.btn--primary:hover{background:var(--ink-600)}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--text);width:auto}
.btn--ghost:hover{border-color:var(--ink-500)}

/* ---------- Formularios ---------- */
.form{display:flex;flex-direction:column;gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field__label{font-size:.82rem;font-weight:500;color:var(--muted)}
.field__input{height:46px;padding:0 .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--surface);font:inherit;color:var(--text);transition:border-color .15s,box-shadow .15s}
.field__input:focus{outline:none;border-color:var(--ink-500);box-shadow:0 0 0 3px rgba(40,52,85,.12)}

/* ---------- Alertas ---------- */
.alert{padding:.7rem .9rem;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:.25rem;border:1px solid transparent}
.alert--danger{background:var(--danger-bg);color:var(--danger);border-color:#f3cfca}

/* ---------- Login (split) ---------- */
.auth-body{min-height:100vh}
.auth-split{display:grid;grid-template-columns:minmax(340px,42%) 1fr;min-height:100vh}
.auth-brand{position:relative;background:var(--ink);color:#fff;padding:3rem 3rem 2rem;
  display:flex;flex-direction:column;justify-content:space-between;border-right:3px solid var(--brass)}
.auth-brand__inner{margin-top:auto;margin-bottom:auto;max-width:30ch}
.auth-brand .wordmark{color:#fff}
.auth-brand__tag{margin-top:1rem;color:#c5cad6;font-size:1.05rem;font-weight:400}
.auth-brand__foot{font-size:.8rem;color:#8b93a6;letter-spacing:.02em}
.auth-form{display:flex;align-items:center;justify-content:center;padding:2rem}
.auth-card{width:100%;max-width:380px}
.auth-card__title{font-family:var(--font-serif);font-weight:600;font-size:1.7rem;margin-bottom:.25rem}
.auth-card__sub{color:var(--muted);margin-bottom:1.5rem;font-size:.95rem}
.auth-card .btn{margin-top:.5rem}

/* ---------- Shell dashboard ---------- */
.app-body{background:var(--paper)}
.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{background:var(--ink);color:#cdd2de;display:flex;flex-direction:column;padding:1.25rem 0;position:sticky;top:0;height:100vh}
.sidebar__brand{padding:.25rem 1.5rem 1.5rem;color:#fff;border-bottom:1px solid rgba(255,255,255,.07)}
.sidebar__nav{display:flex;flex-direction:column;gap:.15rem;padding:1rem .75rem;flex:1}
.navitem{display:flex;align-items:center;gap:.7rem;padding:.65rem .8rem;border-radius:var(--radius-sm);
  color:#aeb5c5;font-size:.92rem;font-weight:500;transition:background .15s,color .15s}
.navitem:hover{background:rgba(255,255,255,.06);color:#fff}
.navitem.is-active{background:var(--ink-600);color:#fff}
.navitem svg{width:18px;height:18px;flex:none;opacity:.9}
.navitem--soon{cursor:default;opacity:.55}
.navitem--soon:hover{background:transparent;color:#aeb5c5}
.navitem em{margin-left:auto;font-style:normal;font-size:.66rem;letter-spacing:.04em;text-transform:uppercase;
  color:var(--brass-200);border:1px solid rgba(216,195,154,.3);border-radius:6px;padding:.1rem .35rem}
.sidebar__user{display:flex;align-items:center;gap:.65rem;margin:0 .75rem;padding:.85rem;border-radius:var(--radius-sm);
  background:rgba(255,255,255,.05)}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--brass);color:var(--ink);font-weight:600;
  display:flex;align-items:center;justify-content:center;font-size:1rem;flex:none}
.sidebar__user-info{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.sidebar__user-info strong{font-size:.88rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar__user-info span{font-size:.76rem;color:#8b93a6}
.sidebar__logout{margin-left:auto;color:#aeb5c5;display:flex;padding:.3rem;border-radius:6px;flex:none}
.sidebar__logout:hover{color:#fff;background:rgba(255,255,255,.08)}
.sidebar__logout svg{width:18px;height:18px}

.app-main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2rem;
  background:var(--surface);border-bottom:1px solid var(--line)}
.topbar__title{font-family:var(--font-serif);font-weight:600;font-size:1.3rem}
.topbar__meta{font-size:.85rem;color:var(--muted)}
.topbar__meta b{color:var(--text);font-weight:500}
.content{padding:2rem;max-width:1080px;width:100%}

/* ---------- Bienvenida + tarjetas ---------- */
.welcome{margin-bottom:1.5rem}
.welcome__h{font-family:var(--font-serif);font-weight:600;font-size:1.5rem;margin-bottom:.3rem}
.welcome__p{color:var(--muted);max-width:60ch}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.1rem}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow)}
.card--wide{grid-column:1/-1}
.card__h{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:1rem;font-weight:600}
.kv{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px solid var(--line-2)}
.kv:last-child{border-bottom:none}
.kv>span{color:var(--muted);font-size:.88rem}
.kv strong{font-weight:500;font-size:.92rem}
.badges{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:flex-end}
.badge{background:var(--ink);color:#fff;border-radius:999px;padding:.2rem .65rem;font-size:.76rem;font-weight:500}
.steps{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.steps li{position:relative;padding-left:1.4rem;color:var(--text);font-size:.92rem}
.steps li::before{content:"";position:absolute;left:0;top:.45rem;width:8px;height:8px;border-radius:50%;
  border:2px solid var(--brass)}

/* ---------- Tabla ---------- */
.table{width:100%;border-collapse:collapse;font-size:.88rem}
.table th{text-align:left;color:var(--muted);font-weight:500;font-size:.76rem;text-transform:uppercase;
  letter-spacing:.04em;padding:.5rem .6rem;border-bottom:1px solid var(--line)}
.table td{padding:.6rem;border-bottom:1px solid var(--line-2);color:var(--text)}
.table tr:last-child td{border-bottom:none}

/* ---------- Error ---------- */
.err{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;padding:2rem}
.err__code{font-family:var(--font-serif);font-size:4rem;font-weight:600;color:var(--ink)}
.err__msg{color:var(--muted)}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .auth-split{grid-template-columns:1fr}
  .auth-brand{min-height:200px;border-right:none;border-bottom:3px solid var(--brass);padding:2rem}
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;flex-direction:row;align-items:center;flex-wrap:wrap;padding:.75rem 1rem}
  .sidebar__brand{border:none;padding:.25rem .5rem}
  .sidebar__nav{flex-direction:row;flex:1 1 100%;order:3;padding:.5rem 0;overflow-x:auto}
  .sidebar__user{order:2;margin:0}
  .content{padding:1.25rem}
}

/* ================= Configuracion ================= */
.muted{color:var(--muted)}
code.muted{font-size:.85em}
.alert--ok{background:var(--ok-bg);color:var(--ok);border-color:#cbe6d6}

.cfg-head{margin-bottom:1rem}
.cfg-head__title{font-family:var(--font-serif);font-weight:600;font-size:1.35rem;margin-bottom:.2rem}
.cfg-head__sub{color:var(--muted);font-size:.92rem}

.cfg-tabs{display:flex;flex-wrap:wrap;gap:.35rem;border-bottom:1px solid var(--line);margin-bottom:1.1rem}
.cfg-tab{padding:.55rem .9rem;font-size:.9rem;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px}
.cfg-tab:hover{color:var(--text)}
.cfg-tab.is-active{color:var(--ink);border-bottom-color:var(--brass)}

.cfg-filtro{margin-bottom:1rem;max-width:320px}
.field--inline{flex-direction:column}

.cfg-grid{display:grid;grid-template-columns:1fr 330px;gap:1.2rem;align-items:start}
.cfg-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.cfg-card .table{width:100%}
.cfg-card .table th{padding:.7rem .9rem;background:var(--surface-2)}
.cfg-card .table td{padding:.65rem .9rem;vertical-align:middle}
.cfg-form-card{padding:1.3rem;position:sticky;top:1rem}
.cfg-form-card__h{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:1rem;font-weight:600}
.cfg-form-card__h #cfgTitulo{color:var(--brass)}

.field-row{display:flex;gap:.75rem}
.field-row .field{flex:1}
.field-row .btn{width:auto;flex:1}
select.field__input{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23646b7a' stroke-width='2'%3e%3cpath d='M6 9l6 6 6-6'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}
.field__color{padding:.2rem;height:46px;cursor:pointer}
.check{display:flex;align-items:center;gap:.55rem;font-size:.9rem;color:var(--text);cursor:pointer;padding:.2rem 0}
.check input{width:17px;height:17px;accent-color:var(--ink)}

.color-dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:.5rem;vertical-align:middle;box-shadow:0 0 0 1px rgba(0,0,0,.08)}
.flag{font-size:.74rem;font-weight:500;padding:.15rem .5rem;border-radius:999px}
.flag--on{background:var(--ok-bg);color:var(--ok)}
.flag--off{background:#f0eee8;color:var(--muted)}
.chip{display:inline-block;font-size:.72rem;background:var(--line-2);color:var(--text);border-radius:6px;padding:.12rem .45rem;margin:.05rem .1rem}

.acciones{display:flex;gap:.4rem;align-items:center;white-space:nowrap}
.acciones form{display:inline}
.btn-mini{height:30px;padding:0 .7rem;font-size:.8rem;font-weight:500;border:1px solid var(--line);background:var(--surface);border-radius:7px;cursor:pointer;color:var(--text)}
.btn-mini:hover{border-color:var(--ink-500)}
.btn-mini--danger{color:var(--danger);border-color:#eccac6}
.btn-mini--danger:hover{background:var(--danger-bg);border-color:var(--danger)}

@media (max-width:880px){
  .cfg-grid{grid-template-columns:1fr}
  .cfg-form-card{position:static}
}

/* ================= Clientes ================= */
.btn--auto{width:auto}
.btn--danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn--danger:hover{filter:brightness(.94)}
.link-strong{font-weight:600;color:var(--ink)}
.link-strong:hover{color:var(--brass)}
.badge--soft{background:var(--line-2);color:var(--muted);font-size:.72rem;padding:.1rem .45rem;border-radius:6px;margin-left:.4rem;font-weight:500}
.flag--warn{background:#fbf1dc;color:#8a6314}
.back-link{display:inline-block;color:var(--muted);font-size:.88rem;margin-bottom:1rem}
.back-link:hover{color:var(--ink)}

.toolbar{display:flex;gap:.8rem;align-items:center;margin-bottom:1.1rem}
.searchbar{flex:1;display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:0 .8rem;height:42px}
.searchbar svg{width:17px;height:17px;color:var(--muted);flex-shrink:0}
.searchbar input{flex:1;border:0;outline:0;background:transparent;font-size:.92rem;color:var(--text);font-family:inherit}
.searchbar__clear{color:var(--muted);font-size:1.2rem;line-height:1;padding:0 .2rem}

.pager{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;font-size:.88rem}
.pager__nav{display:flex;align-items:center;gap:.6rem}

.empty-state{text-align:center;color:var(--muted);padding:2.2rem 1rem}
.empty-state--box p{color:var(--text);font-weight:500;margin-bottom:.3rem}

/* Formulario */
.form--wide{max-width:720px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.form-grid--3{grid-template-columns:1fr 1fr 1fr}
.form-sec{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:1.4rem 0 .2rem;font-weight:600;border-top:1px solid var(--line);padding-top:1.1rem}
.form-actions{display:flex;gap:.6rem;margin-top:1.5rem}
textarea.field__input{resize:vertical;min-height:64px;font-family:inherit}

.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:3px;margin-bottom:1.2rem}
.seg__opt{position:relative}
.seg__opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.seg__opt span{display:block;padding:.45rem 1rem;font-size:.88rem;font-weight:500;color:var(--muted);border-radius:7px;cursor:pointer}
.seg__opt input:checked + span{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}

.cli-natural .solo-juridica{display:none}
.cli-juridica .solo-natural{display:none}

/* Detalle */
.detalle-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.4rem;flex-wrap:wrap}
.detalle-head__title{font-family:var(--font-serif);font-weight:600;font-size:1.5rem}
.detalle-head__meta{display:flex;align-items:center;gap:.5rem;margin-top:.4rem;flex-wrap:wrap}
.detalle-head__actions{display:flex;gap:.5rem;align-items:center}
.detalle-head__actions form{display:inline}
.detalle-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:1.1rem;align-items:start}
.detalle-card{padding:1.3rem}
.detalle-card__h{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:1rem;font-weight:600}
.ficha__row{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--line)}
.ficha__row:last-child{border-bottom:0}
.ficha__k{color:var(--muted);font-size:.85rem}
.ficha__v{text-align:right;font-weight:500}
.ficha__notas{padding-top:.7rem}
.ficha__notas .ficha__k{display:block;margin-bottom:.3rem}
.ficha__notas p{font-size:.9rem;color:var(--text)}

@media (max-width:880px){
  .form-grid,.form-grid--3{grid-template-columns:1fr}
  .detalle-grid{grid-template-columns:1fr}
}

/* ================= Modales ================= */
body.modal-open{overflow:hidden}
.modal-overlay{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;padding:1.2rem;background:rgba(20,27,45,.5);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);animation:ovl .15s ease}
.modal-overlay[hidden]{display:none}
@keyframes ovl{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.28);width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:pop .17s cubic-bezier(.2,.8,.3,1)}
.modal[hidden]{display:none}
@keyframes pop{from{transform:translateY(10px) scale(.985);opacity:0}to{transform:none;opacity:1}}
.modal--sm{max-width:430px}
.modal--md{max-width:560px}
.modal--wide{max-width:800px}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:1.05rem 1.4rem;border-bottom:1px solid var(--line)}
.modal__title{font-family:var(--font-serif);font-weight:600;font-size:1.2rem}
.modal__close{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:var(--surface);cursor:pointer;color:var(--muted);font-size:1.25rem;line-height:1;display:flex;align-items:center;justify-content:center}
.modal__close:hover{color:var(--ink);border-color:var(--ink-500)}
.modal__body{padding:1.4rem;overflow-y:auto}
.modal__foot{display:flex;justify-content:flex-end;gap:.6rem;padding:1rem 1.4rem;border-top:1px solid var(--line);background:var(--surface-2)}
.modal__error{background:var(--danger-bg);color:var(--danger);border:1px solid #eccac6;border-radius:9px;padding:.6rem .85rem;font-size:.88rem;margin-bottom:1.1rem}
.modal__error[hidden]{display:none}
.modal .seg{margin-bottom:1.1rem}
.modal .form-sec{margin-top:1.1rem;padding-top:.9rem}
.modal .ficha__row:first-child{padding-top:0}

/* ================= Casos ================= */
.filtro-estado{flex-shrink:0}
.filtro-estado .field__input{height:42px;min-width:170px}
.caso-titulo{display:block;font-weight:500;color:var(--ink)}
.caso-titulo:hover{color:var(--brass)}
.caso-cliente{display:block;font-size:.8rem;color:var(--muted);margin-top:.1rem}
.flag--info{background:#e2ecf7;color:#1f5b9e}
.flag--done{background:#e7e3f3;color:#5b4a9e}
.prio{font-size:.74rem;font-weight:500;padding:.15rem .55rem;border-radius:999px;display:inline-flex;align-items:center;gap:.32rem}
.prio::before{content:"";width:7px;height:7px;border-radius:50%}
.prio--baja{background:#eef0ee;color:#5a6b5a}
.prio--baja::before{background:#7da37d}
.prio--media{background:#fbf1dc;color:#8a6314}
.prio--media::before{background:#d8a32a}
.prio--alta{background:#f8e0dc;color:#a32118}
.prio--alta::before{background:#c0392b}
