:root{
  --primary:#F4DDDB;
  --primary-2:#EED2D0;
  --secondary:#B14561;
  --bg:#FFF9F8;
  --card:#FFFFFF;
  --text:#241D20;
  --muted:#7A646A;
  --border:#EBD8D7;
  --danger:#D9534F;
  --success:#5B7F49;
  --warning:#D98C23;
  --radius:14px;
  --shadow:0 8px 20px rgba(59,36,31,.08);
  --shadow-sm:0 4px 12px rgba(59,36,31,.06);
  --font: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial, "Apple Color Emoji","Segoe UI Emoji";
  --fs-root:14px;
  --fs-body:1rem;
  --fs-xs:.785rem;
  --fs-sm:.857rem;
  --fs-ui:.928rem;
  --fs-field:.928rem;
  --fs-label:.892rem;
  --fs-muted:.892rem;
  --fs-table:.892rem;
  --fs-table-head:.75rem;
  --fs-title-lg:1.143rem;
  --fs-title-xl:1.643rem;
  --content-max:1440px;
  --mobile-header-h:56px;
}

*{box-sizing:border-box}
html,body {height:100%; font-size:var(--fs-root);}

body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:var(--bg);
  font-size:var(--fs-body);
  line-height:1.55;
}

button,input,select,textarea{
  font:inherit;
}

a{color:var(--secondary); text-decoration:none}
a:hover{text-decoration:underline}

.app-shell{
  display:flex;
  min-height:100vh;
}

.sidebar{
  width:260px;
  background:var(--primary);
  color:var(--text);
  /* sin padding derecho para que la opción activa pueda “tocar” el contenido */
  padding:18px 0 18px 14px;
  position:sticky;
  top:0;
  height:100vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.sidebar-top{flex:0 0 auto;}
.sidebar-sep{
  height:1px;
  background:rgba(47,35,37,.12);
  margin:10px 14px 8px 0;
}
.sidebar-scroll{flex:1 1 auto; overflow:auto; padding-right:0;}
.sidebar-bottom{flex:0 0 auto; padding:10px 10px 0;}

.account{
  border-top:1px solid rgba(47,35,37,.12);
  padding-top:10px;
  margin-top:8px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.account-name{font-weight:800; font-size:var(--fs-ui); color:rgba(47,35,37,.70); opacity:1;}
.account-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  flex-direction:row;
  padding-right:14px;
}
.account-link{
  color:var(--text);
  opacity:.95;
  padding:8px 10px;
  border-radius:10px;
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  margin-right:0;
}
.account-link:hover{background:rgba(47,35,37,.08); text-decoration:none;}
.account-user{flex:0 1 auto; min-width:0; margin-left:0; padding:8px 2px 8px 4px; gap:2px; font-weight:600; font-size:var(--fs-sm); opacity:.9;}
.account-user span{display:block; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:92px;}
.account-logout{flex:0 0 auto; white-space:nowrap;}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 10px 14px;
  margin-bottom:10px;
}
.brand img{width:44px;height:44px}
.brand .title{
  font-weight:800;
  letter-spacing:.2px;
  font-size:1.25rem;
  line-height:1;
  color:#000;
}
.brand .subtitle{
  font-size:var(--fs-sm);
  opacity:.85;
  margin-top:3px;
  color:var(--muted);
}
.brand:hover{text-decoration:none}

