:root{
  --bg:#F8F5F4;
  --panel:#FFFFFF;
  --panel-2:#f8f3dd;
  --text:#1E1810;
  --muted:#575250;
  --border:#dddddd;
  --accent:#725631;
  --accent-2:#4B4F58;
  --danger:#b85c4a;
  --shadow:0 10px 24px rgba(30,24,16,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}
body{min-height:100vh}
button,input{font:inherit}
.auth-shell{display:none;min-height:100vh;padding:24px;align-items:center;justify-content:center;background:radial-gradient(circle at top,#f8f3dd 0%,#F8F5F4 65%)}
.auth-shell.is-visible{display:flex}
.auth-card{width:min(100%,460px);background:var(--panel);border:1px solid var(--border);border-radius:28px;padding:28px;box-shadow:var(--shadow)}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.auth-title{margin:0 0 8px;font-size:30px}
.auth-copy{margin:0 0 22px;color:var(--muted);line-height:1.5}
.auth-form{display:grid;gap:16px}
.field{display:grid;gap:8px}
.field span{font-size:13px;color:var(--muted);font-weight:600}
.field input{width:100%;padding:14px 16px;border-radius:16px;border:1px solid var(--border);background:#FFFFFF;color:var(--text);outline:none}
.field input:focus{border-color:var(--accent)}
.auth-meta{margin-top:16px;color:var(--muted);font-size:13px}
.alert{margin-top:16px;padding:12px 14px;border-radius:14px;border:1px solid transparent}
.alert-error{background:rgba(184,92,74,.10);border-color:rgba(184,92,74,.25);color:#8c3d2e}
.btn{border-radius:16px;padding:12px 16px;border:1px solid var(--border);cursor:pointer}
.btn-primary{background:var(--accent);color:#FFFFFF;border-color:transparent;font-weight:700}
.btn-primary:disabled{opacity:.7;cursor:wait}
.btn-ghost{background:transparent;color:var(--text)}
.app-shell{display:grid;grid-template-columns:220px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#725631 0%, #4B4F58 100%);border-right:1px solid rgba(30,24,16,.08);padding:20px;display:flex;flex-direction:column;gap:20px}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:44px;height:44px;border-radius:14px;background:#f8f3dd;color:var(--accent);display:grid;place-items:center;font-weight:800;font-size:22px}
.brand-title{font-size:18px;font-weight:700;color:#FFFFFF}
.brand-subtitle{font-size:12px;color:rgba(255,255,255,.72)}
.menu{display:flex;flex-direction:column;gap:8px}
.menu-item{background:transparent;border:1px solid transparent;color:#FFFFFF;text-align:left;padding:12px 14px;border-radius:14px;cursor:pointer;font-size:14px}
.menu-item:hover{background:rgba(248,243,221,.18);border-color:rgba(255,255,255,.16)}
.menu-item.is-active{background:#f8f3dd;color:var(--accent);border-color:#f8f3dd}
.sidebar-footer{margin-top:auto}
.env-pill{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(248,243,221,.16);border:1px solid rgba(255,255,255,.16);font-size:12px;color:#FFFFFF}
.main{padding:24px}
.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px}
.topbar-main{display:flex;align-items:center;gap:8px}
.topbar h1{margin:0 0 4px;font-size:18px;line-height:1.15}
.topbar p{margin:0;color:var(--muted)}
.topbar-actions{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--border);border-radius:18px;background:var(--panel)}
.topbar-user{align-items:center}
.global-task-alert{display:inline-flex;align-items:center;gap:8px;border-color:rgba(114,86,49,.22);background:var(--panel-2);color:var(--text)}
.global-task-alert strong{display:inline-grid;place-items:center;min-width:24px;height:24px;padding:0 6px;border-radius:999px;background:#b2332f;color:#fff;font-size:11px;line-height:1}
.global-task-alert:hover{border-color:rgba(114,86,49,.34);background:#efe8c8}
.global-task-tray-summary{margin-bottom:12px}
.global-task-tray-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--panel-2)}
.global-task-tray-main{display:grid;gap:6px}
.global-task-tray-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.global-task-tray-meta{display:flex;gap:10px;flex-wrap:wrap}
.global-task-tray-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start;justify-content:flex-end}
.sidebar-toggle{min-width:32px;padding:5px 8px}
.user-chip{display:flex;align-items:center;gap:10px}
.user-name{font-size:14px;font-weight:700}
.user-role{font-size:12px;color:var(--muted);text-transform:capitalize}
.status-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);display:inline-block}
.grid{display:grid;gap:18px}
.grid-4{grid-template-columns:repeat(4,1fr);margin-bottom:18px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:20px;box-shadow:var(--shadow)}
.kpi-label{font-size:13px;color:var(--muted);margin-bottom:8px}
.kpi-value{font-size:32px;font-weight:800}
.kpi-value-small{font-size:20px;line-height:1.4}
.clean-list{padding-left:18px;color:var(--muted)}
.clean-list li{margin-bottom:8px}
.code-box{background:var(--panel-2);border:1px solid var(--border);border-radius:14px;padding:12px 14px;margin-bottom:10px;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:13px;color:var(--text)}
.dashboard-session-grid{margin-bottom:18px}
.dashboard-session-list{display:grid;gap:12px}
.dashboard-session-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}
.dashboard-session-row:last-child{border-bottom:none;padding-bottom:0}
.dashboard-session-row span{color:var(--muted)}
.dashboard-session-row strong{text-align:right}
.dashboard-session-row .badge{justify-content:center;text-transform:capitalize}
.view{display:none}
.view.is-visible{display:block}
.placeholder-table{border:1px solid var(--border);border-radius:16px;overflow:hidden}
.placeholder-table .row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;padding:14px 16px;border-top:1px solid var(--border)}
.placeholder-table .row.header{background:var(--panel-2);font-weight:700;border-top:0}
.table-wrap .muted{text-align:center}
.cliente-header{margin-bottom:10px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:6px}
.cliente-header-name{font-size:18px;font-weight:700;line-height:1.1}
.cliente-header-meta{display:grid;gap:2px;color:var(--muted);font-size:12px}
.cliente-detail-topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap;margin-bottom:12px}
.cliente-detail-tabs{display:flex;gap:8px;flex-wrap:wrap}
.cliente-detail-tab{padding:8px 12px;border:1px solid var(--border);border-radius:999px;background:#FFFFFF;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:background .18s ease,color .18s ease,border-color .18s ease}
.cliente-detail-tab.is-active{background:var(--panel-2);color:var(--text);border-color:rgba(114,86,49,.28)}
.cliente-topbar-side{display:grid;gap:8px;justify-items:end;min-width:min(100%,360px)}
.cliente-topbar-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.cliente-topbar-indicators{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.cliente-topbar-indicator,.cliente-topbar-alert{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#FFFFFF}
.cliente-topbar-indicator span,.cliente-topbar-alert span{font-size:11px;color:var(--muted);font-weight:600}
.cliente-topbar-indicator strong,.cliente-topbar-alert strong{font-size:12px}
.cliente-topbar-alert{border-color:rgba(184,92,74,.28);background:rgba(184,92,74,.10);color:#8c3d2e}
.cliente-topbar-indicator.erp-warning,
.cliente-topbar-alert.erp-warning{
  border-color:rgba(139,32,32,.58);
  background:#b2332f;
  color:#fff;
  box-shadow:0 10px 18px rgba(178,51,47,.18);
  transition:background-color .18s ease,box-shadow .18s ease,border-color .18s ease,transform .18s ease;
}
.cliente-topbar-indicator.erp-warning span,
.cliente-topbar-alert.erp-warning span,
.cliente-topbar-indicator.erp-warning strong,
.cliente-topbar-alert.erp-warning strong{
  color:#fff;
}
.cliente-topbar-indicator.erp-warning:hover,
.cliente-topbar-alert.erp-warning:hover,
.cliente-topbar-indicator.erp-warning:focus-visible,
.cliente-topbar-alert.erp-warning:focus-visible{
  background:#962622;
  border-color:#7f1d1d;
  box-shadow:0 12px 22px rgba(150,38,34,.24);
}
.cliente-detail-panel{display:none}
.cliente-detail-panel.is-active{display:block}
.cliente-header-card{margin-bottom:10px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-bono-card{margin-bottom:10px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#FFFFFF}
.cliente-bono-card h3{margin:0 0 8px;font-size:12px;line-height:1.2;text-transform:uppercase;color:var(--muted)}
.cliente-bono-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}
.cliente-header-meta{display:grid;gap:4px}
.cliente-header-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}
.cliente-header-detail{padding:8px 10px;border:1px solid rgba(114,86,49,.14);border-radius:10px;background:#FFFFFF}
.cliente-header-detail span{display:block;font-size:10px;color:var(--muted);margin-bottom:2px}
.cliente-header-detail strong{display:block;font-size:12px;line-height:1.25}
.cliente-bono-editor-inline-actions{grid-column:1 / -1;display:flex;justify-content:flex-start;align-items:center}
.cliente-bono-grid span{display:block;font-size:10px;color:var(--muted);margin-bottom:2px}
.cliente-bono-grid strong{font-size:12px;line-height:1.2}
.cliente-bono-classes{margin-top:8px}
.cliente-bono-clases-toggle{padding:5px 8px;border-radius:8px;font-size:10px}
.cliente-bono-clases-list{display:grid;gap:6px;margin-top:6px}
.cliente-bono-clase-item{padding:7px 8px;border:1px solid var(--border);border-radius:8px;background:var(--panel-2)}
.cliente-bono-clase-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:2px}
.cliente-bono-clase-top strong{font-size:11px;line-height:1.2}
.cliente-bono-clase-meta{font-size:10px;line-height:1.3;color:var(--muted)}
.cliente-bono-clase-estado{display:inline-flex;padding:2px 6px;border-radius:999px;border:1px solid var(--border);font-size:9px;line-height:1.1;text-transform:capitalize;background:#FFFFFF}
.cliente-bono-clase-estado.is-futura{color:#0b7ea0;border-color:rgba(12,194,240,.24);background:rgba(12,194,240,.12)}
.cliente-bono-clase-estado.is-realizada{color:#2f7d32;border-color:rgba(91,181,91,.28);background:rgba(91,181,91,.12)}
.cliente-bono-clase-estado.is-cancelada{color:#a13e2c;border-color:rgba(184,92,74,.24);background:rgba(184,92,74,.12)}
.cliente-bono-clase-empty{padding:7px 8px;border:1px dashed var(--border);border-radius:8px;background:#FFFFFF;font-size:10px}
.cliente-bonos-historial{display:grid;gap:6px}
.cliente-bono-history-editor{margin-bottom:12px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-bono-history-item{padding:8px 9px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-bono-history-summary{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}
.cliente-bono-history-basic{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:6px 10px}
.cliente-bono-history-basic span,.cliente-bono-history-grid span{display:block;font-size:9px;color:var(--muted);margin-bottom:1px}
.cliente-bono-history-basic strong,.cliente-bono-history-grid strong{font-size:11px;line-height:1.15}
.cliente-bono-history-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.cliente-bono-pay-inline{min-width:140px;justify-content:center}
.cliente-bono-history-toggle{display:none}
.cliente-bono-history-detail{display:none}
.cliente-bono-history-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 10px}
.cliente-data-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}
.cliente-data-grid span,.cliente-stack-item span,.cliente-task-meta,.cliente-timeline-date{display:block;font-size:10px;line-height:1.2;color:var(--muted)}
.cliente-data-grid strong,.cliente-stack-item strong,.cliente-task-top strong,.cliente-timeline-text{font-size:12px;line-height:1.25}
.cliente-stack-list{display:grid;gap:8px}
.cliente-stack-item{padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-stack-item strong{display:block;white-space:pre-wrap}
.cliente-edit-fields{margin-bottom:8px}
.cliente-detail-field input,.cliente-detail-field textarea,.cliente-detail-field select{width:100%}
.cliente-detail-field textarea{padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:#FFFFFF;color:var(--text);resize:vertical}
.cliente-detail-field-wide{grid-column:1 / -1}
.field-wide{grid-column:1 / -1}
.cliente-block-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.cliente-block-head h3{margin:0;font-size:12px;line-height:1.2;text-transform:uppercase;color:var(--muted)}
.btn-icon{display:inline-grid;place-items:center;min-width:28px;width:28px;height:28px;padding:0;border-radius:999px;font-size:13px;font-weight:700;background:#FFFFFF;color:var(--accent);border-color:rgba(114,86,49,.22)}
.btn-icon:hover{background:var(--panel-2);border-color:rgba(114,86,49,.32)}
.cliente-notes-card{margin-bottom:10px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#FFFFFF}
.cliente-notes-view{min-height:48px;padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2);white-space:pre-wrap}
.cliente-notes-field textarea{width:100%;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:#FFFFFF;color:var(--text);resize:none}
.cliente-task-form{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(150px,.8fr) minmax(120px,.7fr);gap:10px 12px;margin-bottom:12px}
.cliente-task-form-text{grid-column:auto}
.cliente-task-form-actions{align-self:end}
.cliente-task-list{display:grid;gap:8px}
.cliente-task-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:9px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-task-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.cliente-task-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.cliente-task-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:flex-end}
.cliente-task-state,.cliente-task-priority,.cliente-timeline-type{display:inline-flex;padding:2px 6px;border-radius:999px;border:1px solid var(--border);font-size:9px;line-height:1.1;text-transform:capitalize;background:#FFFFFF}
.cliente-task-state.is-done{color:#2f7d32;border-color:rgba(91,181,91,.28);background:rgba(91,181,91,.12)}
.cliente-task-state.is-pending{color:#a13e2c;border-color:rgba(184,92,74,.24);background:rgba(184,92,74,.12)}
.cliente-task-priority.is-high{color:#a13e2c;border-color:rgba(184,92,74,.24);background:rgba(184,92,74,.12)}
.cliente-task-priority.is-medium{color:#725631;border-color:rgba(114,86,49,.22);background:rgba(114,86,49,.10)}
.cliente-task-priority.is-low{color:#0b7ea0;border-color:rgba(12,194,240,.24);background:rgba(12,194,240,.12)}
.cliente-health-list{display:grid;gap:10px}
.cliente-health-card{display:grid;gap:8px;padding:12px 14px;border:1px solid rgba(114,86,49,.14);border-radius:14px;background:var(--panel-2)}
.cliente-health-card-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}
.cliente-health-card-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.cliente-health-card-label{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.cliente-health-card-date{font-size:12px;color:var(--muted)}
.cliente-health-monitor{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:rgba(114,86,49,.10);color:#725631;font-size:12px;font-weight:700}
.cliente-health-note{font-size:14px;line-height:1.45;white-space:pre-wrap;color:var(--text)}
.cliente-health-card-actions{display:flex;justify-content:flex-end}
.cliente-doc-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:12px}
.cliente-doc-summary-item{padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-doc-summary-item span,.cliente-doc-meta{display:block;font-size:10px;line-height:1.2;color:var(--muted)}
.cliente-doc-summary-item strong,.cliente-doc-top strong{font-size:12px;line-height:1.25}
.cliente-doc-form{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(140px,.85fr) minmax(120px,.75fr) auto;gap:10px 12px;margin-bottom:12px}
.cliente-doc-form-actions{align-self:end}
.cliente-doc-sync-field{align-self:end}
.checkbox-inline{display:flex;align-items:center;gap:8px;font-size:10px;line-height:1.2;color:var(--text)}
.checkbox-inline input{margin:0}
.cliente-doc-template-meta-box{min-height:38px;padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2);font-size:11px;line-height:1.3;color:var(--text)}
.cliente-doc-template-summary{margin-bottom:12px;padding:9px 10px;border:1px solid var(--border);border-radius:10px;background:#FFFFFF}
.cliente-doc-template-summary.text-danger{border-color:rgba(184,92,74,.25);background:rgba(184,92,74,.10);color:#8c3d2e}
.cliente-doc-modal-form{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:0}
.cliente-doc-viewer{margin-bottom:12px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#FFFFFF}
.cliente-doc-viewer-title{font-size:13px;font-weight:700;line-height:1.25;margin-bottom:4px}
.cliente-doc-viewer-title-input{width:100%;margin:0 0 8px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);font-size:14px;font-weight:700}
.cliente-doc-viewer-meta{margin-bottom:10px}
.cliente-doc-viewer-content{padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2);font-size:12px;line-height:1.5}
.cliente-doc-viewer-content.is-editing{min-height:320px;background:#fff;outline:none}
.cliente-doc-viewer-content h1,.cliente-doc-viewer-content h2,.cliente-doc-viewer-content h3{margin:0 0 8px}
.cliente-doc-viewer-content p{margin:0 0 8px}
.cliente-doc-viewer-content ul{margin:0 0 8px 18px;padding:0}
.cliente-doc-signature-panel{margin-bottom:12px}
.cliente-doc-signature-panel.is-fullscreen{position:fixed;inset:0;z-index:90;margin:0;background:rgba(30,24,16,.18);pointer-events:none}
.cliente-doc-signature-shell{position:fixed;top:12vh;left:50%;transform:translateX(-50%);display:grid;gap:14px;width:min(720px,50vw);min-width:520px;max-width:calc(100vw - 48px);padding:16px;border:1px solid rgba(114,86,49,.22);border-radius:18px;background:#f8f5f4;box-shadow:0 20px 50px rgba(30,24,16,.22);pointer-events:auto}
.cliente-doc-signature-head{display:grid;gap:6px;cursor:move;user-select:none}
.cliente-doc-signature-kicker{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.cliente-doc-signature-title{font-size:24px;line-height:1.1;font-weight:800}
.cliente-doc-signature-stage{display:grid;min-height:0}
.cliente-doc-signature-canvas{display:block;width:100%;height:280px;min-height:280px;border:1px dashed rgba(114,86,49,.28);border-radius:14px;background:#fff;touch-action:none}
.cliente-doc-signature-actions{margin-top:0;align-self:end;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.cliente-doc-list{display:grid;gap:8px}
.cliente-doc-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:9px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-doc-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.cliente-doc-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.cliente-doc-send{color:#725631}
.cliente-doc-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:flex-end}
.cliente-doc-status{display:inline-flex;padding:2px 6px;border-radius:999px;border:1px solid var(--border);font-size:9px;line-height:1.1;text-transform:capitalize;background:#FFFFFF}
.cliente-doc-status.is-pending{color:#a13e2c;border-color:rgba(184,92,74,.24);background:rgba(184,92,74,.12)}
.cliente-doc-status.is-signed{color:#2f7d32;border-color:rgba(91,181,91,.28);background:rgba(91,181,91,.12)}
.cliente-doc-status.is-expired{color:#4B4F58;border-color:rgba(75,79,88,.20);background:rgba(75,79,88,.10)}
.cliente-reservas-toolbar{margin-bottom:12px;max-width:240px}
.cliente-reservas-list{display:grid;gap:10px}
.cliente-reserva-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--panel-2)}
.cliente-reserva-main{display:grid;gap:6px}
.cliente-reserva-time{font-size:15px;font-weight:700;color:#1e3cff}
.cliente-reserva-label{font-size:11px;color:var(--muted)}
.cliente-reserva-service{font-size:18px;font-weight:700;line-height:1.2}
.cliente-reserva-meta{display:grid;gap:4px;font-size:12px;color:var(--text)}
.cliente-reserva-datebox{display:grid;place-items:center;min-width:64px;padding:10px 8px;border-radius:14px;background:#f0eee9;color:#3b3b3b;font-weight:800;text-align:center}
.cliente-reserva-datebox strong{display:block;font-size:16px;line-height:1}
.cliente-reserva-datebox span{display:block;font-size:11px;line-height:1.1}
.cliente-reserva-actions{display:flex;align-items:flex-start;gap:8px}
.cliente-modal-shell{position:fixed;inset:0;z-index:120}
.cliente-modal-backdrop{position:absolute;inset:0;background:rgba(24,18,12,.36)}
.cliente-modal-card{position:relative;z-index:1;width:min(1040px,calc(100vw - 48px));margin:28px auto;padding:0;border-radius:18px;background:#fff;box-shadow:0 24px 50px rgba(0,0,0,.22);overflow:hidden}
.cliente-summary-modal-card{width:min(920px,calc(100vw - 48px))}
.cliente-sesiones-modal-card{display:grid;gap:0}
.cliente-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 22px;border-bottom:1px solid var(--border)}
.cliente-modal-kicker{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.cliente-modal-head h3{margin:4px 0 0;font-size:28px;line-height:1.1}
.cliente-modal-note{padding:14px 22px 0;font-size:12px;color:var(--muted);font-weight:600}
.cliente-sesiones-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:18px 22px}
.cliente-sesiones-column{display:grid;gap:10px;padding:14px;border:1px solid var(--border);border-radius:14px;background:#eef7fd}
.cliente-sesiones-column-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.cliente-sesiones-column-head h4{margin:0;font-size:18px;line-height:1.2;color:#2d6d96}
.cliente-sesiones-list{display:grid;gap:8px;max-height:360px;overflow:auto;padding-right:4px}
.cliente-sesion-item{padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:#fff;cursor:pointer}
.cliente-sesion-item.is-selected{border-color:#2d6d96;box-shadow:0 0 0 2px rgba(45,109,150,.14)}
.cliente-sesion-item strong{display:block;font-size:16px;line-height:1.2;margin-bottom:6px}
.cliente-sesion-item span{display:block;font-size:12px;line-height:1.4;color:var(--text)}
.cliente-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:18px 22px;border-top:1px solid var(--border);background:#fff}
@media (max-width: 980px){
  .cliente-bono-history-basic{grid-template-columns:repeat(3,minmax(0,1fr))}
  .cliente-sesiones-columns{grid-template-columns:1fr}
}
.template-list{display:grid;gap:8px}
.template-list-item{display:grid;gap:6px;width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:var(--panel-2);text-align:left;cursor:pointer}
.template-list-item.is-active{border-color:rgba(114,86,49,.38);background:#fffaf0}
.template-list-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.template-list-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:10px;line-height:1.25;color:var(--muted)}
.template-list-copy{margin:0;font-size:11px;line-height:1.45;color:var(--text)}
.template-flag{display:inline-flex;padding:2px 6px;border-radius:999px;background:#FFFFFF;border:1px solid rgba(114,86,49,.22);color:var(--accent)}
.grid-plantillas{grid-template-columns:minmax(320px,.95fr) minmax(0,1.35fr)}
.bono-template-active-field{display:flex;flex-direction:column;justify-content:flex-end}
.bono-template-active-field input{width:18px;height:18px}
.template-flags{grid-column:1 / -1;display:flex;gap:10px;flex-wrap:wrap;padding:10px;border:1px solid var(--border);border-radius:12px;background:var(--panel-2)}
.template-editor-wrap{grid-column:1 / -1}
.template-editor-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.template-editor-field{display:grid;gap:8px}
.template-editor-select{width:auto;min-width:120px;padding:8px 10px;border-radius:10px}
.template-editor{min-height:420px;padding:18px;border:1px solid var(--border);border-radius:12px;background:#FFFFFF;font-size:14px;line-height:1.6;outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.5)}
.template-editor:focus{border-color:rgba(114,86,49,.38)}
.template-editor h1,.template-editor h2,.template-editor h3{margin:0 0 12px}
.template-editor h1{font-size:30px;line-height:1.2}
.template-editor h2{font-size:24px;line-height:1.25}
.template-editor h3{font-size:18px;line-height:1.3}
.template-editor p{margin:0 0 12px}
.template-editor ul,.template-editor ol{margin:0 0 12px 24px;padding:0}
.template-editor blockquote{margin:0 0 12px;padding:10px 14px;border-left:4px solid rgba(114,86,49,.35);background:#faf6ec;color:#433626}
.template-variable-box{grid-column:1 / -1;padding:10px;border:1px solid var(--border);border-radius:12px;background:#FFFFFF}
.template-variable-title{font-size:11px;font-weight:700;margin-bottom:8px}
.template-variable-list{display:flex;gap:8px;flex-wrap:wrap}
.cliente-timeline-list{display:grid;gap:8px}
.cliente-timeline-item{display:grid;grid-template-columns:110px minmax(0,1fr);gap:10px;padding:9px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.cliente-timeline-content{display:grid;gap:4px}
.cliente-timeline-top{display:flex;align-items:center;gap:8px}
.data-table tbody tr{cursor:pointer}
.calendar-mock{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:14px}
.day{border:1px dashed var(--border);border-radius:16px;padding:20px;text-align:center;color:var(--muted);background:var(--panel-2)}
.calendar-week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:12px;margin-top:12px}
.calendar-day-card{display:grid;gap:10px;padding:12px;border:1px solid var(--border);border-radius:14px;background:var(--panel-2);align-content:start;min-height:220px}
.calendar-day-head{display:grid;gap:4px;padding-bottom:8px;border-bottom:1px solid rgba(114,86,49,.16)}
.calendar-day-head strong{font-size:14px;line-height:1.2}
.calendar-day-head span{font-size:11px;color:var(--muted)}
.calendar-class-list{display:grid;gap:8px}
.calendar-class-item{display:grid;gap:6px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#fff}
.calendar-class-top{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.calendar-class-top strong{font-size:13px;line-height:1.2}
.calendar-class-time{font-size:11px;color:var(--muted);font-weight:700}
.calendar-class-metrics{display:flex;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--muted)}
.calendar-pill{display:inline-flex;padding:3px 7px;border-radius:999px;border:1px solid var(--border);font-size:10px;line-height:1.1;background:#fff;color:var(--text)}
.calendar-pill.is-full{color:#a13e2c;border-color:rgba(184,92,74,.24);background:rgba(184,92,74,.12)}
.calendar-pill.is-free{color:#2f7d32;border-color:rgba(91,181,91,.28);background:rgba(91,181,91,.12)}
.calendar-pill.is-dup{color:#0b7ea0;border-color:rgba(12,194,240,.24);background:rgba(12,194,240,.12)}
.calendar-empty{padding:10px;border:1px dashed var(--border);border-radius:12px;background:#fff;font-size:11px;color:var(--muted)}
code{background:var(--panel-2);padding:2px 6px;border-radius:8px;border:1px solid var(--border)}
[hidden]{display:none !important}
@media (max-width: 1100px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:sticky;top:0;z-index:10}
  .grid-4,.grid-2{grid-template-columns:1fr}
  .topbar{flex-direction:column}
  .calendar-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}


.view{display:none}
.view.is-visible{display:block}
.muted{color:var(--muted)}
.section-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}
.inline-actions{display:flex;gap:10px;align-items:center}
.clientes-section-head{justify-content:flex-start}
.clientes-toolbar{align-items:flex-end;flex-wrap:wrap}
.clientes-toolbar-field{min-width:220px}
.clientes-toolbar{width:100%}
.clientes-toolbar-field input{min-width:240px}
.clientes-toolbar-field-search{flex:1 1 520px;min-width:360px}
.clientes-toolbar-field-search input{width:100%;min-width:0}
.grid-staff{grid-template-columns:minmax(0,1.6fr) minmax(340px,1fr)}
.table-wrap{overflow:auto}
.data-table{width:100%;border-collapse:collapse;font-size:14px}
.data-table th,.data-table td{padding:12px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.data-table th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.badge{display:inline-flex;padding:6px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px}
.badge.ok{background:rgba(114,86,49,.10);color:#725631;border-color:rgba(114,86,49,.25)}
.badge.off{background:rgba(75,79,88,.10);color:#4B4F58;border-color:rgba(75,79,88,.20)}
.badge.cliente-activa{background:rgba(91,181,91,.12);color:#2f7d32;border-color:rgba(91,181,91,.28)}
.badge.cliente-caducado{background:rgba(75,79,88,.10);color:#4B4F58;border-color:rgba(75,79,88,.20)}
.badge.cliente-pendiente{background:rgba(184,92,74,.12);color:#a13e2c;border-color:rgba(184,92,74,.24)}
.badge.cliente-pausado{background:rgba(12,194,240,.12);color:#0b7ea0;border-color:rgba(12,194,240,.24)}
.action-stack{display:flex;gap:8px;flex-wrap:wrap}
.btn-small{padding:8px 10px;border-radius:12px;font-size:12px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .field:last-of-type{grid-column:1 / -1}
.form-actions{grid-column:1 / -1;display:flex;gap:10px}
.cliente-summary-modal-body{padding:18px 22px}
#cliente-summary-modal .cliente-modal-head{padding-bottom:12px}
#cliente-summary-modal .cliente-modal-head h3{font-size:44px;line-height:1.05}
#cliente-summary-modal .cliente-modal-actions{padding:14px 0 0;border-top:none;background:transparent}
#cliente-edit-fields .cliente-detail-field{grid-column:auto}
.select{width:100%;padding:14px 16px;border-radius:16px;border:1px solid var(--border);background:#FFFFFF;color:var(--text);outline:none}
.sep{border:none;border-top:1px solid var(--border);margin:20px 0}
.small-code{font-size:13px;min-height:52px}
@media (max-width: 1100px){
  .grid-staff,.grid-4,.grid-2{grid-template-columns:1fr}
}
@media (max-width: 800px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{border-right:none;border-bottom:1px solid var(--border)}
  .topbar{flex-direction:column;align-items:stretch}
  .form-grid{grid-template-columns:1fr}
  .cliente-detail-topbar{flex-direction:column}
  .cliente-topbar-side{justify-items:start;min-width:100%}
  .cliente-topbar-actions,
  .cliente-topbar-indicators{justify-content:flex-start}
  .cliente-operativos-grid,
  .cliente-data-grid,
  .cliente-doc-summary,
  .cliente-doc-form,
  .cliente-doc-item,
  .cliente-task-form,
  .cliente-task-item,
  .cliente-timeline-item,
  .cliente-bono-history-basic,
  .cliente-bono-grid,.cliente-bono-history-grid{grid-template-columns:1fr}
  .cliente-task-actions,
  .cliente-doc-actions{justify-content:flex-start}
  .cliente-doc-signature-shell{width:min(calc(100vw - 24px),640px);min-width:0;top:8vh;left:12px;transform:none}
  .cliente-doc-signature-canvas{height:220px;min-height:220px}
  .grid-plantillas{grid-template-columns:1fr}
  .template-flags,
  .template-variable-list,
  .template-editor-toolbar{gap:6px}
  .template-editor-select{width:100%}
  .cliente-doc-signature-shell{padding:12px}
  .cliente-doc-signature-title{font-size:18px}
  .calendar-week-grid{grid-template-columns:1fr}
  .payment-context-summary{grid-template-columns:1fr}
}

#view-dashboard{
  font-size:11px;
}

#view-dashboard .grid{
  gap:8px;
}

#view-dashboard h2{
  margin:0 0 4px;
  font-size:12px;
  line-height:1.15;
}

#view-dashboard .card{
  padding:8px 10px;
}

#view-dashboard .kpi-label{
  font-size:10px;
  margin-bottom:4px;
}

#view-dashboard .kpi-value{
  font-size:13px;
  line-height:1.1;
}

#view-dashboard .kpi-value-small{
  font-size:11px;
  line-height:1.2;
}

#view-dashboard .dashboard-session-row{
  gap:6px;
  padding:3px 0;
}

#view-dashboard .dashboard-session-row span{
  font-size:10px;
}

#view-dashboard .dashboard-session-row strong{
  font-size:10px;
}

#view-dashboard .badge{
  padding:1px 5px;
  font-size:8px;
  line-height:1.1;
}

#view-dashboard .muted,
#view-dashboard p,
#view-dashboard .code-box{
  font-size:10px;
}

.app-shell .brand-subtitle,
#page-subtitle{
  display:none;
}

.ops-panel{display:grid;gap:12px}
.ops-item{padding:14px 16px;border:1px solid rgba(114,86,49,.16);border-radius:14px;background:linear-gradient(180deg,#fff 0%,#fbf7ef 100%)}
.ops-item strong{display:block;margin-bottom:6px;font-size:13px;line-height:1.2}
.ops-item p{margin:0;font-size:12px;line-height:1.5}

.app-shell{grid-template-columns:180px 1fr}

.sidebar{
  padding:10px;
  gap:10px;
}

.brand{
  gap:8px;
}

.brand-mark{
  width:28px;
  height:28px;
  border-radius:8px;
  font-size:13px;
}

.brand-title{
  font-size:12px;
}

.menu-icon{
  width:14px;
  min-width:14px;
  display:inline-grid;
  place-items:center;
  font-size:12px;
}

.menu-label{
  white-space:nowrap;
}

.menu{
  gap:4px;
}

.menu-item{
  padding:6px 8px;
  border-radius:8px;
  font-size:11px;
}

.env-pill{
  padding:4px 8px;
  font-size:10px;
}

.main{
  padding:10px;
}

.topbar{
  gap:10px;
  margin-bottom:10px;
}

.topbar h1{
  margin:0 0 2px;
  font-size:15px;
  line-height:1.1;
}

.topbar-actions{
  gap:6px;
  padding:6px 8px;
  border-radius:10px;
}

.user-name{
  font-size:11px;
}

.user-role{
  font-size:9px;
}

.btn{
  padding:7px 10px;
  border-radius:10px;
  font-size:11px;
}

.grid{
  gap:8px;
}

.grid-4{
  margin-bottom:8px;
}

.card{
  padding:10px 12px;
  border-radius:12px;
}

.card h2{
  margin:0 0 6px;
  font-size:13px;
  line-height:1.15;
}

.card p,
.muted,
.clean-list,
.placeholder-table,
.code-box{
  font-size:11px;
}

.clean-list li{
  margin-bottom:2px;
}

.code-box{
  padding:7px 9px;
  border-radius:8px;
  margin-bottom:6px;
}

.placeholder-table .row{
  padding:8px 10px;
}

.calendar-mock{
  gap:6px;
  margin-top:8px;
}

.day{
  border-radius:10px;
  padding:10px;
  font-size:11px;
}

.data-table{
  font-size:11px;
}

.data-table th,.data-table td{
  padding:7px 6px;
}

.action-stack{
  gap:4px;
}

.btn-small{
  padding:4px 6px;
  border-radius:8px;
  font-size:10px;
}

.form-grid{
  gap:8px;
}

.field span{
  font-size:10px;
}

.field input,
.select{
  padding:8px 10px;
  border-radius:10px;
  font-size:11px;
}

.form-actions{
  gap:6px;
}

.sep{
  margin:10px 0;
}

.app-shell.sidebar-collapsed{
  grid-template-columns:54px 1fr;
}

.app-shell.sidebar-collapsed .sidebar{
  padding:10px 6px;
}

.app-shell.sidebar-collapsed .brand{
  justify-content:center;
}

.app-shell.sidebar-collapsed .brand > div:last-child,
.app-shell.sidebar-collapsed .env-pill{
  display:none;
}

.app-shell.sidebar-collapsed .menu-item{
  justify-content:center;
  padding:6px;
}

.app-shell.sidebar-collapsed .menu-label{
  display:none;
}

.payment-context-card{display:grid;gap:16px;padding:18px;border:1px solid var(--border);border-radius:16px;background:var(--panel-2)}
.payment-context-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.payment-context-summary div{display:grid;gap:4px;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff}
.payment-context-summary span{font-size:11px;color:var(--muted)}
.payment-context-summary strong{font-size:14px;line-height:1.2}
.cliente-bono-state{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;border:1px solid var(--border);font-size:11px;font-weight:600;background:var(--panel-2)}
.cliente-bono-state.is-pending{color:#a35a00;border-color:rgba(201,128,23,.25);background:rgba(201,128,23,.12)}
/* Calendar operational refresh */
#page-subtitle:empty{display:none}
#view-calendario .section-head{align-items:center;margin-bottom:8px}
#calendar-summary{display:none}
.calendar-week-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-top:8px}
.calendar-day-card{display:grid;gap:6px;padding:8px;border-radius:12px;min-height:0}
.calendar-day-head{gap:1px;padding-bottom:4px}
.calendar-day-head strong{font-size:13px;color:#2f6db2}
.calendar-day-head span{font-size:10px}
.calendar-class-list{display:grid;gap:6px}
.calendar-band{display:grid;gap:6px;padding:8px;border:1px solid rgba(114,86,49,.12);border-radius:12px;background:rgba(255,255,255,.68)}
.calendar-band-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-bottom:6px;border-bottom:1px solid rgba(114,86,49,.12)}
.calendar-band-head strong{font-size:11px;line-height:1.1;text-transform:uppercase;letter-spacing:.04em;color:#5f4a2a}
.calendar-band-head span{font-size:10px;line-height:1.1;color:#8b8174}
.calendar-band-slots{display:grid;gap:6px}
.calendar-band-empty{padding:8px;border:1px dashed rgba(114,86,49,.16);border-radius:10px;background:#fff;font-size:10px;line-height:1.2;color:#8b8174}
.calendar-slot{border:1px dashed rgba(114,86,49,.18);border-radius:10px;min-height:34px;padding:2px;background:#faf8f5;cursor:pointer}
.calendar-slot-label{font-size:10px;color:#8b8174;margin-bottom:2px}
.calendar-class-item{gap:2px;padding:6px 7px;border-radius:10px;border-width:1px;cursor:pointer;position:relative}
.calendar-class-item.is-draggable{cursor:grab}
.calendar-class-item.dragging{opacity:.55}
.calendar-class-item strong{font-size:11px;line-height:1.05}
.calendar-class-time{font-size:9px;line-height:1;color:#5f5951}
.calendar-class-metrics{font-size:10px;gap:5px}
.calendar-service-tag{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;border-radius:999px;font-size:9px;font-weight:700;background:rgba(255,255,255,.9);color:#3d3427;padding:0 5px}
.calendar-modal-card{width:min(760px,calc(100vw - 32px));max-height:calc(100vh - 36px);overflow:auto;border-radius:16px}
.calendar-modal-card .cliente-modal-head{padding:16px 18px}
.calendar-modal-card .cliente-modal-head h3{font-size:26px;line-height:1.08}
.calendar-modal-card .cliente-modal-note{padding:10px 18px 0;font-size:12px}
.calendar-modal-card .cliente-summary-grid{padding:12px 18px 0}
.calendar-modal-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.calendar-choice-group{display:flex;gap:8px;flex-wrap:wrap}
.calendar-choice-group-wide{width:100%}
.calendar-choice-btn{padding:10px 14px;border:1px solid #d7ded3;border-radius:999px;background:#fff;color:#4a443f;font-size:13px;font-weight:600;cursor:pointer;transition:.16s ease}
.calendar-choice-btn:hover{border-color:#b9c5b1;background:#f7faf4}
.calendar-choice-btn.is-active{background:#eef6e5;border-color:#7d9a60;color:#2f4a1d}
.calendar-color-palette{display:flex;flex-direction:column;gap:10px}
.calendar-color-group{display:flex;flex-direction:column;gap:6px}
.calendar-color-group-label{font-size:11px;color:#6f675f;font-weight:700}
.calendar-color-row{display:flex;gap:8px;flex-wrap:wrap}
.calendar-color-swatch{width:28px;height:28px;border-radius:999px;border:2px solid rgba(90,82,74,.18);cursor:pointer;transition:.16s ease;box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}
.calendar-color-swatch:hover{transform:translateY(-1px)}
.calendar-color-swatch.is-active{border-color:#3f382f;box-shadow:0 0 0 3px rgba(63,56,47,.14)}
.calendar-color-inline{display:flex;align-items:center;gap:10px}
.calendar-color-preview{width:24px;height:24px;border-radius:999px;border:1px solid rgba(15,23,42,.12);background:#cfe8a9;display:inline-block}
.calendar-color-modal-card,.calendar-delete-modal-card{width:min(520px,calc(100vw - 32px))}
.check-inline{display:flex;align-items:center;gap:10px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.calendar-modal-card .field{gap:6px}
.calendar-modal-card .field span{font-size:12px;color:#6a625c;font-weight:600}
.calendar-modal-card .field input,.calendar-modal-card .field select,.calendar-modal-card .field textarea,.calendar-modal-card .select{padding:12px 14px;border-radius:12px;background:#fff;color:#1e1810;font-size:14px}
.calendar-class-add-row{display:flex;gap:10px;align-items:flex-end;padding:12px 18px 14px}
.calendar-class-add-row .field-grow{flex:1}
.calendar-modal-card .cliente-stack-list{padding:0 18px 6px}
.calendar-modal-card .cliente-modal-actions{padding:14px 18px;position:sticky;bottom:0;background:#fff}
.calendar-modal-card .btn{padding:11px 14px;border-radius:999px}
.calendar-modal-card .btn-primary{background:#725631;border-color:#725631;color:#fff}
.calendar-client-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:#fff}
.calendar-client-section{display:flex;flex-direction:column;gap:8px}
.calendar-client-section + .calendar-client-section{margin-top:10px}
.calendar-client-section-head{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#5d544b;font-weight:700}
.calendar-client-section.is-waitlist .calendar-client-section-head{color:#8a661d}
.calendar-client-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--muted)}
.calendar-client-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700}
.calendar-client-badge.is-activo{color:#2f7d32}
.calendar-client-badge.is-pendiente{color:#c47a14}
.calendar-client-badge.is-prueba{color:#0b7ea0}
.calendar-client-badge.is-fijo{color:#2f6db2}
.calendar-client-badge.is-waiting{color:#8a661d}
@media (max-width: 1100px){.calendar-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 700px){.calendar-week-grid{grid-template-columns:1fr}.calendar-class-add-row{flex-direction:column;align-items:stretch}.calendar-modal-grid{grid-template-columns:1fr}.calendar-modal-card{width:min(640px,calc(100vw - 20px))}}

/* Comunicaciones */
.comms-modal-card{width:min(600px,calc(100vw - 32px))}
.comms-modal-body{padding:16px 22px}
.comms-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.comms-destinatario-info{margin-top:8px;font-size:11px}
.comms-variables-box{display:flex;gap:6px;flex-wrap:wrap;padding:8px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.comms-var-chip{padding:3px 8px;border-radius:999px;background:#fff;border:1px solid rgba(114,86,49,.22);color:var(--accent);font-size:10px;font-weight:600;cursor:pointer;user-select:none}
.comms-var-chip:hover{background:var(--panel-2);border-color:var(--accent)}
@media (max-width:700px){.comms-form-grid{grid-template-columns:1fr}}

/* Informes */
.informes-toolbar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}
.informes-tipo-group{display:flex;gap:8px;flex-wrap:wrap}
.informes-fechas{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}

/* Ajustes */
.ajustes-panel{display:none}
.ajustes-panel.is-active{display:block}
.ajustes-item-list{display:grid;gap:8px;margin-bottom:4px}
.ajustes-item-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:9px 12px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.ajustes-item-row.is-inactive{opacity:.55}
.ajustes-item-info{display:flex;align-items:center;gap:10px}
.ajustes-item-swatch{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.12);flex-shrink:0}
.ajustes-item-name{font-size:13px;font-weight:600}
.ajustes-item-meta{font-size:11px;color:var(--muted);margin-left:4px}
.ajustes-item-actions{display:flex;gap:6px}
.ajustes-add-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}
.ajustes-add-actions{display:flex;align-items:flex-end}
.ajustes-color-field{width:90px}
.ajustes-color-field input[type=color]{width:100%;height:36px;padding:2px 4px;border-radius:10px;border:1px solid var(--border);cursor:pointer}
.ajustes-horarios-table{display:grid;gap:6px}
.ajustes-horarios-head{display:grid;grid-template-columns:140px 80px 1fr 1fr;gap:10px;padding:6px 10px;font-size:10px;font-weight:700;text-transform:uppercase;color:var(--muted)}
.ajustes-horario-row{display:grid;grid-template-columns:140px 80px 1fr 1fr;gap:10px;align-items:center;padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-2)}
.ajustes-horario-dia{font-size:13px;font-weight:600;text-transform:capitalize}
.ajustes-horario-row input[type=time]{width:100%;padding:7px 10px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:12px}
.ajustes-horario-row input[type=checkbox]{width:18px;height:18px;cursor:pointer}
.ajustes-empty{padding:12px;border:1px dashed var(--border);border-radius:10px;font-size:12px;color:var(--muted);text-align:center}
@media (max-width:800px){.ajustes-horarios-head,.ajustes-horario-row{grid-template-columns:1fr 60px 1fr 1fr}.ajustes-add-row{flex-direction:column;align-items:stretch}}

/* Modal resumen cliente: look premium alineado con alta base */
#cliente-summary-modal .cliente-summary-modal-card{
  width:min(980px,calc(100vw - 48px));
  margin:20px auto;
  background:#f8f5f4;
  border-radius:24px;
  box-shadow:0 28px 60px rgba(22,17,11,.18);
}
#cliente-summary-modal .cliente-summary-modal-head{
  padding:26px 28px 16px;
  border-bottom:none;
  align-items:flex-start;
}
#cliente-summary-modal .cliente-summary-modal-copy{
  display:grid;
  gap:8px;
}
#cliente-summary-modal .cliente-modal-kicker{
  font-size:13px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#6a625c;
}
#cliente-summary-modal .cliente-summary-modal-head h3{
  margin:0;
  font-size:52px;
  line-height:1;
  font-weight:800;
  color:#1e1810;
}
#cliente-summary-modal #cliente-summary-close{
  min-width:40px;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(208,198,186,.95);
  background:rgba(255,255,255,.7);
  color:#725631;
  font-size:20px;
  line-height:1;
}
#cliente-summary-modal #cliente-summary-close:hover{
  background:#fff;
  border-color:rgba(181,164,143,.95);
}
#cliente-summary-modal .cliente-summary-modal-body{
  padding:0 28px 26px;
}
#cliente-summary-modal #cliente-edit-fields{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:22px 18px;
}
#cliente-summary-modal .field{
  gap:10px;
}
#cliente-summary-modal .field span{
  font-size:16px;
  color:#6a625c;
  font-weight:600;
  line-height:1.2;
}
#cliente-summary-modal .field input,
#cliente-summary-modal .field select,
#cliente-summary-modal .field textarea,
#cliente-summary-modal .select{
  width:100%;
  min-height:66px;
  padding:18px 20px;
  border:1px solid #d8d1ca;
  border-radius:20px;
  background:#fff;
  color:#1e1810;
  font-size:16px;
  line-height:1.2;
  box-shadow:none;
}
#cliente-summary-modal .field input:focus,
#cliente-summary-modal .field select:focus,
#cliente-summary-modal .field textarea:focus,
#cliente-summary-modal .select:focus{
  border-color:#bfa88c;
  box-shadow:0 0 0 3px rgba(114,86,49,.12);
}
#cliente-summary-modal .cliente-summary-modal-actions{
  justify-content:flex-end;
  align-items:center;
  gap:14px;
  padding:0 28px 28px;
  border-top:none;
  background:transparent;
}
#cliente-summary-modal .cliente-summary-modal-actions .btn{
  padding:14px 22px;
  min-height:54px;
  border-radius:999px;
  font-size:15px;
  font-weight:700;
}
#cliente-summary-modal .cliente-summary-modal-actions .btn-primary{
  background:#8b6737;
  border-color:#8b6737;
  color:#fff;
}
#cliente-summary-modal .cliente-summary-modal-actions .btn-ghost{
  background:#fff;
  border-color:#d0c6ba;
  color:#1e1810;
}
@media (max-width: 900px){
  #cliente-summary-modal .cliente-summary-modal-card{
    width:min(760px,calc(100vw - 28px));
  }
  #cliente-summary-modal .cliente-summary-modal-head h3{
    font-size:38px;
  }
}
@media (max-width: 700px){
  #cliente-summary-modal .cliente-summary-modal-card{
    width:min(100vw - 20px,640px);
    margin:10px auto;
    border-radius:18px;
  }
  #cliente-summary-modal .cliente-summary-modal-head{
    padding:18px 18px 12px;
  }
  #cliente-summary-modal .cliente-summary-modal-head h3{
    font-size:30px;
  }
  #cliente-summary-modal .cliente-summary-modal-body{
    padding:0 18px 18px;
  }
  #cliente-summary-modal #cliente-edit-fields{
    grid-template-columns:1fr;
    gap:16px;
  }
  #cliente-summary-modal .cliente-summary-modal-actions{
    padding:0 18px 18px;
    flex-wrap:wrap;
  }
}

#global-task-tray-list{display:grid;gap:10px;max-height:55vh;overflow:auto;padding-right:4px}