.nav{
  margin-top:8px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.nav a{
  color:var(--text);
  padding:10px 12px;
  border-radius:12px;
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:600;
  opacity:.96;
  /* separa del borde derecho por defecto */
  margin-right:14px;
}
.nav a:hover{
  background:rgba(47,35,37,.08);
  text-decoration:none;
}
.nav a.active{
  /* misma “piel” que la zona de datos */
  background:#fffafb;
  color:var(--text);
  box-shadow:none;
  /* evitar que el background se oscurezca por la opacidad general del link */
  opacity:1;
  /* llega hasta el borde para unirse visualmente con el contenido */
  margin-right:0;
  border-radius:12px 0 0 12px;
}

/* Cabeceras de secciones con acción a la derecha (p.ej. + Nuevo diagnóstico) */
.section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.section-head h3{margin:0;}
.section-head .btn{white-space:nowrap;}

.section-head.compact{margin-bottom:10px; flex-wrap:wrap;}
.section-title-row{display:flex; align-items:center; gap:8px; min-width:0;}
.section-title-row h3{margin:0;}
.section-more{display:inline-flex; align-items:center; justify-content:center; min-width:22px; text-decoration:none; color:var(--muted); font-weight:800; font-size:18px; line-height:1;}
.section-more:hover{color:var(--text);}
.section-actions-right{display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-left:auto;}

/* Acciones de formularios al final */
.form-actions{
  margin-top:14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-start;
}
.btn-back{
  padding:10px 16px;
  font-size:14px;
  min-width:218px; /* ~doble ancho que el resto */
}

.form-actions .actions-left{display:flex; gap:10px; flex-wrap:wrap; align-items:center;}
.form-actions .actions-mid{display:flex; gap:10px; flex-wrap:wrap; align-items:center; flex:1 1 auto;}
.form-actions .actions-right{display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-left:auto;}
.form-actions .actions-right form{display:inline;}

/* Separador visual entre la barra de acciones (volver/guardar/...) y las secciones posteriores (archivos, relacionados, etc.) */
.edit-sep{
  height:1px;
  background:var(--border);
  margin:14px 20px;
  border-radius:999px;
}


/* si quitamos el título interno de página, alineamos acciones a la derecha */
.page-header{justify-content:flex-end;}
.card.no-topgap > .page-header{display:none;}

.entity-head{margin:0 0 16px; padding-top:0;}
.entity-head-main{display:flex; align-items:baseline; gap:14px; flex-wrap:wrap;}
.entity-head-main a{text-decoration:none;}
.entity-head-main a:hover{text-decoration:underline;}
.entity-title-link,.entity-subtitle-link{display:inline-flex; align-items:center; gap:6px;}
.entity-title-link{font-size:1.714rem; font-weight:900; color:var(--text); line-height:1.15;}
.entity-subtitle-link{font-size:1rem; font-weight:700; color:var(--muted);}
.title-ext-icon{display:inline-block; color:#8b95a5; font-size:.82em; line-height:1; transform:translateY(-.02em);}
.entity-title-prefix{display:inline-flex; align-items:center; gap:8px; color:var(--text); font-size:1.714rem; font-weight:900; line-height:1.15;}
.entity-title-prefix .prefix-icon{color:#8b95a5; font-size:.82em;}
.form-vertical{width:100%;}

.nav .section{
  margin:14px 10px 6px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  opacity:.75;
}

.sidebar .footer{
  margin-top:10px;
  padding:6px 0 10px;
  font-size:var(--fs-sm);
  opacity:.75;
}

.main{
  flex:1;
  display:flex;
  flex-direction:column;
  min-width:0;
}


.topbar{
  background:rgba(248,244,239,.92);
  backdrop-filter:saturate(140%) blur(6px);
  border-bottom:0;
  height:0;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  position:sticky;
  top:0;
  z-index:20;
  white-space:nowrap;
}

/* Nota: el título superior se elimina para evitar doble título.
   El título principal queda en el contenido de cada página. */

.user-pill{
  display:flex;
  align-items:center;
  gap:10px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:999px;
  padding:4px 10px;
  box-shadow:none;
}
.user-pill .role{ display:none; }
.user-pill .name{
  font-weight:700;
  font-size:var(--fs-ui);
}


.btn{
  border:1px solid var(--border);
  border-radius:10px;
  padding:8px 12px;
  font-weight:700;
  font-size:var(--fs-ui);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none !important;
  background:#eef2f7;
  color:var(--text);
}
.btn:hover{ background:#e7ecf3; }

.btn.is-disabled,
.btn[aria-disabled="true"]{
  opacity:.55;
  cursor:not-allowed;
  pointer-events:none;
}


/* Botones: todos en gris claro excepto los destructivos */
.btn-primary,
.btn-secondary,
.btn-ghost{background:#eef2f7; border-color:var(--border); color:var(--text)}
.btn-primary:hover,
.btn-secondary:hover,
.btn-ghost:hover{background:#e7ecf3}

.btn-danger{
  background:#f8d7da;
  border-color:#f1aeb5;
  color:#842029;
}
.btn-danger:hover{filter:brightness(.98)}

.btn-success{
  background:#d1e7dd;
  border-color:#a3cfbb;
  color:#0f5132;
}
.btn-success:hover{filter:brightness(.98)}

.content{
  padding:28px 30px;
}
.container{
  max-width:none;
  width:100%;
  margin:0;
}


.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:16px;
}
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:24px;
}
.card h2,.card h3{margin:0 0 14px}
.card h2{font-size:1.375rem}
.card h3{font-size:var(--fs-title-lg)}
.card .muted{color:var(--muted); font-size:var(--fs-muted)}

.card p{margin:0 0 10px}

.kpi{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
}
.kpi .num{
  font-size:1.714rem;
  font-weight:900;
  color:var(--primary);
  line-height:1;
}
.kpi .label{font-size:var(--fs-ui);color:var(--muted);font-weight:700}
.kpi .chip{
  font-size:var(--fs-sm);
  color:#0f172a;
  background:#eef2f7;
  border:1px solid var(--border);
  padding:4px 10px;
  border-radius:999px;
  font-weight:700;
}

.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
}
.table th{
  text-align:left;
  font-size:var(--fs-table-head);
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#334155;
  background:#f8fafc;
  border-bottom:1px solid var(--border);
  padding:10px 12px;
}
.table td{
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  vertical-align:top;
  font-size:var(--fs-table);
}
.photo-cell{
  width:36px;
  text-align:center;
  vertical-align:middle;
  opacity:.9;
}
.table tr:last-child td{border-bottom:none}

/* Hover sobrio en listados */
.table-hover tbody tr:hover{background:#f7f9fb}
tr[data-href]{cursor:pointer}

.badge{
  display:inline-flex;
  align-items:center;
  padding:3px 10px;
  border-radius:999px;
  font-weight:800;
  font-size:var(--fs-sm);
  border:1px solid var(--border);
  background:#fff;
}
.badge.success{color:var(--success); border-color:rgba(46,155,95,.25); background:rgba(46,155,95,.08)}
.badge.warning{color:var(--warning); border-color:rgba(212,155,42,.28); background:rgba(212,155,42,.10)}
.badge.danger{color:var(--danger); border-color:rgba(217,83,79,.28); background:rgba(217,83,79,.10)}
.badge.muted{color:var(--muted); background:#f9fafb}

input[type="text"],input[type="email"],input[type="password"],input[type="date"],input[type="datetime-local"],input[type="number"],input[type="search"],select,textarea{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  font-size:var(--fs-field);
}

label{display:block; margin:0 0 7px; font-weight:700; font-size:var(--fs-label)}
textarea{min-height:110px; resize:vertical}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:rgba(47,111,100,.55);
  box-shadow:0 0 0 4px rgba(47,111,100,.12);
}

.form-row{display:grid; grid-template-columns:repeat(12,1fr); gap:12px; margin-bottom:18px}
.col-12{grid-column:span 12}
.col-6{grid-column:span 6}
.col-4{grid-column:span 4}
.col-3{grid-column:span 3}
.col-8{grid-column:span 8}
.col-9{grid-column:span 9}

.flash{
  border-radius:14px;
  padding:12px 14px;
  border:1px solid var(--border);
  background:#fff;
  margin-bottom:14px;
  box-shadow:var(--shadow-sm);
  font-weight:700;
}
.flash.ok{border-color:rgba(46,155,95,.28); background:rgba(46,155,95,.08); color:var(--success)}
.flash.err{border-color:rgba(217,83,79,.28); background:rgba(217,83,79,.10); color:var(--danger)}

.hr{height:1px;background:var(--border);margin:14px 0}

.collapse-head{
  display:flex; align-items:center; justify-content:space-between;
  cursor:pointer;
  user-select:none;
}
.collapse-icon{opacity:.7}

.hidden{display:none !important}

.login-wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:22px;
  background: radial-gradient(900px 500px at 15% 10%, rgba(47,111,100,.18), transparent 60%),
              radial-gradient(700px 420px at 85% 25%, rgba(79,111,165,.16), transparent 55%),
              var(--bg);
}
.login-card{
  width:min(460px, 100%);
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  box-shadow:var(--shadow);
  padding:22px;
}
.login-card .brandline{display:flex; align-items:center; gap:12px; margin-bottom:10px}
.login-card .brandline img{width:46px;height:46px}
.login-card h1{font-size:1.375rem;margin:6px 0 4px}
.login-card p{margin:0 0 14px; color:var(--muted)}

/* Menú Sistema desplegable (sobrio) */
.menu-group{position:relative; margin-right:14px;}
.menu-group-title{cursor:pointer; padding:10px 12px; border-radius:12px; font-weight:700; color:var(--text); opacity:.96; user-select:none; display:flex; align-items:center; gap:8px;}
.menu-group-title .sys-caret{margin-left:auto; opacity:.85;}
.menu-group-title:hover{background:rgba(255,255,255,.10)}
/* Al desplegar Sistema, ocultar el texto para que el popup tenga más espacio */
.menu-group.open .menu-group-title .sys-text{display:none;}
/* Al desplegar: el popup tapa el botón (no deja “hueco” desaprovechado) */
.menu-group.open .menu-group-title{opacity:0; pointer-events:none;}
/* Popup de sistema (tipo overlay; no se recorta por el scroll del sidebar) */
.menu-group-items{display:none; position:fixed; left:0; top:0; width:218px;
  background:rgba(255,255,255,.08); color:var(--text); border:1px solid rgba(255,255,255,.14); border-radius:12px; padding:5px; box-shadow:0 10px 24px rgba(0,0,0,.20); z-index:80;
  backdrop-filter: blur(6px);
  overflow:auto;
}
.menu-group.open .menu-group-items{display:block}
.menu-group-items a{display:flex; gap:6px; align-items:center; padding:6px 8px; border-radius:9px; color:var(--text); text-decoration:none; font-size:.86rem; line-height:1.12; font-weight:700;}
.menu-group-items a:hover{background:rgba(255,255,255,.10)}
.menu-group-items a.active{background:rgba(255,255,255,.16)}

/* Cliente/Perro: mini dashboard */
.client-summary{display:flex; gap:24px; flex-wrap:wrap; align-items:flex-start; margin-bottom:18px}
.client-photo{width:160px; height:160px; object-fit:cover; border-radius:12px; border:1px solid var(--border); background:#fff}
.client-photo.placeholder{display:flex; align-items:center; justify-content:center; color:var(--muted); font-weight:800; background:#f7f9fb}

.dog-grid{display:flex; gap:14px; flex-wrap:wrap; align-items:flex-start}
.dog-thumb{width:120px; text-decoration:none; color:inherit}
.dog-thumb img{width:120px; height:86px; object-fit:cover; border-radius:10px; border:1px solid var(--border); background:#fff; display:block}
.dog-thumb-ph{width:120px; height:86px; border-radius:10px; border:1px solid var(--border); background:#f7f9fb; display:flex; align-items:center; justify-content:center; color:var(--muted); font-weight:800}
.dog-name{margin-top:6px; font-size:var(--fs-ui); font-weight:800; text-align:center}

.dog-thumb-add{display:flex; align-items:center; justify-content:center; min-height:116px; text-align:center; padding:10px; border:1px dashed var(--border); border-radius:12px; background:#f8fafc; font-weight:800;}
.dog-thumb-add:hover{background:#f1f5f9; text-decoration:none;}
.client-edit-card{padding-top:26px;}
.client-edit-card label{font-size:var(--fs-label); margin-bottom:8px;}
.client-edit-card input,
.client-edit-card select,
.client-edit-card textarea{font-size:var(--fs-field); padding:10px 12px;}
.client-form-row{grid-template-columns:repeat(12,1fr); gap:14px 16px;}
.client-form-row .field-name{grid-column:span 7;}
.client-form-row .field-phone{grid-column:span 5;}
.client-form-row .field-email{grid-column:span 5;}
.client-form-row .field-address{grid-column:span 7;}
.client-form-row .field-notes{grid-column:span 12;}
.mini-table-link{display:inline-block; color:var(--text); font-weight:700; text-decoration:none;}
.mini-table-link:hover{text-decoration:underline;}

/* Formularios: tipografía base centralizada */
form:not(.upload-form) label,
.form-row label,
.form-vertical label{
  font-size:var(--fs-label);
  line-height:1.25;
}

form:not(.upload-form) input[type="text"],
form:not(.upload-form) input[type="email"],
form:not(.upload-form) input[type="password"],
form:not(.upload-form) input[type="date"],
form:not(.upload-form) input[type="datetime-local"],
form:not(.upload-form) input[type="number"],
form:not(.upload-form) input[type="search"],
form:not(.upload-form) select,
form:not(.upload-form) textarea,
.form-row input,
.form-row select,
.form-row textarea,
.form-vertical input,
.form-vertical select,
.form-vertical textarea{
  font-size:var(--fs-field);
  padding:10px 12px;
}

form:not(.upload-form) .form-row,
.form-row{
  gap:16px 18px;
  align-items:start;
}

.card form:not(.upload-form){width:100%;}
.card.no-topgap{padding-top:18px;}
.client-edit-card{padding-top:28px;}
.client-form-row .field-name{grid-column:span 8;}
.client-form-row .field-phone{grid-column:span 4;}
.client-form-row .field-email{grid-column:span 6;}
.client-form-row .field-address{grid-column:span 6;}
.client-form-row .field-notes textarea{min-height:150px;}

@media (max-width: 900px){
  .col-4,.col-3{grid-column:span 12}
  .client-form-row .field-name,
  .client-form-row .field-phone,
  .client-form-row .field-email,
  .client-form-row .field-address,
  .client-form-row .field-notes{grid-column:span 12;}
}


.mini-panels{display:flex; gap:18px; flex-wrap:wrap}
.mini-panel{flex:1; min-width:320px}
.mini-panel h3{margin:0 0 10px}

.dog-summary{display:flex; gap:24px; flex-wrap:wrap}
.dog-main-photo{width:200px; height:200px; object-fit:cover; border-radius:12px; border:1px solid var(--border); background:#fff}
.dog-main-photo.placeholder{display:flex; align-items:center; justify-content:center; color:var(--muted); font-weight:800; background:#f7f9fb}

/* Responsive: formularios y miniaturas */
@media (max-width: 900px){
  .col-6,.col-8,.col-9{grid-column:span 12}
}

@media (max-width: 768px){
  .sidebar{position:relative; height:auto; width:100%}
  .app-shell{flex-direction:column}
  .content{padding:22px}
  .client-summary,.dog-summary{flex-direction:column}
  .dog-grid{overflow-x:auto; flex-wrap:nowrap; padding-bottom:6px}
}

@media (max-width: 768px){
  .sidebar{position:relative; width:100%; height:auto}
  .app-shell{flex-direction:column}
  .topbar{position:relative}
  .content{padding:16px}
}


/* SaaS tables */
.saas-toolbar{display:flex; gap:12px; align-items:center; margin:10px 0 14px 0; flex-wrap:wrap;}
.saas-search{max-width:420px;}
.saas-status{color:var(--muted); font-size:var(--fs-sm); white-space:nowrap;}
.saas-status.done{color:#c7cdd6; font-weight:900;}
.saas-status.soft-count{color:#c7cdd6;}

input.loading{
  background-image:url('img/spinner.svg');
  background-repeat:no-repeat;
  background-position:right 10px center;
  background-size:16px 16px;
  padding-right:34px;
}

th.sortable{cursor:pointer; user-select:none;}
th.sortable.asc::after{content:' ▲'; color:var(--muted); font-size:var(--fs-sm);}
th.sortable.desc::after{content:' ▼'; color:var(--muted); font-size:var(--fs-sm);}

.clickable-row{cursor:pointer;}


/* ===== SaaS headers (title + search + new, one line) ===== */
.page-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
  flex-wrap:wrap;
}
.page-title-h{
  font-size:1.214rem;
  font-weight:800;
  margin:0;
}
.page-actions{
  display:flex;
  gap:10px;
  align-items:center;
  min-width:260px;
  width:100%;
}
.page-actions .btn{white-space:nowrap;}
.page-actions .spacer{flex:1 1 auto;}
.page-actions .export-links{display:flex; align-items:center; gap:8px; margin-left:auto;}
.page-actions .export-sep{display:inline-block; width:1px; height:28px; background:var(--border); margin:0 2px 0 4px;}
.page-actions .saas-search{
  height:34px;
  padding:6px 10px;
  min-width:220px;
}
.page-actions .saas-search.loading{
  background:url('img/spinner.svg') no-repeat right 10px center;
  background-size:16px 16px;
}
.page-actions .export-links .btn{white-space:nowrap;}
.page-actions .saas-search{flex:0 1 320px;}
.page-actions .saas-date-from,.page-actions .saas-date-to{width:auto; min-width:148px;}

@media(max-width:768px){
  .page-actions{ width:100%; flex-wrap:wrap; }
  .page-actions .saas-search{ flex:1; min-width:0; }
  .page-actions .spacer{display:none;}
  .page-actions .export-links{margin-left:0;}
}

/* Forms: one field per line by default */
.form-vertical label{ margin-top:12px; display:block; font-weight:700; }
.form-vertical input, .form-vertical select, .form-vertical textarea{ width:100%; }

/* Autocomplete */
.autocomplete{
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  max-height:220px;
  overflow:auto;
  margin-top:6px;
}
.autocomplete .item{
  padding:8px 10px;
  cursor:pointer;
}
.autocomplete .item:hover{
  background:#f1f5f9;
}
.autocomplete .hint{
  font-size:var(--fs-sm);
  color:var(--muted);
  padding:8px 10px;
}

.top-right{display:flex; align-items:center; gap:10px;}


/* Lightbox para imágenes */
.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(17,24,39,.70);z-index:9999;padding:24px;}
.lightbox.open{display:flex;}
.lightbox .box{background:#fff;border-radius:14px;max-width:min(1100px,96vw);max-height:92vh;box-shadow:var(--shadow);overflow:hidden;}
.lightbox .box img{display:block;max-width:96vw;max-height:92vh;height:auto;width:auto;}
.lightbox .cap{padding:10px 14px;border-top:1px solid var(--border);font-size:var(--fs-ui);color:var(--muted);}


.upload-head{display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:6px;}
.upload-head h3{margin:0;}
.upload-limits{font-size:var(--fs-sm); white-space:nowrap; text-align:right;}
.upload-form{margin-top:8px;}
.upload-line{display:flex; align-items:end; gap:10px; flex-wrap:wrap;}
.upload-line .field-file{flex:1.1; min-width:190px;}
.upload-line .field-title{flex:1.1; min-width:180px;}
.upload-line .field-desc{flex:2; min-width:220px;}
.upload-line .field-btn{display:flex; align-items:end;}
@media (max-width: 900px){
  .upload-head{align-items:flex-start; flex-direction:column;}
  .upload-limits{text-align:left; white-space:normal;}
}


.upload-table-wrap{margin-top:12px;}
.upload-row td{background:#f8fafc; vertical-align:middle;}
.upload-row:hover td{background:#f8fafc;}
.upload-row-type{font-size:1rem; text-align:center; color:transparent;}
.upload-row-actions{white-space:nowrap; text-align:center;}
.upload-form-inline{margin:0;}
.upload-form-inline .btn{white-space:nowrap;}
.upload-inline{display:flex; align-items:center; gap:10px; width:100%;}
.upload-file-wrap{display:flex; flex-direction:column; gap:4px; min-width:260px; flex:1.2;}
.upload-inline input[type="text"]{min-width:180px; flex:1;}
.upload-limits-inline small{line-height:1.2; display:block;}
@media (max-width: 1100px){
  .upload-inline{flex-wrap:wrap;}
  .upload-row-actions{min-width:120px;}
}

.upload-row-emptysep td{border-top:14px solid #fff;}


/* Formularios: un único campo por línea */
form:not(.upload-form) .form-row,
.form-row,
.client-form-row{
  grid-template-columns:1fr !important;
  gap:16px !important;
}
form:not(.upload-form) .form-row > *,
.form-row > *,
.client-form-row > *{
  grid-column:1 / -1 !important;
}
form:not(.upload-form) label,
.form-row label,
.form-vertical label{
  display:block;
  margin:0 0 8px;
}
form:not(.upload-form) input[type="text"],
form:not(.upload-form) input[type="email"],
form:not(.upload-form) input[type="password"],
form:not(.upload-form) input[type="date"],
form:not(.upload-form) input[type="datetime-local"],
form:not(.upload-form) input[type="number"],
form:not(.upload-form) input[type="search"],
form:not(.upload-form) select,
form:not(.upload-form) textarea,
.form-row input,
.form-row select,
.form-row textarea,
.form-vertical input,
.form-vertical select,
.form-vertical textarea{
  width:100%;
}
.table-compact th, .table-compact td{padding:8px 10px; font-size:var(--fs-ui);}



/* Ajustes Balucan / pagos / backup */
.brand img{width:64px;height:64px;object-fit:contain}
.client-summary-sep{width:1px; align-self:stretch; background:var(--border); border-radius:999px; min-height:132px}
.client-photo{width:120px; height:120px}
.client-photo.placeholder{font-size:13px}
.payments-card .table th,.payments-card .table td{vertical-align:middle}
.payment-row-form{background:#fff0ef}
.payment-row-total td{font-weight:800;background:#fff8f8}
.payment-row-form input{min-width:0}
.payment-obs-cell{display:flex; align-items:center; justify-content:space-between; gap:10px}
.payment-obs-text{min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.payment-delete-inline{flex:0 0 auto}
.kpi-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:12px}
.kpi{background:var(--card); border:1px solid var(--border); border-radius:14px; padding:14px 16px; box-shadow:var(--shadow-sm)}
.kpi .k{font-size:var(--fs-sm); color:var(--muted); text-transform:uppercase; letter-spacing:.08em}
.kpi .v{font-size:1.25rem; font-weight:900; margin-top:4px}
.backup-form-grid{display:grid; grid-template-columns:1fr auto; gap:12px; align-items:end}
.badge-soft{display:inline-flex; align-items:center; padding:4px 8px; border-radius:999px; background:#ffe9e8; color:var(--text); font-weight:700; font-size:12px}
@media (max-width: 860px){
  .client-summary-sep{display:none}
  .backup-form-grid{grid-template-columns:1fr}
  .payment-obs-cell{display:block}
  .payment-delete-inline{margin-top:8px}
}

.section{display:none;}


/* ===== Tipografía y layout unificados ===== */
body,
.table td,
.table th,
input,
select,
textarea,
button{font-size:inherit;}

.content{padding:24px;}
.container{max-width:var(--content-max);}
.card{padding:20px;}
.card h2{font-size:1.375rem;}
.card h3{font-size:var(--fs-title-lg);}
.page-title-h{font-size:1.25rem;}
.entity-title-link,
.entity-title-prefix{font-size:1.75rem;}
.entity-subtitle-link{font-size:1rem;}
.kpi .num{font-size:1.75rem;}
.kpi .k{font-size:var(--fs-xs);}
.kpi .v{font-size:1.25rem;}
.upload-limits,
.lightbox .cap,
.saas-status,
.kpi .label,
.badge,
.autocomplete .hint{font-size:var(--fs-sm);}
.table-wrap,
.upload-table-wrap{width:100%; overflow-x:auto;}
.table{min-width:760px;}
.table.table-fit{min-width:0;}
.form-actions .btn,
.page-actions .btn,
.section-actions-right .btn{min-height:38px;}

.sidebar-mobile-toggle,
.sidebar-backdrop{display:none;}

@media (max-width: 768px){
  body{padding-top:var(--mobile-header-h);}
  .sidebar-mobile-toggle{
    display:inline-flex;
    position:fixed;
    top:10px;
    left:12px;
    z-index:130;
    align-items:center;
    gap:8px;
    border:1px solid var(--border);
    border-radius:999px;
    background:#fff;
    color:var(--text);
    box-shadow:var(--shadow-sm);
    padding:9px 14px;
    font-weight:800;
    line-height:1;
  }
  .sidebar-mobile-toggle:hover{text-decoration:none; background:#fff;}
  .sidebar-backdrop{
    position:fixed;
    inset:0;
    z-index:109;
    background:rgba(36,29,32,.35);
    opacity:0;
    pointer-events:none;
    transition:opacity .2s ease;
  }
  body.sidebar-open .sidebar-backdrop{
    display:block;
    opacity:1;
    pointer-events:auto;
  }
  .app-shell{display:block; min-height:100vh;}
  .sidebar{
    position:fixed;
    top:0;
    left:0;
    bottom:0;
    width:min(320px, calc(100vw - 28px));
    max-width:92vw;
    height:100vh;
    z-index:120;
    transform:translateX(-104%);
    transition:transform .22s ease;
    padding-top:16px;
    box-shadow:0 12px 32px rgba(0,0,0,.18);
  }
  body.sidebar-open .sidebar{transform:translateX(0);}
  .main{width:100%;}
  .topbar{display:none;}
  .content{padding:16px 14px 22px;}
  .container{max-width:100%;}
  .card{padding:16px; border-radius:12px;}
  .page-header,
  .section-head,
  .section-head.compact,
  .form-actions,
  .upload-head,
  .upload-line,
  .section-actions-right{align-items:stretch;}
  .page-actions,
  .section-actions-right,
  .form-actions .actions-left,
  .form-actions .actions-mid,
  .form-actions .actions-right{width:100%;}
  .page-actions .saas-search,
  .page-actions .saas-date-from,
  .page-actions .saas-date-to,
  .section-actions-right .btn,
  .form-actions .btn,
  .btn-back,
  .upload-line > *{width:100%; min-width:0;}
  .page-actions .export-links{width:100%; margin-left:0; justify-content:flex-start; flex-wrap:wrap;}
  .page-actions .export-sep{display:none;}
  .table{min-width:640px;}
  .client-summary,
  .dog-summary,
  .mini-panels,
  .dog-grid{gap:12px;}
  .dog-grid{overflow-x:auto; flex-wrap:nowrap; padding-bottom:4px;}
}

@media (max-width: 640px){
  html,body{font-size:13.5px;}
  .brand img{width:56px; height:56px;}
  .brand .title{font-size:1.15rem;}
  .content{padding:12px;}
  .card{padding:14px;}
  .flash{padding:10px 12px;}
  .table{min-width:580px;}
  input[type="text"],input[type="email"],input[type="password"],input[type="date"],input[type="datetime-local"],input[type="number"],input[type="search"],select,textarea{padding:9px 10px;}
}

/* Informes */
.report-card .page-header{align-items:flex-start;}
.report-filters{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px 14px;margin-top:14px;align-items:end;}
.report-filters label{display:block;font-size:var(--fs-sm);font-weight:800;margin-bottom:5px;color:var(--muted);}
.report-filters input,.report-filters select{width:100%;min-width:0;}
.report-field-wide{grid-column:span 2;}
.report-filter-actions{grid-column:1 / -1;display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:2px;}
.report-summary{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-bottom:12px;}
.report-filter-summary{flex:1 1 100%;font-size:var(--fs-sm);}
.report-payments-table .num,.table .num{text-align:right;white-space:nowrap;}
@media (max-width:980px){
  .report-filters{grid-template-columns:repeat(2,minmax(0,1fr));}
  .report-field-wide{grid-column:1 / -1;}
}
@media (max-width:640px){
  .report-filters{grid-template-columns:1fr;}
  .report-filter-actions .btn{width:100%;}
}

/* Cabecera documental en impresiones/PDF: un único rectángulo claro sin bordes */
.screen-doc-header{margin-bottom:18px;}
.screen-doc-header .doc-header-block{width:100%;border:0!important;border-collapse:collapse!important;border-spacing:0!important;background:#f2f4f7!important;margin:0 0 14px;}
.screen-doc-header .doc-header-block td,.screen-doc-header .doc-header-inner td,.screen-doc-header .doc-header-content td{border:0!important;background:#f2f4f7!important;vertical-align:top;}
.screen-doc-header .doc-header-accent{height:4px;background:#dfe7ef!important;font-size:1px;line-height:1px;}
.screen-doc-header .doc-header-company{padding:18px 20px!important;}
.screen-doc-header .doc-header-client{padding:18px 20px!important;text-align:right;}
.screen-doc-header .doc-header-inner,.screen-doc-header .doc-header-content{width:100%;border:0!important;border-collapse:collapse!important;border-spacing:0!important;background:#f2f4f7!important;margin:0;}
.screen-doc-header .doc-logo{width:auto;max-width:58px;max-height:58px;margin-right:12px;vertical-align:top;border-radius:10px;}
.screen-doc-header .doc-brand{font-weight:900;font-size:1.25rem;color:var(--text);line-height:1.15;}
.screen-doc-header .doc-subbrand{font-size:var(--fs-sm);color:var(--muted);margin-top:2px;}
.screen-doc-header .doc-contact{font-size:var(--fs-xs);color:var(--muted);margin-top:4px;line-height:1.35;}
.screen-doc-header .doc-client-name{font-weight:900;font-size:1.05rem;color:var(--text);line-height:1.15;}
.screen-doc-header .doc-client-line{font-size:var(--fs-xs);color:var(--muted);line-height:1.35;margin-top:3px;}
.screen-doc-header .doc-heading{border-bottom:1px solid var(--border);padding-bottom:11px;margin:0 0 14px;}
.screen-doc-header .doc-kicker{font-size:var(--fs-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;}
.screen-doc-header .doc-title{font-weight:900;font-size:1.15rem;color:var(--text);line-height:1.15;}
.screen-doc-header .doc-subtitle{font-size:var(--fs-xs);color:var(--muted);margin-top:4px;}
.screen-doc-header .doc-rule{display:none;}
@media (max-width:640px){
  .screen-doc-header .doc-header-block td{display:block;width:100%!important;text-align:left!important;}
}

.company-logo-preview{min-height:78px;border:1px dashed var(--border);border-radius:14px;background:#f8fafc;padding:10px;display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.company-logo-preview img{max-width:110px;max-height:70px;border-radius:12px;background:#fff;border:1px solid var(--border);padding:6px;}
.checkline{display:inline-flex!important;align-items:center;gap:6px;margin:0!important;font-weight:700;color:var(--muted);}
@media (max-width:640px){
  .screen-doc-header .doc-top-boxes td{display:block;width:100%!important;text-align:left!important;padding:0!important;}
  .screen-doc-header .doc-right-cell{margin-top:8px;}
}


/* Documentos imprimibles/PDF: evitar cortes de campos entre páginas */
@media print{
  table.fields tr, table.list tr, table.report-table tr, table.kpis tr, .box, .filter-box{break-inside:avoid;page-break-inside:avoid;}
  h2,h3{break-after:avoid-page;page-break-after:avoid;}
}

/* Informe de pagos: cabeceras ordenables */
.table-sort-link{display:inline-flex;align-items:center;gap:4px;color:inherit;text-decoration:none;font-weight:800;}
.table-sort-link:hover{text-decoration:underline;}
.table th.num .table-sort-link{justify-content:flex-end;width:100%;}

/* Ajuste 1.9.11: informe de pagos más compacto y acciones junto al buscador */
.report-card{padding:16px 18px;}
.report-card .page-header{margin-bottom:2px;}
.report-card .page-header h2{margin-bottom:2px;}
.report-filters{
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:8px 10px;
  margin-top:10px;
  align-items:end;
}
.report-filters label{
  font-size:.78rem;
  line-height:1.1;
  margin-bottom:3px;
}
.report-filters input,
.report-filters select{
  min-height:34px;
  padding:7px 9px;
  font-size:.86rem;
}
.report-span-1{grid-column:span 1;}
.report-span-2{grid-column:span 2;}
.report-field-search{grid-column:span 4;}
.report-filter-actions-inline{
  grid-column:span 2;
  display:flex;
  justify-content:flex-end;
  align-items:flex-end;
  gap:6px;
  flex-wrap:nowrap;
  margin-top:0;
}
.report-filter-actions-inline .btn{
  min-height:34px;
  padding:7px 9px;
  white-space:nowrap;
}
@media (max-width:1180px){
  .report-filters{grid-template-columns:repeat(4,minmax(0,1fr));}
  .report-field-search{grid-column:span 2;}
  .report-filter-actions-inline{grid-column:span 2;}
}
@media (max-width:780px){
  .report-filters{grid-template-columns:repeat(2,minmax(0,1fr));}
  .report-span-1,.report-span-2,.report-field-search,.report-filter-actions-inline{grid-column:1 / -1;}
  .report-filter-actions-inline{justify-content:flex-start;flex-wrap:wrap;}
}
@media (max-width:640px){
  .report-filter-actions-inline .btn{width:auto;flex:1 1 46%;}
}

/* Copias: acciones compactas en la lista de backups */
.btn-sm{
  padding:5px 8px;
  border-radius:8px;
  font-size:12px;
  gap:5px;
  min-height:0;
}
.btn-warn{
  background:#fff3cd;
  border-color:#ffda6a;
  color:#664d03;
}
.btn-warn:hover{filter:brightness(.98)}
.nowrap{white-space:nowrap;}
.table th.actions,.table td.actions{text-align:right;}
.table td.actions form{margin-left:4px;}
