:root{
  --bg:#eef3f8;
  --bg-soft:#f6f9fc;
  --surface:#ffffff;
  --surface-2:#f8fbfe;
  --line:#d9e3ee;
  --line-strong:#cad7e5;
  --text:#16345f;
  --text-soft:#5d728a;
  --text-muted:#8392a3;
  --primary:#1f4f8f;
  --primary-strong:#173d70;
  --primary-soft:#e9f1fb;
  --success:#2c7a64;
  --success-soft:#e9f6f1;
  --warn:#946200;
  --warn-soft:#fff6dc;
  --danger:#a34848;
  --danger-soft:#fbefef;
  --shadow-sm:0 8px 18px rgba(16,45,80,.05);
  --shadow-md:0 18px 42px rgba(16,45,80,.08);
  --radius-sm:10px;
  --radius-md:16px;
  --radius-lg:24px;
  --container:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Poppins","Inter",system-ui,sans-serif;background:linear-gradient(180deg,#f6f9fc 0%,#edf2f7 100%);color:var(--text);font-size:14px;line-height:1.45}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
textarea{resize:vertical;min-height:110px}

/* Shared top header for citizen flow */
.top-header{padding:12px 14px 4px}
.top-header__inner{max-width:var(--container);margin:0 auto;background:rgba(255,255,255,.95);border:1px solid var(--line);box-shadow:var(--shadow-sm);border-radius:18px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand__logo{width:52px;height:52px;border-radius:14px;border:1px solid var(--line);padding:4px;background:#fff;object-fit:contain}
.brand__text{min-width:0}
.brand__kicker{display:inline-flex;align-items:center;padding:4px 9px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:11px;font-weight:700;margin-bottom:5px}
.brand__text h1{margin:0;font-size:1.25rem;line-height:1.08;letter-spacing:-.03em}
.brand__text p{margin:3px 0 0;color:var(--text-soft);font-size:.83rem}

.page{max-width:var(--container);margin:0 auto;padding:10px 14px 26px}
.card,.hero-card,.resume-card,.panel-pro,.modal-card{background:rgba(255,255,255,.97);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-sm)}
.card,.panel-pro{padding:18px}

.button-secondary,.btn-mini,.licencia-card__btn,.scroll-btn,.ghost-btn,.tab-btn,button[type="submit"],#btnActualizarEstado,#finalizar,#guardarCita,#btnLoginFuncionario{
  min-height:38px;padding:0 14px;border-radius:12px;border:1px solid var(--line-strong);background:#fff;color:var(--primary-strong);font-weight:700;transition:.18s ease;box-shadow:none
}
.button-secondary:hover,.btn-mini:hover,.licencia-card__btn:hover,.scroll-btn:hover,.ghost-btn:hover,.tab-btn:hover,button[type="submit"]:hover,#btnActualizarEstado:hover,#finalizar:hover,#guardarCita:hover,#btnLoginFuncionario:hover{background:var(--primary-soft);border-color:#bfd0e4;transform:translateY(-1px)}
button[type="submit"],#btnActualizarEstado,#finalizar,#guardarCita,#btnLoginFuncionario,.licencia-card__btn{background:linear-gradient(180deg,#fbfdff 0%,#f1f6fb 100%)}
button:disabled{opacity:.55;cursor:not-allowed;transform:none!important}

.small-badge,.card__badge,.resume-card__badge,.hero-badge,.admin-login-chip,.inc-chip,.top-chip,.documento-item__tag,.licencia-chip,.hero-chip{
  display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:var(--primary-soft);border:1px solid #d7e4f1;color:var(--primary);font-size:11px;font-weight:700
}

.hero-split{display:grid;grid-template-columns:1.2fr .9fr;gap:14px;margin-bottom:14px}
.hero-card{padding:18px 18px 16px;position:relative;overflow:hidden}
.hero-card::after{content:"";position:absolute;right:-34px;top:-34px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(31,79,143,.08),transparent 70%)}
.hero-card h2{position:relative;margin:0 0 8px;font-size:1.45rem;line-height:1.08;letter-spacing:-.04em;max-width:650px}
.hero-card>p{position:relative;margin:0;color:var(--text-soft);max-width:720px}
.hero-points{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}
.hero-point{padding:12px 13px;border-radius:16px;background:var(--surface-2);border:1px solid #e5edf5}
.hero-point strong{display:block;font-size:.9rem;margin-bottom:4px;color:var(--primary-strong)}
.hero-point p{margin:0;font-size:.82rem;color:var(--text-soft)}
.resume-card{padding:18px;background:linear-gradient(180deg,#fff 0%,#f8fbfe 100%)}
.resume-grid{display:grid;gap:9px}
.resume-item{display:grid;grid-template-columns:30px 1fr;gap:9px 11px;padding:11px;border-radius:15px;background:#fbfdff;border:1px solid #e5edf5}
.resume-item span{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-weight:700;font-size:12px}
.resume-item strong{font-size:.9rem;align-self:center}
.resume-item p{grid-column:2;margin:-2px 0 0;color:var(--text-soft);font-size:.8rem}
.panel-title{margin:0 0 12px;font-size:1rem;font-weight:700;color:var(--text)}

.progress-card{display:grid;grid-template-columns:minmax(0,1.5fr) 240px;gap:14px;align-items:center;padding:14px 16px;margin-bottom:14px}
.progress-header h2{margin:0 0 2px;font-size:.95rem}
.progress-header p{margin:0;color:var(--text-soft);font-size:.8rem}
.progress-steps-wrap{margin-top:10px}
.progress-steps{position:relative;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}
.progress-line{position:absolute;left:9%;right:9%;top:14px;height:3px;background:#dbe5ef;border-radius:999px}
.step{display:grid;justify-items:center;gap:6px;position:relative;z-index:1;text-align:center}
.step__circle{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#fff;border:2px solid #d4e0eb;font-weight:700;font-size:12px;color:var(--text-soft)}
.step span{font-size:11px;font-weight:700;color:var(--text-soft);line-height:1.15}
.step--active .step__circle,.step--done .step__circle{background:var(--primary);border-color:var(--primary);color:#fff}
.step--active span,.step--done span{color:var(--primary-strong)}
.summary-item{padding:14px;border-radius:16px;background:linear-gradient(180deg,#fbfdff 0%,#f1f6fb 100%);border:1px solid #dbe7f1}
.summary-item span{display:block;margin-bottom:5px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--primary)}
.summary-item strong{display:block;margin-bottom:5px;font-size:.94rem;line-height:1.25}
.summary-item p{margin:0;color:var(--text-soft);font-size:.8rem}

.card__title{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.card__title h3{margin:0 0 4px;font-size:1.05rem}
.card__title p{margin:0;color:var(--text-soft);font-size:.84rem}
.notice,.revision-note{padding:11px 12px;border-radius:14px;background:#f8fbfe;border:1px solid #e2ebf4;color:var(--text-soft);font-size:.82rem}
.mensaje{min-height:20px;margin-top:12px;font-size:.82rem;color:var(--text-soft)}
.mensaje:not(:empty){padding:10px 12px;border-radius:12px;background:#f8fbfe;border:1px solid #e2ebf4}
.mensaje.ok{color:var(--success);background:var(--success-soft);border-color:#cfe6dc}
.mensaje.error{color:var(--danger);background:var(--danger-soft);border-color:#ebd3d3}

.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.field{display:grid;gap:6px}
.field--full{grid-column:1/-1}
label{font-size:.79rem;font-weight:700;color:var(--text)}
input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:12px;padding:11px 12px;color:var(--text);outline:none;transition:.18s ease}
input:focus,select:focus,textarea:focus{border-color:#b9cbe0;box-shadow:0 0 0 3px rgba(31,79,143,.08)}
.actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px;flex-wrap:wrap}
.muted-text{color:var(--text-soft);font-size:.8rem}

/* Index */
body.portal-body{background:linear-gradient(180deg,#eef4fa 0%,#edf2f7 100%)}
.portal-shell{padding-top:6px}
.portal-single{display:grid;grid-template-columns:1.04fr .96fr;gap:14px;align-items:start}
.portal-panel{padding:18px 18px 16px}
.portal-panel h2{margin:0 0 8px;font-size:1.35rem;letter-spacing:-.03em}
.portal-panel p{margin:0;color:var(--text-soft);font-size:.84rem}
.portal-tabs{display:inline-flex;gap:8px;background:#eef4fa;border:1px solid #dce6f0;border-radius:14px;padding:5px;margin:14px 0 12px}
.tab-btn{min-height:34px;padding:0 14px;background:transparent;border-color:transparent;color:var(--text-soft)}
.tab-btn.is-active{background:#fff;border-color:#d1deeb;color:var(--primary-strong);box-shadow:var(--shadow-sm)}
.portal-form-card{padding:16px;border-radius:18px;background:#fbfdff;border:1px solid #e2ebf4}
.form-section[hidden]{display:none!important}
.portal-aside{display:grid;gap:12px}
.portal-mini-list{display:grid;gap:10px}
.portal-mini-item{display:grid;grid-template-columns:30px 1fr;gap:10px;padding:11px 12px;border:1px solid #e2ebf4;border-radius:16px;background:#fbfdff}
.portal-mini-item span{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-weight:700}
.portal-mini-item strong{display:block;font-size:.9rem;margin-bottom:2px}
.portal-mini-item p{margin:0;color:var(--text-soft);font-size:.79rem}
.portal-note{padding:14px 15px;border-radius:18px;background:linear-gradient(180deg,#fff 0%,#f6fafe 100%);border:1px solid #dce8f3}
.portal-note strong{display:block;margin-bottom:5px;font-size:.92rem}

/* Licencias */
.card--licencias{padding-bottom:16px}
.licencias-toolbar{display:grid;grid-template-columns:36px 1fr 36px;gap:10px;align-items:center;margin-bottom:12px}
.toolbar-text{margin:0;color:var(--text-soft);font-size:.8rem}
.scroll-btn{padding:0;font-size:1rem;border-radius:12px}
.licencias-scroller{overflow:auto;padding-bottom:2px}
.licencias-track{display:flex;gap:12px;min-height:100%}
.licencia-card{min-width:280px;max-width:280px;display:flex;flex-direction:column;justify-content:space-between;gap:12px;padding:14px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,#fff 0%,#f9fbfe 100%);box-shadow:var(--shadow-sm)}
.licencia-card__header,.licencia-card__footer{display:flex;align-items:center;justify-content:space-between;gap:8px}
.licencia-card__code{display:inline-flex;padding:5px 9px;border-radius:10px;background:var(--primary-soft);color:var(--primary);font-weight:700;font-size:.8rem}
.licencia-card__status{display:inline-flex;padding:5px 8px;border-radius:999px;font-size:.72rem;font-weight:700}
.licencia-card__status.ok{background:var(--success-soft);color:var(--success)}
.licencia-card__status.off{background:#f2f5f8;color:#7d8a98}
.licencia-card h4{margin:0 0 6px;font-size:1rem}
.licencia-card p{margin:0;color:var(--text-soft);font-size:.82rem;line-height:1.5}
.licencia-card--disabled{opacity:.78}
.licencia-card__btn{font-size:.82rem;padding:0 12px}

/* Cita */
.cita-summary{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:0!important;margin:14px 0}

/* Documentos */
.documentos-status,.revision-status-panel{display:grid;gap:4px;min-width:180px;padding:12px 14px;border-radius:16px;background:#fbfdff;border:1px solid #e2ebf4}
.documentos-status__label,.revision-status-panel__label,.documentos-hero__label,.revision-box__label{font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--text-soft)}
.documentos-hero{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:12px}
.documentos-hero__item,.revision-box{padding:13px 14px;border-radius:16px;background:#fbfdff;border:1px solid #e2ebf4}
.documentos-hero__item strong,.revision-box strong{display:block;margin-top:5px;font-size:.95rem}
.documentos-hero__item p,.revision-box p{margin:4px 0 0;color:var(--text-soft);font-size:.8rem}
.documentos-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}
.documento-item{padding:14px;border-radius:18px;background:#fff;border:1px solid var(--line);display:grid;gap:10px;box-shadow:var(--shadow-sm)}
.documento-item__top{display:flex;justify-content:space-between;align-items:center}
.documento-item__icon{font-size:1rem;color:var(--primary)}
.documento-item h4{margin:0 0 4px;font-size:.96rem}
.documento-item p{margin:0;color:var(--text-soft);font-size:.8rem}
.documento-item__tag.is-required{background:var(--warn-soft);color:var(--warn);border-color:#f0e0a7}
.documento-item__tag.is-optional{background:#f2f5f8;color:#6d7d8e;border-color:#dde6ee}
.documento-upload{display:grid;gap:6px;padding:12px;border:1px dashed #cad7e5;border-radius:14px;background:#fbfdff}
.documento-upload input{padding:0;border:none;background:transparent}
.documento-upload__button{font-weight:700;color:var(--primary-strong)}
.documento-upload__hint{font-size:.75rem;color:var(--text-soft)}
.documento-file-state{padding:10px 11px;border-radius:12px;font-size:.78rem;border:1px solid #e2ebf4;background:#f9fbfd;color:var(--text-soft)}
.documento-file-state.ok{background:var(--success-soft);border-color:#d2e7de;color:var(--success)}
.documento-file-state.empty{background:#f9fbfd}
.actions--documentos{margin-top:16px}

/* Revision */
.revision-card__title{align-items:stretch}
.revision-badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 12px;border-radius:999px;font-size:.76rem;font-weight:700;border:1px solid #d9e4ef;background:#f4f7fa;color:#617487;white-space:nowrap}
.revision-badge--pending{background:#f2f5f8;color:#627386}
.revision-badge--review{background:var(--primary-soft);color:var(--primary)}
.revision-badge--ok{background:var(--success-soft);color:var(--success)}
.revision-badge--warn{background:var(--warn-soft);color:var(--warn)}
.revision-overview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:12px}
.revision-box--accent{background:linear-gradient(180deg,#fff 0%,#f6fafe 100%)}
.revision-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.revision-panel{padding:14px;border-radius:18px;background:#fbfdff;border:1px solid #e2ebf4}
.revision-panel__head{margin-bottom:12px}
.revision-panel__head h4{margin:0 0 3px;font-size:.94rem}
.revision-panel__head p{margin:0;color:var(--text-soft);font-size:.8rem}
.revision-timeline{display:grid;gap:12px}
.revision-step{display:grid;grid-template-columns:14px 1fr;gap:10px;align-items:start}
.revision-step__dot{width:14px;height:14px;border-radius:50%;border:2px solid #cdd9e6;background:#fff;margin-top:3px}
.revision-step strong{display:block;margin-bottom:2px;font-size:.86rem}
.revision-step p{margin:0;color:var(--text-soft);font-size:.79rem}
.revision-step.is-active .revision-step__dot,.revision-step.is-done .revision-step__dot{background:var(--primary);border-color:var(--primary)}
.revision-observacion{padding:13px;border-radius:14px;background:#fff;border:1px solid var(--line);min-height:104px;color:var(--text-soft)}
.revision-docs{display:grid;gap:10px}
.revision-doc{display:grid;grid-template-columns:40px 1fr auto;gap:10px;align-items:center;padding:12px;border-radius:16px;border:1px solid var(--line);background:#fff}
.revision-doc__icon{width:40px;height:40px;border-radius:12px;background:var(--primary-soft);display:grid;place-items:center;color:var(--primary);font-size:1rem}
.revision-doc__body strong{display:block;margin-bottom:3px;font-size:.9rem}
.revision-doc__body p{margin:0;color:var(--text-soft);font-size:.78rem}
.revision-doc__status{display:inline-flex;padding:6px 8px;border-radius:999px;background:#f1f4f7;color:#617487;font-size:.72rem;font-weight:700}
.revision-doc--empty{grid-template-columns:1fr!important}
.admin-doc__actions{display:flex;align-items:center;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.admin-link{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--primary-strong);font-weight:700;font-size:.78rem}

/* Funcionario login */
.admin-login-body{display:grid;place-items:center;min-height:100vh;padding:16px;background:linear-gradient(180deg,#eef4fa 0%,#edf2f7 100%)}
.admin-login-shell{width:100%;max-width:420px}
.admin-login-card{position:relative;padding:18px;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-md)}
.admin-login-topbar{margin-bottom:14px}
.admin-login-back{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 11px;border-radius:999px;background:#f5f8fb;border:1px solid #dde8f1;color:var(--text-soft);font-size:.8rem;font-weight:700}
.admin-login-card__brand{text-align:center;margin-bottom:16px}
.admin-login-brandmark{width:70px;height:70px;margin:0 auto 12px;border-radius:20px;border:1px solid var(--line);display:grid;place-items:center;background:#fbfdff}
.admin-login-brandmark__logo{width:50px;height:50px;border-radius:14px;object-fit:contain}
.admin-login-card__brand h1{margin:0 0 8px;font-size:1.45rem;letter-spacing:-.04em}
.admin-login-card__brand p{margin:0;color:var(--text-soft);font-size:.84rem}
.admin-login-form{display:grid;gap:12px}
.input-wrap{position:relative}
.input-wrap i{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:#8696a8;font-size:.88rem}
.input-wrap input{padding-left:39px}

/* Funcionario panel */
body.admin-app{background:linear-gradient(180deg,#eef4fa 0%,#edf2f7 100%)}
.topbar-pro{height:68px;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 18px;position:sticky;top:0;z-index:25;backdrop-filter:blur(10px)}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:12px}
.topbar-logo{max-height:42px;max-width:150px;object-fit:contain}
.topbar-user{font-weight:700;color:#eef4fa;font-size:.9rem}
.layout-pro{display:grid;grid-template-columns:220px minmax(0,1fr);min-height:calc(100vh - 68px)}
.sidebar-pro{padding:16px 12px;background:linear-gradient(180deg,#f7fbff 0%,#eff4f9 100%);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
.side-item{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:14px;color:var(--text-soft);font-weight:700;font-size:.84rem}
.side-item .icon{width:28px;height:28px;border-radius:10px;display:grid;place-items:center;background:#fff;border:1px solid #dde8f2;color:var(--primary)}
.side-item.active,.side-item:hover{background:#fff;border:1px solid #dde8f2;color:var(--primary-strong)}
.content-pro{padding:18px}
.admin-hero-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}
.admin-hero-card{padding:13px 14px;border-radius:16px;background:#fbfdff;border:1px solid #e2ebf4}
.admin-hero-card span{display:block;color:var(--text-soft);font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.admin-hero-card strong{display:block;font-size:1.35rem;line-height:1;color:var(--primary-strong);margin-bottom:4px}
.admin-hero-card p{margin:0;color:var(--text-soft);font-size:.77rem}
.filtros-box{margin-bottom:10px}
.funcionario-filtros-row{display:grid;grid-template-columns:180px minmax(0,1fr) auto;gap:10px;padding:12px;border:1px solid #e2ebf4;border-radius:16px;background:#fbfdff}
.filtro{display:grid;gap:6px}
.filtro-busqueda-wide{min-width:0}
.acciones-filtro{display:flex;align-items:end;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.tabla-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff}
.tabla-pro{width:100%;border-collapse:separate;border-spacing:0}
.tabla-pro th{padding:12px 12px;background:#f7fafc;border-bottom:1px solid var(--line);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:var(--text-soft);text-align:left}
.tabla-pro td{padding:13px 12px;border-bottom:1px solid #edf2f7;font-size:.84rem;vertical-align:middle}
.tabla-pro tbody tr:hover{background:#fbfdff}
.tabla-pro strong{display:block;font-size:.9rem}
.tabla-pro small{display:block;margin-top:3px;color:var(--text-soft);font-size:.76rem}
.admin-table-empty,.admin-empty{text-align:center;padding:24px 16px;color:var(--text-soft)}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(20,40,70,.16);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;padding:18px;z-index:60}
.modal-overlay.is-open{display:flex!important}
.funcionario-modal-card{width:min(920px,100%);max-height:min(88vh,860px);overflow:hidden;display:flex;flex-direction:column;border-radius:24px}
.modal-header{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:#fff}
.modal-inc-chip-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.inc-chip-code{background:#f2f5f8;color:var(--text-soft)}
.modal-title{margin:0;font-size:1.35rem;letter-spacing:-.03em}
.modal-close{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--text-soft);font-size:1rem}
.modal-body{padding:20px;overflow:auto;background:#fbfdff}
.admin-detail-head-pro{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.admin-detail-head-pro h3{margin:0 0 4px;font-size:1.25rem}
.admin-detail-grid-pro{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0 0 14px!important}
.admin-form-grid{grid-template-columns:1fr}
.actions--admin-form{justify-content:space-between}

@media (max-width:980px){
  .hero-split,.portal-single,.cita-layout,.revision-grid,.documentos-grid,.admin-detail-grid-pro,.documentos-hero,.revision-overview{grid-template-columns:1fr}
  .progress-card{grid-template-columns:1fr}
  .layout-pro{grid-template-columns:88px 1fr}
  .side-item span:last-child{display:none}
  .side-item{justify-content:center}
  .admin-hero-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .funcionario-filtros-row{grid-template-columns:1fr}
  .acciones-filtro{justify-content:flex-start}
}
@media (max-width:720px){
  .top-header__inner,.topbar-pro{padding-left:12px;padding-right:12px}
  .form-grid,.cita-summary{grid-template-columns:1fr}
  .portal-tabs{display:flex;width:100%}
  .tab-btn{flex:1}
  .licencia-card{min-width:250px;max-width:250px}
  .admin-hero-grid{grid-template-columns:1fr}
  .tabla-pro{min-width:760px}
}
@media (max-width:560px){
  body{font-size:13px}
  .page{padding-left:10px;padding-right:10px}
  .brand__text h1{font-size:1.05rem}
  .hero-card h2,.portal-panel h2,.modal-title{font-size:1.15rem}
  .top-header__inner{padding:11px 12px;align-items:flex-start;flex-direction:column}
  .button-secondary{width:100%}
  .progress-steps{overflow:auto;grid-template-columns:repeat(5,58px);padding-bottom:4px}
  .funcionario-modal-card{max-height:92vh}
  .modal-body,.modal-header{padding:14px}
}

:root{
  --container: 1080px;
  --radius-sm: 9px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --shadow-sm: 0 10px 24px rgba(15, 23, 42, .05);
  --shadow-md: 0 16px 34px rgba(15, 23, 42, .07);
}
body{font-size:13.5px}
.top-header{padding:10px 12px 4px}
.top-header__inner{max-width:1080px;padding:11px 14px;border-radius:16px}
.brand__logo{width:48px;height:48px;border-radius:12px}
.brand__text h1{font-size:1.15rem}
.brand__text p{font-size:.79rem}
.page{max-width:1080px;padding:8px 12px 20px}
.page--compact{max-width:860px}
.card,.panel-pro,.resume-card,.hero-card,.modal-card{border-radius:18px}
.card,.panel-pro{padding:15px}
.button-secondary,.btn-mini,.licencia-card__btn,.scroll-btn,.ghost-btn,.tab-btn,button[type="submit"],#btnActualizarEstado,#finalizar,#guardarCita,#btnLoginFuncionario{
  min-height:34px;
  padding:0 12px;
  border-radius:10px;
  background:linear-gradient(180deg,#ffffff 0%, #f5f8fb 100%);
  color:#24466c;
  border:1px solid #d9e3ee;
  box-shadow:none;
}
.button-secondary:hover,.btn-mini:hover,.licencia-card__btn:hover,.scroll-btn:hover,.ghost-btn:hover,.tab-btn:hover,button[type="submit"]:hover,#btnActualizarEstado:hover,#finalizar:hover,#guardarCita:hover,#btnLoginFuncionario:hover{
  background:#ffffff;
  border-color:#c8d5e2;
  transform:none;
}
.small-badge,.card__badge,.inc-chip,.resume-card__badge,.hero-chip,.licencia-chip,.documento-item__tag,.revision-doc__status{
  font-size:.68rem;
  min-height:24px;
  padding:0 9px;
  border-radius:999px;
}
.progress-card{grid-template-columns:1fr 220px;gap:10px;padding:13px 15px;margin-bottom:12px}
.progress-card--simple{grid-template-columns:1fr}
.progress-header h2{font-size:.93rem}
.progress-header p{font-size:.78rem}
.progress-line{top:14px;height:2px}
.step__circle{width:28px;height:28px;font-size:.72rem}
.step span{font-size:.7rem}
.summary-item{padding:12px 13px;border-radius:14px}
.summary-item strong{font-size:.9rem}
.summary-item p{font-size:.78rem}
.portal-shell{display:block}
.portal-single{display:block}
.portal-panel--single{max-width:860px;margin:0 auto}
.portal-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}
.portal-panel h2{margin:6px 0 0;font-size:1.2rem}
.portal-tabs{margin:0;padding:4px;border-radius:12px}
.tab-btn{min-height:32px;font-size:.8rem}
.portal-form-card--single{padding:14px;border-radius:16px;background:#fbfdff;border:1px solid #e2ebf4}
.form-grid{gap:10px}
label{font-size:.77rem}
input,select,textarea{min-height:38px;padding:0 11px;border-radius:10px;font-size:.84rem}
textarea{padding:10px 11px;min-height:96px}
.notice{padding:10px 11px;border-radius:12px;font-size:.78rem}
.actions{margin-top:0;gap:10px}
.muted-text{font-size:.76rem}
.mensaje{font-size:.79rem}
.portal-aside,.portal-note{display:none!important}
.licencias-toolbar{gap:10px;padding:10px 12px}
.toolbar-text{font-size:.77rem}
.licencias-scroller{padding:4px 0 2px}
.licencias-track{gap:12px}
.licencia-card{min-width:255px;max-width:255px;padding:14px;border-radius:16px}
.licencia-card h4{font-size:.95rem}
.licencia-card p{font-size:.77rem}
.cita-layout,.documentos-grid,.revision-grid{gap:10px}
.cita-panel,.revision-panel,.documento-item,.documentos-hero__item,.revision-box{padding:12px;border-radius:14px}
.horas--grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}
.hora-btn{min-height:34px;border-radius:10px;font-size:.8rem}
.documentos-hero{gap:10px;margin-bottom:10px}
.documento-item__top{margin-bottom:0}
.documento-upload{padding:10px;border-radius:12px}
.documento-file-state{font-size:.75rem}
.revision-overview{gap:10px}
.revision-step strong{font-size:.83rem}
.revision-step p,.revision-panel__head p{font-size:.77rem}
.revision-observacion{min-height:88px}
.topbar-pro{height:62px;padding:0 14px}
.layout-pro{grid-template-columns:210px 1fr;min-height:calc(100vh - 62px)}
.sidebar-pro{padding:14px 10px}
.side-item{padding:10px 11px;border-radius:12px;font-size:.8rem}
.side-item .icon{width:26px;height:26px;border-radius:9px}
.content-pro{padding:14px}
.content-pro--admin{display:grid;gap:12px}
.admin-page-head{padding:14px 15px}
.admin-page-head h1{margin:6px 0 4px;font-size:1.2rem}
.admin-page-head p{margin:0;color:var(--text-soft);font-size:.8rem}
.panel-pro--tight{padding:12px 14px}
.admin-hero-grid{gap:8px}
.admin-hero-card{padding:12px;border-radius:14px}
.admin-hero-card strong{font-size:1.18rem}
.admin-hero-card p{font-size:.72rem}
.funcionario-filtros-row{grid-template-columns:160px minmax(0,1fr) auto;padding:10px;border-radius:14px;gap:8px}
.acciones-filtro{gap:6px}
.tabla-wrap--soft{border-radius:16px}
.tabla-pro th{padding:11px 10px;font-size:.7rem}
.tabla-pro td{padding:11px 10px;font-size:.8rem}
.btn-ver{min-width:94px}
.modal-overlay{padding:14px;background:rgba(15, 23, 42, .22)}
.funcionario-modal-card{width:min(860px,100%);max-height:min(88vh,820px);border-radius:22px}
.modal-header{padding:15px 16px}
.modal-title{font-size:1.15rem}
.modal-close{width:34px;height:34px;border-radius:10px}
.modal-body--admin{padding:16px;background:#f8fbfe}
.detail-shell{display:grid;gap:12px}
.detail-summary-row{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);gap:12px;align-items:start}
.detail-id-card,.detail-mini-card,.detail-section{background:#fff;border:1px solid #dde7f0;border-radius:16px;box-shadow:var(--shadow-sm)}
.detail-id-card{padding:15px}
.detail-id-card__top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.detail-id-card h3{margin:0 0 5px;font-size:1.15rem;line-height:1.15}
.detail-id-card p{margin:0;color:var(--text-soft);font-size:.8rem}
.detail-mini-grid{display:grid;gap:10px}
.detail-mini-card{padding:13px}
.detail-mini-card span{display:block;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--text-soft);margin-bottom:6px}
.detail-mini-card strong{display:block;font-size:.95rem;margin-bottom:3px}
.detail-mini-card p{margin:0;color:var(--text-soft);font-size:.77rem}
.detail-section{padding:14px}
.detail-section__head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.detail-section__head h4{margin:0 0 3px;font-size:.95rem}
.detail-section__head p{margin:0;color:var(--text-soft);font-size:.77rem}
.doc-order-list{display:grid;gap:9px}
.doc-order-item{display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:10px;align-items:start;padding:11px 12px;border:1px solid #e3ebf3;border-radius:14px;background:#fbfdff}
.doc-order-item__index{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:#edf3fa;color:#24466c;font-weight:700;font-size:.8rem}
.doc-order-item__head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.doc-order-item__head strong{font-size:.85rem}
.doc-order-item__main p{margin:0;color:var(--text-soft);font-size:.76rem;line-height:1.45}
.doc-order-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:7px;font-size:.75rem;color:var(--text-soft)}
.doc-order-status{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;font-weight:700;text-transform:capitalize}
.doc-order-status.is-ok{background:#edf5ef;color:#2d6a54}
.doc-order-status.is-empty{background:#f3f5f7;color:#66788b}
.doc-order-pill{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;font-size:.68rem;font-weight:700}
.doc-order-pill.is-required{background:#fff6de;color:#8b6700}
.doc-order-pill.is-optional{background:#eff3f6;color:#5f7388}
.doc-order-item__action{display:flex;align-items:center;min-height:100%}
.doc-order-empty{padding:14px;border-radius:14px;border:1px dashed #d6e1eb;background:#fbfdff}
.doc-order-empty strong{display:block;margin-bottom:4px}
.doc-order-empty p,.ghost-text{margin:0;color:var(--text-soft);font-size:.77rem}
.detail-section--form .form-grid{gap:10px}
.actions--admin-form{justify-content:space-between}
.admin-empty{padding:22px 16px;color:var(--text-soft)}
.admin-empty__icon{width:42px;height:42px;margin:0 auto 8px;border-radius:14px;display:grid;place-items:center;background:#eef4fa;color:#325981}
@media (max-width: 980px){
  .detail-summary-row{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .portal-panel-head{display:grid;gap:10px}
  .portal-tabs{width:100%}
  .tab-btn{flex:1}
  .layout-pro{grid-template-columns:84px 1fr}
  .side-item span:last-child{display:none}
  .side-item{justify-content:center}
  .funcionario-filtros-row{grid-template-columns:1fr}
  .acciones-filtro{justify-content:flex-start}
  .tabla-pro{min-width:760px}
  .detail-summary-row,.detail-mini-grid{grid-template-columns:1fr}
  .doc-order-item{grid-template-columns:30px 1fr}
  .doc-order-item__action{grid-column:2;justify-content:flex-start}
}
@media (max-width: 560px){
  body{font-size:13px}
  .top-header__inner,.topbar-pro{padding-left:11px;padding-right:11px}
  .button-secondary{width:100%}
  .progress-card,.card,.panel-pro{padding:12px}
  .progress-steps{overflow:auto;grid-template-columns:repeat(5,58px);padding-bottom:4px}
  .funcionario-modal-card{max-height:92vh}
  .modal-header,.modal-body--admin{padding:12px}
  .doc-order-item{padding:10px}
}

.documento-plantilla-box{padding:12px;border-radius:14px;background:var(--primary-soft);border:1px solid #d7e4f1;display:grid;gap:6px}
.documento-plantilla-box strong{font-size:.82rem;color:var(--primary-strong)}
.documento-plantilla-box p{margin:0;color:var(--text-soft);font-size:.77rem}
.documento-plantilla-link{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:10px;border:1px solid #bfd0e4;background:#fff;color:var(--primary-strong);font-weight:700;width:max-content}
.documento-plantilla-link:hover{background:#f8fbfe}

input.is-invalid,
select.is-invalid,
textarea.is-invalid {
  border-color: #d66b6b;
  box-shadow: 0 0 0 3px rgba(163, 72, 72, 0.08);
}

.documentos-hero__item strong,
.detail-mini-card strong,
.revision-box strong,
.summary-item strong {
  overflow-wrap: anywhere;
}


/* Cita compacta */
.page--cita-compacta{max-width:980px}
.cita-card--compacta{padding:18px 18px 16px}
.cita-card__top{margin-bottom:12px}
.cita-card__top h2{margin:6px 0 4px;font-size:1.9rem;line-height:1.05;letter-spacing:-.04em}
.cita-card__top p{margin:0;color:var(--text-soft);font-size:.92rem}
.cita-shell{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:14px;align-items:start}
.cita-main{display:grid;gap:12px}
.cita-aside{display:grid;gap:10px;position:sticky;top:10px}
.cita-panel--compact{padding:14px 14px 12px;border-radius:18px;background:#fbfdff;border:1px solid #e2ebf4}
.cita-panel__head--tight h3{margin:0 0 2px;font-size:1rem}
.cita-panel__head--tight p{margin:0 0 10px;color:var(--text-soft);font-size:.8rem}
.cita-date-input{min-height:40px;padding:10px 12px}
.horas--compact{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.hora-btn{min-height:68px;padding:10px 14px;border-radius:16px;border:1px solid #d8e3ef;background:#fff;color:var(--primary-strong);font-weight:800;font-size:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;line-height:1.05}
.hora-btn::after{content:"Disponible";font-size:.78rem;font-weight:600;color:var(--text-soft)}
.hora-btn.active{background:#eef4ff;border-color:#b8ccec;box-shadow:none}
.hora-btn:disabled,.hora-btn--occupied{background:#f4f6f8;color:#b2bcc8;border-color:#e2e8ef;cursor:not-allowed}
.hora-btn:disabled::after,.hora-btn--occupied::after{content:"Ocupada";color:#b2bcc8}
.actions--cita-compact{margin-top:0;justify-content:space-between;align-items:center}
.actions--cita-compact button{min-height:40px;padding:0 16px}
.cita-resumen-card{padding:14px 14px 12px;border-radius:16px;background:#fbfdff;border:1px solid #e2ebf4}
.cita-resumen-card__label{display:block;margin-bottom:6px;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;font-weight:800;color:var(--primary)}
.cita-resumen-card strong{display:block;font-size:1.1rem;line-height:1.22;color:var(--primary-strong)}

@media (max-width: 900px){
  .page--cita-compacta{max-width:100%;padding-left:12px;padding-right:12px}
  .cita-card--compacta{padding:16px 14px}
  .cita-card__top h2{font-size:1.55rem}
  .cita-shell{grid-template-columns:1fr}
  .cita-aside{position:static;grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width: 640px){
  .cita-card__top h2{font-size:1.35rem}
  .cita-card__top p{font-size:.84rem}
  .cita-panel--compact{padding:12px}
  .horas--compact{grid-template-columns:1fr 1fr;gap:8px}
  .hora-btn{min-height:60px;padding:9px 11px;font-size:.95rem;border-radius:14px}
  .hora-btn::after{font-size:.72rem}
  .cita-aside{grid-template-columns:1fr 1fr;gap:8px}
  .cita-resumen-card{padding:11px 12px}
  .cita-resumen-card strong{font-size:.98rem}
  .actions--cita-compact{flex-direction:column;align-items:stretch}
  .actions--cita-compact .muted-text{text-align:center}
  .actions--cita-compact button{width:100%}
}

/* Documentos - lista simple */
.docs-simple-card{padding:18px}
.docs-simple-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px}
.docs-simple-head h3{margin:6px 0 4px;font-size:1.75rem;line-height:1.1;color:var(--primary-strong)}
.docs-simple-head p{margin:0;color:var(--text-soft)}
.docs-simple-state{min-width:210px;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:#fbfdff}
.docs-simple-state span{display:block;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);margin-bottom:6px}
.docs-simple-state strong{font-size:1.1rem;color:var(--primary-strong)}
.docs-simple-summary{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px;padding:10px 12px;border:1px solid #dbe7f1;background:#fbfdff;border-radius:16px}
.docs-simple-summary__item{display:flex;align-items:center;gap:8px;min-height:36px;padding:8px 12px;border-radius:12px;background:#fff;border:1px solid #e4edf6}
.docs-simple-summary__item span{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft)}
.docs-simple-summary__item strong{font-size:.95rem;color:var(--primary-strong)}
.docs-simple-summary__item--counter strong{font-size:1.02rem}
.docs-simple-tip{margin-bottom:12px;padding:10px 12px;border-radius:14px;background:#f8fbfe;border:1px solid #e2ebf4;color:var(--text-soft);font-size:.86rem}
.docs-list{display:grid;gap:10px}
.docs-row{display:grid;grid-template-columns:56px minmax(0,1.6fr) minmax(250px,.95fr);gap:12px;align-items:center;padding:14px;border:1px solid #dbe7f1;border-radius:18px;background:#fff}
.docs-row__index{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#edf3fb;color:var(--primary);font-weight:800;font-size:1.1rem}
.docs-row__main h4{margin:0 0 6px;font-size:1rem;color:var(--primary-strong)}
.docs-row__main p{margin:0 0 8px;color:var(--text-soft);font-size:.88rem}
.docs-row__title-wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.docs-row__badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:800;border:1px solid transparent}
.docs-row__badge.is-required{background:#fff6dc;color:#946200;border-color:#ecd08d}
.docs-row__badge.is-optional{background:#eef4fa;color:var(--text-soft);border-color:#d8e4ef}
.docs-row__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--text-soft);font-size:.82rem}
.docs-template-link{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:10px;border:1px solid #bfd0e4;background:var(--primary-soft);color:var(--primary-strong);font-weight:700}
.docs-row__upload{display:grid;gap:8px;justify-items:start}
.docs-upload-inline{position:relative;display:flex;align-items:center;gap:10px;min-width:0;width:100%;padding:10px 12px;border:1px dashed #c5d6e8;border-radius:14px;background:#fcfdff;cursor:pointer}
.docs-upload-inline input{position:absolute;inset:0;opacity:0;cursor:pointer}
.docs-upload-inline__button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:10px;border:1px solid #bfd0e4;background:#fff;color:var(--primary-strong);font-weight:700;white-space:nowrap}
.docs-upload-inline__name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--primary-strong);font-weight:600;font-size:.9rem}
.docs-row__status{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:999px;font-size:.82rem;font-weight:700;border:1px solid #d8e4ef;color:var(--text-soft);background:#f7fafd}
.docs-row__status.ok{background:#e9f6f1;border-color:#cfe6dc;color:var(--success)}
.docs-simple-actions{margin-top:12px}

@media (max-width: 900px){
  .docs-simple-head{flex-direction:column}
  .docs-simple-state{min-width:0;width:100%}
  .docs-row{grid-template-columns:44px 1fr}
  .docs-row__upload{grid-column:1 / -1;padding-left:56px}
}
@media (max-width: 640px){
  .docs-simple-card{padding:14px}
  .docs-simple-head h3{font-size:1.35rem}
  .docs-simple-summary{padding:8px}
  .docs-simple-summary__item{width:100%;justify-content:space-between}
  .docs-row{padding:12px;gap:10px;grid-template-columns:1fr}
  .docs-row__index{display:none}
  .docs-row__upload{grid-column:auto;padding-left:0}
  .docs-upload-inline{flex-direction:column;align-items:flex-start}
  .docs-upload-inline__name{white-space:normal;overflow:visible;text-overflow:clip}
}

/* Documentos lista simple compacta */

.page--docs-compact{max-width:980px}
.documentos-simple-card{padding:16px 16px 14px}
.documentos-strip--compact{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:8px 12px}
.documentos-strip--compact .documentos-strip__item strong{font-size:.92rem}
.documentos-helper{padding:9px 12px;font-size:.81rem}
.documentos-simple-list{gap:8px}
.doc-row{grid-template-columns:40px minmax(0,1.4fr) minmax(220px,.8fr);gap:12px;padding:12px 14px;border-radius:16px}
.doc-row__index{width:38px;height:38px;border-radius:13px;font-size:.95rem}
.doc-row__main{gap:6px}
.doc-row__head h4{font-size:.98rem;margin:0 0 3px}
.doc-row__head p{font-size:.8rem}
.doc-row__meta{gap:8px}
.doc-row__template{min-height:32px;padding:0 11px;font-size:.84rem}
.doc-row__formats{font-size:.75rem}
.doc-row__upload{gap:6px}
.doc-upload-box{min-height:54px;padding:8px 12px;gap:10px;border-radius:15px}
.doc-upload-box__button{min-height:34px;padding:0 12px;font-size:.86rem}
.doc-upload-box__name{font-size:.86rem}
.doc-row__status{padding:5px 11px;font-size:.74rem}
.actions--documentos-simple{margin-top:12px}
@media (max-width: 1080px){.page--docs-compact{max-width:920px}}

.documentos-simple-card{padding:18px}
.documentos-simple-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}
.documentos-simple-head h3{margin:6px 0 4px;font-size:1.55rem;line-height:1.05;letter-spacing:-.04em}
.documentos-simple-head p{margin:0;color:var(--text-soft)}
.documentos-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:10px 12px;border:1px solid #dbe6f0;border-radius:16px;background:#fbfdff;margin-bottom:12px}
.documentos-strip__item{display:grid;gap:3px;min-width:0}
.documentos-strip__item span{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;font-weight:800;color:var(--text-soft)}
.documentos-strip__item strong{font-size:.96rem;line-height:1.2;color:var(--primary-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.documentos-helper{padding:10px 12px;border-radius:14px;background:var(--primary-soft);border:1px solid #d8e3ef;color:var(--text-soft);font-size:.83rem;margin-bottom:12px}
.documentos-helper strong{color:var(--primary-strong)}
.documentos-simple-list{display:grid;gap:10px}
.doc-row{display:grid;grid-template-columns:42px minmax(0,1.5fr) minmax(260px,.95fr);gap:14px;align-items:center;padding:14px 16px;border-radius:18px;border:1px solid #dbe6f0;background:#fff;box-shadow:var(--shadow-sm)}
.doc-row__index{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#eef4fb;color:var(--primary);font-weight:800}
.doc-row__main{min-width:0;display:grid;gap:8px}
.doc-row__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.doc-row__head h4{margin:0 0 4px;font-size:1rem;line-height:1.2}
.doc-row__head p{margin:0;color:var(--text-soft);font-size:.83rem}
.doc-row__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.doc-row__formats{font-size:.78rem;color:var(--text-soft)}
.doc-row__template{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:999px;background:#fff;border:1px solid #bfd0e4;color:var(--primary-strong);font-weight:700}
.doc-row__template:hover{background:#f7fbff}
.doc-row__upload{display:grid;gap:8px;justify-items:end}
.doc-upload-box{display:flex;align-items:center;gap:10px;min-width:100%;padding:10px 12px;border:1px dashed #cad7e5;border-radius:16px;background:#fbfdff;cursor:pointer}
.doc-upload-box input{display:none}
.doc-upload-box__button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:10px;background:#fff;border:1px solid #c8d6e6;color:var(--primary-strong);font-weight:700;flex:0 0 auto}
.doc-upload-box__name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);font-size:.82rem;font-weight:600}
.doc-row__status{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;border:1px solid #d8e3ef;background:#f7fafc;color:#5f748b;font-size:.76rem;font-weight:700}
.doc-row__status.is-ok{background:var(--success-soft);border-color:#d4e7df;color:var(--success)}
.actions--documentos-simple{margin-top:14px}
.actions--documentos-simple .muted-text{font-size:.82rem}

@media (max-width: 980px){
  .documentos-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .page--docs-compact{max-width:100%}
  .doc-row{grid-template-columns:38px 1fr;align-items:start}
  .doc-row__upload{grid-column:2;justify-items:stretch}
}

@media (max-width: 640px){
  .documentos-simple-card{padding:14px}
  .documentos-simple-head h3{font-size:1.28rem}
  .documentos-strip{grid-template-columns:1fr;padding:10px}
  .page--docs-compact{max-width:100%}
  .doc-row{grid-template-columns:1fr;padding:12px;gap:10px}
  .doc-row__index{width:34px;height:34px;border-radius:12px;font-size:.92rem}
  .doc-row__head{flex-direction:column;align-items:flex-start;gap:8px}
  .doc-upload-box{flex-direction:column;align-items:flex-start}
  .doc-upload-box__name{white-space:normal;overflow:visible;text-overflow:clip}
  .doc-row__upload{grid-column:auto}
}

/* ===== Panel funcionario renovación ===== */
.admin-app--renewal{background:linear-gradient(180deg,#eff5fb 0%,#edf2f7 100%)}
.topbar-pro--renewal{position:sticky;top:0;z-index:20;background:rgba(19,42,74,.96);backdrop-filter:blur(12px)}
.topbar-copy{display:grid;gap:2px;color:#fff}
.topbar-kicker{font-size:11px;letter-spacing:.08em;text-transform:uppercase;opacity:.72}
.sidebar-pro--renewal{padding-top:18px}
.panel-pro--renewal,.panel-pro--renewal-filters,.panel-pro--agenda,.panel-pro--boards,.panel-pro--table{border-radius:20px;box-shadow:0 16px 38px rgba(16,45,80,.06)}
.panel-pro--renewal,.panel-pro--renewal-filters,.panel-pro--agenda,.panel-pro--boards,.panel-pro--table{padding:14px}
.panel-pro--renewal h1{margin:4px 0 2px;font-size:1.45rem}
.panel-pro--renewal-stats .admin-hero-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}
.panel-pro--renewal-stats .admin-hero-card{padding:12px 10px;border-radius:16px}
.panel-pro--renewal-stats .admin-hero-card strong{font-size:1.2rem}
.filtros-box--renewal{background:linear-gradient(180deg,#f9fbfe 0%,#f2f7fc 100%);border-radius:18px;border:1px solid #dfe9f3;padding:12px}
.funcionario-filtros-row--renewal{display:grid;grid-template-columns:160px 160px 170px minmax(240px,1fr) auto;gap:10px;align-items:end}
.estado-tabs,.agenda-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.estado-tab,.agenda-tab{border:1px solid #cfdae7;background:#fff;border-radius:999px;padding:8px 12px;font-weight:700;color:var(--text-soft);font-size:.8rem}
.estado-tab.is-active,.estado-tab:hover,.agenda-tab.is-active,.agenda-tab:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.panel-title--split{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:10px}
.panel-title--split h3{margin:4px 0 0;font-size:1rem;color:var(--primary-strong)}
.panel-title--compact-slim{margin-bottom:8px}
.agenda-timeline{display:grid;gap:10px;margin-top:12px}
.agenda-item{display:grid;grid-template-columns:126px 1fr;gap:12px;padding:12px;border-radius:16px;background:linear-gradient(180deg,#fff 0%,#f8fbfe 100%);border:1px solid #dce6f0}
.agenda-item--done{background:linear-gradient(180deg,#f4fbf7 0%,#eef8f2 100%);border-color:#cfe4d7}
.agenda-item__hour{display:grid;align-content:center;gap:4px;padding:10px;border-radius:14px;background:#f3f7fb;border:1px solid #dde7f0;text-align:center}
.agenda-item__hour strong{font-size:1.05rem;color:var(--primary-strong)}
.agenda-item__hour span{text-transform:capitalize;color:var(--text-soft);font-size:.75rem}
.agenda-item__body{display:grid;gap:10px}
.agenda-item__top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.agenda-item__top h4{margin:0 0 2px;font-size:.96rem}
.agenda-item__top p{margin:0;color:var(--text-soft);font-size:.8rem}
.agenda-item__badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}
.agenda-item__meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--text-soft);font-size:.76rem}
.agenda-item__actions{display:flex;flex-wrap:wrap;gap:8px}
.admin-attention{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;background:#eef3f8;border:1px solid #d9e3ee;color:var(--text-soft);font-size:.7rem;font-weight:700}
.admin-attention.is-done{background:var(--success-soft);border-color:#cfe6dc;color:var(--success)}
.admin-attention--muted{background:#f3f5f8;color:#8a97a6}
.btn-atender.is-done{background:var(--success-soft);border-color:#cfe6dc;color:var(--success)}
.estado-board-grid{display:grid;grid-template-columns:repeat(5,minmax(180px,1fr));gap:10px;align-items:start}
.estado-board{display:grid;gap:8px;min-height:100%}
.estado-board__head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 2px}
.estado-board__head h4{margin:0;font-size:.86rem}
.estado-board__count{display:inline-flex;min-width:28px;height:28px;align-items:center;justify-content:center;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-weight:700;font-size:.78rem}
.estado-board__list{display:grid;gap:8px}
.board-card{padding:11px;border-radius:16px;background:#fff;border:1px solid #dce6f0;box-shadow:none;display:grid;gap:8px}
.board-card--done{background:linear-gradient(180deg,#f5fbf6 0%,#edf7ef 100%);border-color:#d6e8d7}
.board-card__top,.board-card__actions,.board-card__meta{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.board-card__id{font-weight:700;color:var(--primary-strong);font-size:.8rem}
.board-card h4{margin:0;font-size:.88rem}
.board-card p{margin:0;color:var(--text-soft);font-size:.77rem}
.board-card__meta{justify-content:flex-start;color:var(--text-soft);font-size:.74rem}
.board-empty,.admin-table-empty{padding:12px;border-radius:16px;background:#f8fbfe;border:1px dashed #c9d7e4;text-align:center}
.board-empty--compact{padding:14px}
.board-empty strong,.admin-table-empty strong{display:block;margin-bottom:4px}
.table-actions-stack{display:flex;flex-direction:column;gap:6px}
.funcionario-modal-card--wide{max-width:980px;width:min(980px,calc(100vw - 28px))}
.detail-shell--renewal{display:grid;gap:14px}
.detail-summary-row--renewal{grid-template-columns:1.05fr .95fr}
.admin-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:1200px){
  .funcionario-filtros-row--renewal{grid-template-columns:repeat(2,minmax(0,1fr))}
  .panel-pro--renewal-stats .admin-hero-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .estado-board-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:860px){
  .agenda-item{grid-template-columns:1fr}
  .agenda-item__top,.panel-title--split{flex-direction:column;align-items:flex-start}
  .estado-board-grid{grid-template-columns:1fr}
  .panel-pro--renewal-stats .admin-hero-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-form-grid{grid-template-columns:1fr}
  .funcionario-modal-card--wide{width:min(100vw - 18px,980px)}
}

/* === Agenda compacta solo citas === */
body.admin-app--agenda-only{background:linear-gradient(180deg,#eef4fa 0%,#edf2f7 100%)}
.topbar-pro--agenda-only{height:58px;padding:0 12px}
.topbar-pro--agenda-only .topbar-logo{width:34px;height:34px;border-radius:10px}
.topbar-pro--agenda-only .topbar-copy strong{font-size:.98rem}
.topbar-pro--agenda-only .topbar-kicker{font-size:.62rem}
.topbar-pro--agenda-only .topbar-user{font-size:.82rem}
.agenda-page-shell{max-width:1020px;margin:0 auto;padding:12px}
.agenda-panel--compacta{padding:12px 12px 10px;border-radius:18px}
.agenda-panel__head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}
.agenda-panel__head h2{margin:4px 0 0;font-size:1.08rem;letter-spacing:-.03em}
.agenda-tabs--compact{gap:7px;margin-top:0;margin-bottom:10px}
.agenda-tabs--compact .agenda-tab{padding:7px 12px;font-size:.76rem;border-radius:999px}
.agenda-mensaje{min-height:0;margin:0 0 10px;font-size:.76rem}
.agenda-mensaje:not(:empty){padding:8px 10px;border-radius:12px}
.agenda-timeline--compact{gap:8px;margin-top:0}
.agenda-item--compact{grid-template-columns:116px 1fr;gap:10px;padding:10px 12px;border-radius:16px}
.agenda-item__hour--compact{padding:8px;border-radius:14px;gap:3px}
.agenda-item__hour--compact strong{font-size:1rem;line-height:1.05}
.agenda-item__hour--compact span{font-size:.72rem;line-height:1.25}
.agenda-item__body--compact{gap:8px}
.agenda-item__top--compact h4{font-size:.92rem;margin:0 0 1px}
.agenda-item__top--compact p{font-size:.78rem}
.agenda-item__badges--compact{gap:5px}
.agenda-item__meta--compact{gap:8px;font-size:.74rem}
.agenda-item__actions--compact{gap:7px}
.agenda-item__actions--compact .btn-mini,.agenda-item__actions--compact .admin-attention{min-height:32px;font-size:.72rem;padding:0 11px}
.admin-attention{display:inline-flex;align-items:center;justify-content:center;padding:0 10px;min-height:32px;border-radius:999px;background:#f1f5f9;border:1px solid #d9e4ef;color:var(--text-soft);font-size:.72rem;font-weight:700}
.admin-attention.is-done{background:#eaf7ef;border-color:#cce4d6;color:var(--success)}
.admin-attention--muted{background:#f4f7fa;color:#8190a1}
.btn-atender.is-done{background:#f6fbf7;border-color:#cde3d4;color:var(--success)}
.funcionario-modal-card--compact{width:min(820px,100%);max-height:min(90vh,760px);border-radius:20px}
.modal-header--compact{padding:13px 14px}
.modal-body--compact{padding:14px;background:#f7fbfe}
.modal-title{font-size:1.05rem}
.admin-detail-flow--compact{gap:10px}
.admin-detail-head-pro--compact{margin-bottom:10px}
.detail-hero-card--compact{padding:12px;border-radius:16px}
.detail-hero-card--compact h3{font-size:1rem;margin:10px 0 3px}
.detail-mini-grid--compact{gap:8px}
.detail-mini-grid--compact .detail-mini-card{padding:12px;border-radius:14px}
.detail-mini-grid--compact .detail-mini-card strong{font-size:.95rem}
.detail-mini-grid--compact .detail-mini-card p{font-size:.76rem}
.detail-section--compact{padding:12px;border-radius:16px}
.detail-section__head--compact{margin-bottom:10px}
.detail-section__head--compact h4{font-size:.95rem}
.detail-section__head--compact p{font-size:.76rem}
.admin-doc-row--compact{padding:10px;border-radius:14px;grid-template-columns:36px 1fr auto;gap:10px}
.admin-doc-row--compact .admin-doc-row__index{width:36px;height:36px;font-size:.82rem}
.admin-doc-row--compact .admin-doc-row__head h5{font-size:.9rem;margin:0 0 4px}
.admin-doc-row--compact .admin-doc-row__head p{font-size:.75rem}
.admin-doc-row--compact .admin-doc-row__footer{font-size:.73rem;gap:8px}
.admin-form-grid--compact{gap:10px}
.admin-form-grid--compact textarea{min-height:96px}
.actions--admin-form-compact button{min-height:36px}
.agenda-empty{padding:20px 12px}

@media (max-width: 860px){
  .agenda-page-shell{padding:10px}
  .agenda-item--compact{grid-template-columns:1fr}
  .agenda-item__top--compact{flex-direction:column;align-items:flex-start}
  .agenda-item__badges--compact{justify-content:flex-start}
}

@media (max-width: 640px){
  .topbar-pro--agenda-only{height:auto;min-height:58px;align-items:flex-start;padding-top:10px;padding-bottom:10px}
  .topbar-pro--agenda-only .topbar-left,.topbar-pro--agenda-only .topbar-right{align-items:center}
  .agenda-panel--compacta{padding:10px}
  .agenda-tabs--compact .agenda-tab{padding:6px 10px;font-size:.72rem}
  .agenda-item--compact{padding:9px}
  .agenda-item__meta--compact{display:grid;gap:5px}
  .funcionario-modal-card--compact{width:min(100%,100%);max-height:92vh}
}

.detail-overview--compact{display:grid;grid-template-columns:minmax(0,1.35fr) 250px;gap:10px;align-items:start}
.detail-resume-card,.detail-side-stack .detail-mini-card{background:#fff;border:1px solid #dce7f1;box-shadow:var(--shadow-sm)}
.detail-resume-card--compact{padding:13px 14px;border-radius:16px}
.detail-resume-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.detail-resume-card__chips{display:flex;flex-wrap:wrap;gap:6px}
.detail-resume-card__licencia{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#eff5fb;color:var(--primary);font-size:.72rem;font-weight:700;text-align:right}
.detail-resume-card--compact h3{margin:0 0 4px;font-size:1.02rem;line-height:1.12}
.detail-resume-card__subtitle{margin:0 0 12px;color:var(--text-soft);font-size:.77rem}
.detail-resume-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.detail-info-pill{padding:10px 11px;border-radius:14px;background:#f8fbfe;border:1px solid #e4edf5}
.detail-info-pill span{display:block;margin-bottom:4px;font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--text-soft)}
.detail-info-pill strong{display:block;font-size:.84rem;line-height:1.25;color:var(--primary-strong)}
.detail-side-stack--compact{display:grid;gap:8px}
.detail-mini-card--highlight{padding:11px 12px;border-radius:15px}
.detail-section__counter{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#eef4fa;border:1px solid #dce7f1;color:var(--primary-strong);font-size:.72rem;font-weight:700;white-space:nowrap}
.detail-form-actions{margin-top:6px}
@media (max-width: 860px){
  .detail-overview--compact{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .detail-resume-grid{grid-template-columns:1fr}
  .detail-section__head--compact{flex-direction:column;align-items:flex-start}
}


/* Ajustes finales compactos */
.agenda-page-shell{max-width:940px;padding:10px}
.agenda-panel--compacta{padding:10px 10px 8px;border-radius:16px}
.agenda-panel__head{margin-bottom:6px}
.agenda-panel__head h2{font-size:1rem}
.agenda-tabs--compact{gap:6px;margin-bottom:8px}
.agenda-tabs--compact .agenda-tab{padding:6px 11px;font-size:.74rem}
.agenda-mensaje{margin-bottom:8px;font-size:.74rem}
.agenda-item--compact{grid-template-columns:98px 1fr;gap:9px;padding:9px 10px;border-radius:14px}
.agenda-item__hour--compact{padding:7px;border-radius:12px}
.agenda-item__hour--compact strong{font-size:.95rem}
.agenda-item__hour--compact span{font-size:.69rem}
.agenda-item__top--compact h4{font-size:.88rem}
.agenda-item__top--compact p{font-size:.75rem}
.agenda-item__meta--compact{gap:7px;font-size:.72rem}
.agenda-item__actions--compact .btn-mini,.agenda-item__actions--compact .admin-attention{min-height:30px;font-size:.7rem;padding:0 10px}
.admin-attention{min-height:30px;font-size:.7rem}
.funcionario-modal-card--compact{width:min(760px,100%);max-height:min(88vh,700px);border-radius:18px}
.modal-header--compact{padding:12px 13px}
.modal-body--compact{padding:12px}
.modal-title{font-size:1rem}
.admin-detail-flow--compact{gap:8px}
.detail-overview--compact{grid-template-columns:minmax(0,1.3fr) 220px;gap:8px}
.detail-resume-card--compact{padding:11px 12px;border-radius:14px}
.detail-resume-card__top{margin-bottom:8px}
.detail-resume-card__licencia{min-height:26px;padding:0 9px;font-size:.68rem}
.detail-resume-card--compact h3{font-size:.98rem;margin:0 0 3px}
.detail-resume-card__subtitle{margin:0 0 10px;font-size:.74rem}
.detail-resume-grid{gap:7px}
.detail-info-pill{padding:9px 10px;border-radius:12px}
.detail-info-pill span{margin-bottom:3px;font-size:.64rem}
.detail-info-pill strong{font-size:.8rem}
.detail-mini-card--highlight{padding:10px 11px;border-radius:13px}
.detail-mini-card--highlight strong{font-size:.88rem}
.detail-mini-card--highlight p{font-size:.73rem}
.detail-section--compact{padding:11px;border-radius:14px}
.detail-section__head--compact{margin-bottom:8px}
.detail-section__head--compact h4{font-size:.9rem}
.detail-section__head--compact p{font-size:.74rem}
.detail-section__counter{min-height:26px;padding:0 9px;font-size:.69rem}
.admin-doc-row--compact{grid-template-columns:1fr auto;gap:8px;padding:9px 10px;border-radius:12px}
.admin-doc-row__body{min-width:0}
.admin-doc-row--compact .admin-doc-row__head{gap:6px;margin-bottom:4px}
.admin-doc-row--compact .admin-doc-row__head h5{font-size:.84rem;margin:0 0 3px}
.admin-doc-row--compact .admin-doc-row__head p{font-size:.73rem;line-height:1.38}
.admin-doc-row--compact .admin-doc-row__footer{font-size:.71rem;gap:7px}
.admin-doc-file{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:bottom}
.admin-doc__actions .admin-link{min-height:30px;padding:0 10px;font-size:.7rem}
.admin-form-grid--compact{gap:8px}
.admin-form-grid--compact textarea{min-height:86px}
.actions--admin-form-compact button{min-height:34px}

@media (max-width: 640px){
  .agenda-page-shell{padding:8px}
  .agenda-item--compact{grid-template-columns:1fr;padding:8px}
  .funcionario-modal-card--compact{width:min(100%,100%);max-height:92vh}
  .detail-overview--compact,.detail-resume-grid{grid-template-columns:1fr}
  .admin-doc-row--compact{grid-template-columns:1fr}
  .admin-doc__actions{justify-content:flex-start}
}

/* Refinado detalle modal */
.funcionario-modal-card--compact{width:min(700px,100%);max-height:min(86vh,660px);border-radius:16px}
.modal-header--compact{padding:10px 12px}
.modal-body--compact{padding:10px;background:#f5f9fd}
.modal-inc-chip-row{margin-bottom:6px}
.inc-chip,.inc-chip-code{font-size:.68rem;padding:4px 9px}
.modal-title{font-size:.96rem}
.admin-detail-flow--refined{gap:8px}
.detail-overview--refined{grid-template-columns:minmax(0,1.35fr) 190px;gap:8px}
.detail-resume-card--refined{padding:10px 11px;border-radius:12px}
.detail-resume-card__top--compact{margin-bottom:6px}
.detail-resume-card--refined h3{font-size:.92rem;margin:0 0 8px}
.detail-resume-grid--refined{gap:6px}
.detail-info-pill{padding:8px 9px;border-radius:11px}
.detail-info-pill span{font-size:.62rem}
.detail-info-pill strong{font-size:.78rem;line-height:1.2}
.detail-side-stack--refined{gap:6px}
.detail-mini-card--tight{padding:9px 10px;border-radius:12px}
.detail-mini-card--tight span{font-size:.62rem;margin-bottom:4px}
.detail-mini-card--tight strong{font-size:.82rem;margin-bottom:2px}
.detail-mini-card--tight p{font-size:.71rem;line-height:1.25}
.detail-section--documents,.detail-section--refined-form{padding:10px;border-radius:12px}
.detail-section__head--refined{margin-bottom:8px}
.detail-section__head--refined h4{font-size:.88rem}
.detail-section__head--refined p{font-size:.72rem}
.detail-section__counter{min-height:24px;padding:0 8px;font-size:.66rem}
.detail-doc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.detail-doc-card{border:1px solid #e2ebf3;background:#fbfdff;border-radius:12px;padding:9px 10px;display:grid;gap:7px}
.detail-doc-card.is-complete{background:#fcfffd;border-color:#d9eade}
.detail-doc-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.detail-doc-card__head h5{margin:0;font-size:.82rem;line-height:1.28;color:var(--primary-strong)}
.detail-doc-card__desc{margin:0;color:var(--text-soft);font-size:.71rem;line-height:1.35}
.detail-doc-card__footer{display:flex;align-items:center;justify-content:space-between;gap:8px}
.detail-doc-card__meta{display:grid;gap:4px;min-width:0}
.admin-doc-state{display:inline-flex;align-items:center;min-height:22px;width:max-content;padding:0 8px;border-radius:999px;font-size:.66rem;font-weight:700}
.admin-doc-state.ok{background:#e9f6ef;color:#2b7558}
.admin-doc-state.pending{background:#f3f5f7;color:#6c7d8d}
.admin-doc-file{font-size:.7rem;color:var(--text-soft);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-doc__actions{display:flex;align-items:center;justify-content:flex-end}
.admin-doc__actions .admin-link{min-height:28px;padding:0 9px;font-size:.68rem;border-radius:10px}
.ghost-text{font-size:.69rem}
.admin-empty--soft{padding:14px;border-radius:12px;border:1px dashed #d6e1eb;background:#fbfdff}
.admin-form-grid--refined{gap:8px}
.admin-form-grid--refined textarea{min-height:78px}
.actions--admin-form-compact button{min-height:32px;font-size:.74rem}

@media (max-width: 720px){
  .funcionario-modal-card--compact{width:min(100%,100%);max-height:92vh}
  .detail-overview--refined,.detail-doc-grid,.detail-resume-grid--refined{grid-template-columns:1fr}
}

/* ===== OVERRIDE FINAL CITA COMPACTA Y LIMPIA ===== */
.page--cita-bupa{
  max-width: 860px;
  padding-top: 6px;
  padding-bottom: 16px;
}

.page--cita-bupa .progress-card{
  grid-template-columns: minmax(0,1fr) 200px;
  gap: 10px;
  padding: 12px 14px;
  margin-bottom: 10px;
  border-radius: 16px;
}

.page--cita-bupa .progress-header h2{
  font-size: .92rem;
}

.page--cita-bupa .progress-header p{
  font-size: .76rem;
}

.page--cita-bupa .summary-item{
  padding: 11px 12px;
  border-radius: 14px;
}

.page--cita-bupa .summary-item strong{
  font-size: .88rem;
}

.page--cita-bupa .summary-item p{
  font-size: .74rem;
}

.cita-bupa-card{
  padding: 10px;
  border-radius: 16px;
  overflow: visible;
}

.cita-bupa-hero{
  padding: 4px 2px 10px;
  margin-bottom: 4px;
  background: transparent;
  border-bottom: 1px solid #e5edf4;
  color: var(--text);
  gap: 10px;
}

.cita-bupa-hero__icon{
  display: none;
}

.cita-bupa-hero h2{
  margin: 0 0 3px;
  font-size: 1.08rem;
  line-height: 1.1;
  letter-spacing: -.02em;
  color: var(--primary-strong);
}

.cita-bupa-hero p{
  margin: 0;
  color: var(--text-soft);
  font-size: .78rem;
}

.cita-week-card,
.cita-hours-card{
  margin: 0 0 10px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid #dde7f0;
  background: #fff;
  box-shadow: none;
}

.cita-week-head{
  grid-template-columns: 34px 1fr 34px;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
}

.week-nav{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid #d8e2ec;
  background: #fff;
  color: #55718d;
  font-size: 1.25rem;
  line-height: 1;
  box-shadow: none;
}

.week-nav:hover{
  background: #f7fbff;
  border-color: #cdd9e6;
}

.cita-week-title span{
  display: block;
  margin-bottom: 2px;
  font-size: .7rem;
  color: var(--text-soft);
}

.cita-week-title strong{
  font-size: .96rem;
  color: var(--primary-strong);
}

.cita-days-strip{
  grid-template-columns: repeat(7, minmax(0,1fr));
  gap: 8px;
}

.cita-day{
  min-height: 74px;
  padding: 8px 6px;
  border-radius: 14px;
  border: 1px solid #dde7f0;
  background: #fbfdff;
  gap: 2px;
  box-shadow: none;
  transition: .16s ease;
}

.cita-day:hover:not(:disabled){
  transform: none;
  background: #fff;
  border-color: #c9d8e7;
}

.cita-day.is-active{
  background: #f2f8ff;
  border-color: #8dbbe4;
  box-shadow: 0 0 0 2px rgba(31,79,143,.08);
}

.cita-day.is-disabled{
  background: #f5f7f9;
  border-color: #e4eaf0;
  color: #b2bcc7;
}

.cita-day__weekday{
  font-size: .66rem;
  font-weight: 600;
  color: #74879b;
}

.cita-day__number{
  width: 30px;
  height: 30px;
  border-radius: 10px;
  background: #eef3f8;
  color: var(--primary-strong);
  font-size: .92rem;
}

.cita-day.is-active .cita-day__number{
  background: #deecfb;
  color: var(--primary);
}

.cita-day.is-disabled .cita-day__number{
  background: #eef2f5;
  color: #b4bfca;
}

.cita-day__label{
  font-size: .66rem;
  color: #7b8ea2;
}

.cita-hours-head{
  display: block;
  margin-bottom: 10px;
}

.cita-hours-head h3{
  margin: 0 0 2px;
  font-size: 1rem;
  color: var(--primary-strong);
}

.cita-hours-head p{
  margin: 0;
  font-size: .76rem;
  color: var(--text-soft);
}

.cita-hours-summary{
  display: none;
}

.cita-hours-grid{
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 8px;
}

.hora-btn--bupa{
  min-height: 58px;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid #dbe5ef;
  background: #fff;
  display: grid;
  justify-items: center;
  align-content: center;
  text-align: center;
  gap: 2px;
  box-shadow: none;
}

.hora-btn--bupa strong{
  font-size: .98rem;
  line-height: 1;
  color: var(--primary-strong);
}

.hora-btn--bupa span{
  font-size: .71rem;
  color: var(--text-soft);
  font-weight: 600;
}

.hora-btn--bupa.active{
  background: #edf6ff;
  border-color: #8dbbe4;
  box-shadow: 0 0 0 2px rgba(31,79,143,.08);
}

.hora-btn--bupa.hora-btn--occupied,
.hora-btn--bupa:disabled{
  background: #f4f6f8;
  border-color: #e2e8ef;
}

.hora-btn--bupa.hora-btn--occupied strong,
.hora-btn--bupa:disabled strong,
.hora-btn--bupa.hora-btn--occupied span,
.hora-btn--bupa:disabled span{
  color: #b4bec8;
}

.actions--cita-bupa{
  padding: 0;
  margin-top: 2px;
  gap: 10px;
  align-items: center;
}

.actions--cita-bupa button{
  min-height: 36px;
  padding: 0 14px;
  font-size: .8rem;
}

.actions--cita-bupa .muted-text{
  font-size: .74rem;
}

.page--cita-bupa .mensaje{
  margin: 10px 0 0;
  font-size: .76rem;
}

.page--cita-bupa .mensaje:not(:empty){
  padding: 9px 10px;
  border-radius: 12px;
}

@media (max-width: 900px){
  .page--cita-bupa{
    max-width: 100%;
  }

  .page--cita-bupa .progress-card{
    grid-template-columns: 1fr;
  }

  .cita-days-strip{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }

  .cita-hours-grid{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 640px){
  .page--cita-bupa{
    padding-left: 10px;
    padding-right: 10px;
  }

  .cita-bupa-card{
    padding: 8px;
  }

  .cita-week-card,
  .cita-hours-card{
    padding: 10px;
    border-radius: 12px;
  }

  .cita-days-strip{
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 6px;
  }

  .cita-day{
    min-height: 68px;
    border-radius: 12px;
  }

  .cita-hours-grid{
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 6px;
  }

  .hora-btn--bupa{
    min-height: 54px;
    padding: 8px;
  }

  .actions--cita-bupa{
    flex-direction: column;
    align-items: stretch;
  }

  .actions--cita-bupa button{
    width: 100%;
  }
}

/* =========================================================
    CITA FINAL LIMPIA Y COMPACTA
   ========================================================= */

/* ancho general */
.page--cita-bupa{
  max-width: 760px !important;
  padding-top: 8px !important;
  padding-bottom: 16px !important;
}

/* progreso y resumen superior */
.page--cita-bupa .progress-card{
  grid-template-columns: minmax(0,1fr) 200px !important;
  gap: 12px !important;
  padding: 12px 14px !important;
  margin-bottom: 12px !important;
  border-radius: 18px !important;
}

.summary-item--cita,
.page--cita-bupa .summary-item{
  background: linear-gradient(180deg,#ffffff 0%,#f7fbff 100%) !important;
  border: 1px solid #d8e4ef !important;
  border-radius: 16px !important;
  padding: 12px 14px !important;
  box-shadow: 0 6px 14px rgba(31,79,143,.05) !important;
}

.summary-item--cita span,
.page--cita-bupa .summary-item span{
  font-size: .64rem !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: #6f88a1 !important;
}

.summary-item--cita strong,
.page--cita-bupa .summary-item strong{
  display:block !important;
  font-size: .90rem !important;
  line-height: 1.24 !important;
  color:#143f73 !important;
  margin-top: 3px !important;
}

.summary-item--cita p,
.page--cita-bupa .summary-item p{
  font-size:.74rem !important;
  color:#5f7488 !important;
  margin-top: 4px !important;
  line-height:1.3 !important;
}

/* tarjeta principal */
.cita-bupa-card{
  padding: 10px !important;
  border-radius: 20px !important;
  border: 1px solid #dce7f1 !important;
  box-shadow: 0 10px 24px rgba(16,45,80,.04) !important;
}

/* cabecera */
.cita-bupa-hero{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:12px !important;
  padding: 4px 4px 10px !important;
  margin-bottom: 8px !important;
  border-bottom: 1px solid #e6eef5 !important;
}

.cita-bupa-hero__main{
  display:flex;
  align-items:center;
  gap:10px;
}

.cita-bupa-hero__icon{
  width: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;
  display:grid !important;
  place-items:center !important;
  background: linear-gradient(180deg,#eef6ff 0%,#e2eefb 100%) !important;
  border:1px solid #d3e2f1 !important;
  font-size:.95rem !important;
}

.cita-bupa-hero h2{
  margin:0 0 2px !important;
  font-size:1rem !important;
  line-height:1.08 !important;
  color:#143f73 !important;
}

.cita-bupa-hero p{
  margin:0 !important;
  font-size:.73rem !important;
  color:#5e7489 !important;
}

.cita-bupa-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.cita-badge{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:0 8px;
  border-radius:999px;
  background:#f7fbff;
  border:1px solid #d8e5f1;
  color:#60758a;
  font-size:.67rem;
  font-weight:700;
}

/* ocultar resumen duplicado inferior */
.cita-hours-summary{
  display:none !important;
}

/* tarjetas internas */
.cita-week-card,
.cita-hours-card{
  padding: 10px !important;
  margin: 0 0 10px !important;
  border-radius: 16px !important;
  border: 1px solid #dbe6f0 !important;
  background: linear-gradient(180deg,#ffffff 0%,#fbfdff 100%) !important;
}

/* calendario */
.cita-week-head{
  display:grid !important;
  grid-template-columns: 34px 1fr 34px !important;
  gap:8px !important;
  align-items:center !important;
  margin-bottom:10px !important;
}

.week-nav{
  width:34px !important;
  height:34px !important;
  min-height:34px !important;
  padding:0 !important;
  border-radius:11px !important;
  border: 1px solid #d7e3ef !important;
  background: linear-gradient(180deg,#ffffff 0%,#f5faff 100%) !important;
  color: #1f4f8f !important;
  font-size: 1rem !important;
}

.cita-week-title{
  display:grid !important;
  gap:2px !important;
}

.cita-week-title span{
  font-size:.66rem !important;
  font-weight:700 !important;
  color:#7a8ea2 !important;
}

.cita-week-title strong{
  font-size:.94rem !important;
  line-height:1.15 !important;
  color:#143f73 !important;
}

.cita-days-strip{
  display:grid !important;
  grid-template-columns: repeat(7, minmax(0,1fr)) !important;
  gap: 8px !important;
}

.cita-day{
  min-height: 72px !important;
  padding: 8px 6px !important;
  border-radius: 16px !important;
  border:1px solid #dce7f1 !important;
  background: linear-gradient(180deg,#ffffff 0%,#fbfdff 100%) !important;
  display:grid !important;
  place-items:center !important;
  align-content:center !important;
  gap:3px !important;
  text-align:center !important;
}

.cita-day.is-active{
  background: linear-gradient(180deg,#eef6ff 0%,#e2eefb 100%) !important;
  border-color:#7fb0dd !important;
  box-shadow: 0 0 0 2px rgba(31,79,143,.08) !important;
}

.cita-day__weekday{
  font-size:.63rem !important;
  font-weight:800 !important;
  letter-spacing:.03em !important;
  text-transform:uppercase !important;
  color:#7c90a4 !important;
}

.cita-day__number{
  width:26px !important;
  height:26px !important;
  border-radius:999px !important;
  display:grid !important;
  place-items:center !important;
  background:#eef3f8 !important;
  color:#21486f !important;
  font-size:.84rem !important;
  font-weight:800 !important;
  line-height:1 !important;
}

.cita-day.is-active .cita-day__number{
  background:#1f5ea8 !important;
  color:#fff !important;
}

.cita-day__label{
  font-size:.63rem !important;
  color:#7b8ea2 !important;
  line-height:1 !important;
  text-transform:lowercase !important;
}

/* bloque horarios */
.cita-hours-head{
  display:block !important;
  margin-bottom:8px !important;
}

.cita-hours-copy h3{
  margin:0 0 3px !important;
  font-size:.98rem !important;
  color:#143f73 !important;
}

.cita-hours-copy p{
  margin:0 !important;
  font-size:.73rem !important;
  color:#5f7488 !important;
}

/* HORAS: grid correcto */
.horas,
.cita-hours-grid{
  display:grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  gap: 8px !important;
  align-items:stretch !important;
}

.hora-btn,
.hora-btn--bupa{
  width:100% !important;
  min-height:54px !important;
  padding:6px 8px !important;
  border-radius:13px !important;
  border:1px solid #dbe5ee !important;
  background: linear-gradient(180deg,#ffffff 0%,#fbfdff 100%) !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  align-items:center !important;
  text-align:center !important;
  gap:1px !important;
  box-shadow:none !important;
}

.hora-btn::after,
.hora-btn--bupa::after{
  content:none !important;
}

.hora-btn strong,
.hora-btn--bupa strong{
  font-size:.90rem !important;
  line-height:1 !important;
  color:#123f73 !important;
  font-weight:800 !important;
}

.hora-btn span,
.hora-btn--bupa span{
  font-size:.69rem !important;
  line-height:1.08 !important;
  color:#5d7387 !important;
  font-weight:600 !important;
}

.hora-btn.active,
.hora-btn--bupa.active{
  background: linear-gradient(180deg,#edf6ff 0%,#e2eefb 100%) !important;
  border-color:#7fb0dd !important;
  box-shadow: 0 0 0 2px rgba(31,79,143,.08) !important;
}

/* acciones */
.actions--cita-bupa{
  margin-top:4px !important;
}

#guardarCita{
  min-height:32px !important;
  padding:0 11px !important;
  border-radius:11px !important;
  font-size:.74rem !important;
}

.actions--cita-bupa .muted-text{
  font-size:.70rem !important;
  color:#687d90 !important;
}

.page--cita-bupa .mensaje:not(:empty){
  padding:8px 10px !important;
  border-radius:12px !important;
  margin-top:8px !important;
}

@media (max-width: 860px){
  .page--cita-bupa .progress-card{
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 760px){
  .cita-bupa-hero{
    display:grid !important;
  }

  .cita-days-strip{
    grid-template-columns: repeat(4, minmax(0,1fr)) !important;
  }
}

@media (max-width: 520px){
  .cita-days-strip{
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }

  .horas,
  .cita-hours-grid{
    grid-template-columns: 1fr !important;
  }

  .actions--cita-bupa{
    flex-direction:column !important;
    align-items:stretch !important;
  }

  #guardarCita{
    width:100% !important;
  }
}

.licencia-card{padding:12px;}
.licencias-track{gap:10px;}
.card--licencias{padding:12px;}

/* ===== AJUSTE FINAL: SOLO LICENCIAS CON ICONOS ===== */
.licencia-card.licencia-card--icon{
  min-width:280px;
  max-width:280px;
  padding:14px;
  gap:10px;
  border-radius:18px;
  border:1px solid #d7e3ef;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
  box-shadow:0 8px 18px rgba(16,45,80,.05);
}

.licencia-card__toprow{display:block}
.licencia-card__lefthead{
  display:flex;
  align-items:flex-start;
  gap:10px;
}

.licencia-card__icon{
  width:32px;
  height:32px;
  min-width:32px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#eef4fb;
  border:1px solid #d4e0ec;
  font-size:15px;
  line-height:1;
}

.licencia-card__headcopy{
  display:grid;
  gap:2px;
  min-width:0;
}

.licencia-card__headbadges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}

.licencia-card__mini{
  font-size:.74rem;
  color:var(--text-soft);
}

.licencia-card__mini2{
  font-size:.88rem;
  font-weight:700;
  color:#5f79a5;
  text-transform:lowercase;
  line-height:1;
}

.licencia-card__content h4{
  margin:0 0 8px;
  font-size:1rem;
  line-height:1.2;
}

.licencia-card__content p{
  margin:0;
  font-size:.81rem;
  line-height:1.5;
  color:var(--text-soft);
}

.licencia-card__chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.licencia-chip--soft{
  background:#f4f7fb;
  border-color:#d7e3ef;
  color:#5d738f;
}

.licencia-card__btn--primary{
  width:100%;
  min-height:44px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid #2e63ab;
  background:linear-gradient(180deg,#3e78bf 0%, #2f66b0 100%);
  color:#fff;
  font-size:.88rem;
  font-weight:700;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16);
}

.licencia-card__btn--primary:hover{
  background:linear-gradient(180deg,#4a82c5 0%, #346db8 100%);
  border-color:#2f66b0;
  color:#fff;
}

@media (max-width:720px){
  .licencia-card.licencia-card--icon{
    min-width:252px;
    max-width:252px;
    padding:12px;
  }
}

/* LICENCIAS */
.page--licencias-compact{
  max-width: 1020px !important;
  padding-top: 6px !important;
}

.page--licencias-compact .progress-card{
  grid-template-columns: minmax(0,1fr) 190px !important;
  gap: 8px !important;
  padding: 8px 10px !important;
  margin-bottom: 10px !important;
  border-radius: 16px !important;
}

.page--licencias-compact .progress-header h2{
  font-size: .9rem !important;
  margin-bottom: 1px !important;
}

.page--licencias-compact .progress-header p{
  font-size: .74rem !important;
}

.page--licencias-compact .progress-steps-wrap{
  margin-top: 6px !important;
}

.page--licencias-compact .progress-steps{
  gap: 2px !important;
}

.page--licencias-compact .progress-line{
  top: 10px !important;
  height: 2px !important;
  left: 8.5% !important;
  right: 8.5% !important;
}

.page--licencias-compact .step{
  gap: 2px !important;
}

.page--licencias-compact .step__circle{
  width: 22px !important;
  height: 22px !important;
  font-size: 9px !important;
  border-width: 1.5px !important;
}

.page--licencias-compact .step span{
  font-size: 9px !important;
  line-height: 1.05 !important;
}

.page--licencias-compact .summary-item--licencias{
  padding: 10px 11px !important;
  border-radius: 14px !important;
  margin: 0 !important;
}

.page--licencias-compact .summary-item--licencias span{
  margin-bottom: 4px !important;
  font-size: 9px !important;
}

.page--licencias-compact .summary-item--licencias strong{
  font-size: .83rem !important;
  line-height: 1.18 !important;
  margin-bottom: 4px !important;
}

.page--licencias-compact .summary-item--licencias p{
  font-size: .73rem !important;
  line-height: 1.3 !important;
}

.page--licencias-compact .card--licencias{
  padding-top: 14px !important;
}

/* botón más chico y más limpio */
.page--licencias-compact .licencia-card__footer{
  justify-content: stretch !important;
}

.page--licencias-compact .licencia-card__btn,
.page--licencias-compact .licencia-card__btn--primary{
  min-height: 32px !important;
  height: 32px !important;
  padding: 0 10px !important;
  font-size: .74rem !important;
  font-weight: 700 !important;
  border-radius: 9px !important;
  letter-spacing: 0 !important;
  box-shadow: none !important;
}

.page--licencias-compact .licencia-card__btn--primary{
  background: #f2f6fa !important;
  color: #1f4f8f !important;
  border: 1px solid #c8d8e8 !important;
}

.page--licencias-compact .licencia-card__btn--primary:hover{
  background: #e8f0f8 !important;
  color: #173d70 !important;
  border-color: #b9ccdf !important;
  transform: none !important;
}

.page--licencias-compact .licencia-card__btn--primary:active{
  background: #dfeaf5 !important;
  transform: none !important;
}

@media (max-width: 900px){
  .page--licencias-compact .progress-card{
    grid-template-columns: 1fr !important;
  }
}



/* ===== AJUSTE SOLO DEL CUADRO BLANCO SUPERIOR ===== */
.progress-card{
  padding: 8px 12px !important;
  margin-bottom: 8px !important;
  gap: 10px !important;
  border-radius: 16px !important;
}

.progress-card > div:first-child{
  padding-top: 2px !important;
  padding-bottom: 2px !important;
}

.progress-header{
  margin-bottom: 0 !important;
}

.progress-header h2{
  margin: 0 0 1px !important;
}

.progress-header p{
  margin: 0 !important;
}

.progress-steps-wrap{
  margin-top: 6px !important;
}

/* cuadro derecho un poco más compacto */
.summary-item{
  padding: 10px 12px !important;
  margin: 0 !important;
}

.summary-item span{
  margin-bottom: 4px !important;
}

.summary-item strong{
  margin-bottom: 4px !important;
}

/* en móvil igual compacto */
@media (max-width: 980px){
  .progress-card{
    padding: 8px 10px !important;
  }
}


/* Ajuste puntual solicitado: quitar chips y achicar botón */
.licencia-card__btn,
.licencia-card__btn--primary{
  min-height: 30px !important;
  height: 30px !important;
  padding: 0 10px !important;
  font-size: .72rem !important;
  border-radius: 8px !important;
  box-shadow: none !important;
}

.licencia-card__footer{
  margin-top: 2px !important;
}

/* COLOR BOTON  */
.licencia-card__btn{
  background:#ffffff !important;
  color:#1f4f8f !important;
  border:1px solid #d6e2ee !important;
}

.licencia-card__btn:hover{
  background:#f4f8fc !important;
  border-color:#c8d8e8 !important;
}

/* Revision */
body.revision-page-body{
  background:linear-gradient(180deg,#f3f6fa 0%,#eef2f6 100%);
  color:#16324f;
}

.revision-top-header{padding:12px 16px 6px}
.revision-topbar{
  max-width:980px;
  padding:14px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.96);
  border:1px solid #d7e0ea;
  box-shadow:0 10px 28px rgba(15, 35, 60, .05);
}
.revision-brand{gap:14px}
.revision-brand .brand__logo{
  width:56px;
  height:56px;
  border-radius:14px;
  padding:6px;
}
.revision-brand .brand__kicker{
  background:#eff4f8;
  color:#51657a;
  border:1px solid #d6e0ea;
  margin-bottom:6px;
}
.revision-brand .brand__text h1{
  font-size:1.7rem;
  letter-spacing:-.04em;
  color:#15324f;
}
.revision-brand .brand__text p{
  font-size:.95rem;
  color:#5d7187;
}
.revision-topbar__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.revision-refresh-btn{
  background:#15324f;
  color:#fff;
  border-color:#15324f;
}
.revision-refresh-btn:hover{background:#1d4267;border-color:#1d4267;color:#fff}

.revision-page-shell{
  max-width:980px;
  padding:10px 16px 28px;
}

.revision-hero,
.revision-panel-card{
  background:#fff;
  border:1px solid #d7e0ea;
  border-radius:22px;
  box-shadow:0 14px 34px rgba(15,35,60,.045);
}

.revision-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) 190px;
  gap:18px;
  align-items:center;
  padding:24px 26px;
  margin-bottom:18px;
}
.revision-eyebrow{
  display:inline-block;
  margin-bottom:10px;
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#7c5d31;
}
.revision-hero h2{
  margin:0 0 8px;
  font-size:2.15rem;
  line-height:1.02;
  letter-spacing:-.05em;
  color:#15324f;
}
.revision-hero p{
  margin:0;
  max-width:60ch;
  font-size:1rem;
  line-height:1.55;
  color:#607489;
}
.revision-hero__side{
  display:grid;
  gap:8px;
  justify-items:end;
}
.revision-hero__label{
  font-size:.74rem;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#788b9c;
}
.revision-status-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 18px;
  border-radius:999px;
  border:1px solid transparent;
  font-size:.9rem;
  font-weight:800;
  text-align:center;
}
.revision-status-pill--pending{background:#fff4e5;border-color:#f2d2a1;color:#9a5b00}
.revision-status-pill--review{background:#ebf3ff;border-color:#c8daf9;color:#2156a5}
.revision-status-pill--ok{background:#ebf8f1;border-color:#cce7d7;color:#2f6d50}
.revision-status-pill--warn{background:#fff1ef;border-color:#f1cbc5;color:#b3554d}

.revision-main-grid,
.revision-detail-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:18px;
  margin-bottom:18px;
}
.revision-panel-card{padding:22px 22px 20px}
.revision-panel-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:18px;
}
.revision-panel-card__head h3{
  margin:0 0 5px;
  font-size:1.28rem;
  line-height:1.15;
  letter-spacing:-.03em;
  color:#16324f;
}
.revision-panel-card__head p{
  margin:0;
  font-size:.92rem;
  color:#718396;
}

.revision-summary-list{display:grid;gap:0}
.revision-summary-row{
  display:grid;
  gap:6px;
  padding:16px 0;
  border-top:1px solid #e7edf3;
}
.revision-summary-row:first-child{padding-top:0;border-top:none}
.revision-summary-row span{
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#758799;
}
.revision-summary-row strong{
  font-size:1.24rem;
  line-height:1.2;
  letter-spacing:-.02em;
  color:#17324d;
}
.revision-summary-row small{
  font-size:.95rem;
  color:#6b7d8e;
}

.revision-next-box{
  padding:18px;
  border-radius:18px;
  background:linear-gradient(180deg,#f8fafc 0%,#f2f6fa 100%);
  border:1px solid #dfe7ef;
}
.revision-next-box strong{
  display:block;
  margin-bottom:8px;
  font-size:1.16rem;
  line-height:1.25;
  color:#16324f;
}
.revision-next-box p{
  margin:0;
  font-size:.98rem;
  line-height:1.6;
  color:#65788b;
}
.revision-action-link{
  margin-top:16px;
  min-height:42px;
  padding:0 16px;
}

.revision-steps{display:grid;gap:14px}
.revision-step-item{
  display:grid;
  grid-template-columns:14px 1fr;
  gap:14px;
  align-items:flex-start;
}
.revision-step-item__dot{
  width:14px;
  height:14px;
  margin-top:5px;
  border-radius:50%;
  border:2px solid #c7d3df;
  background:#fff;
}
.revision-step-item strong{
  display:block;
  margin-bottom:4px;
  font-size:1rem;
  color:#17324d;
}
.revision-step-item p{
  margin:0;
  color:#6e8092;
  line-height:1.55;
}
.revision-step-item.is-active .revision-step-item__dot{
  background:#2156a5;
  border-color:#2156a5;
}
.revision-step-item.is-done .revision-step-item__dot{
  background:#2f6d50;
  border-color:#2f6d50;
}

.revision-note-box{
  min-height:132px;
  padding:18px;
  border-radius:18px;
  background:#f9fbfc;
  border:1px solid #e1e8ef;
  color:#5f7387;
  font-size:.98rem;
  line-height:1.65;
}

.revision-doc-list{display:grid;gap:12px}
.revision-doc-card{
  display:grid;
  grid-template-columns:44px minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
  padding:16px 18px;
  border:1px solid #e0e8ef;
  border-radius:18px;
  background:#fbfcfd;
}
.revision-doc-card__icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:#eef4f8;
  font-size:1.1rem;
}
.revision-doc-card__body strong{
  display:block;
  margin-bottom:4px;
  font-size:1rem;
  color:#16324f;
}
.revision-doc-card__body p{
  margin:0;
  color:#6d8092;
  font-size:.94rem;
}
.revision-doc-card__side{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.revision-doc-card__status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:#eff4f8;
  color:#607487;
  font-size:.8rem;
  font-weight:800;
  text-transform:capitalize;
}
.revision-doc-card--empty{
  grid-template-columns:1fr;
  padding:18px;
}
.revision-doc-card--empty strong{display:block;margin-bottom:4px;font-size:1rem;color:#16324f}
.revision-doc-card--empty p{margin:0;color:#6d8092}

.revision-feedback{
  margin-top:16px;
  font-size:.9rem;
}
.revision-feedback:not(:empty){
  padding:12px 14px;
  border-radius:14px;
}

@media (max-width: 920px){
  .revision-hero,
  .revision-main-grid,
  .revision-detail-grid{grid-template-columns:1fr}
  .revision-hero__side{justify-items:start}
}

@media (max-width: 640px){
  .revision-top-header{padding:10px 10px 4px}
  .revision-topbar{padding:14px}
  .revision-brand .brand__text h1{font-size:1.35rem}
  .revision-brand .brand__text p{font-size:.88rem}
  .revision-topbar__actions{width:100%}
  .revision-topbar__actions .button-secondary{flex:1;justify-content:center}
  .revision-page-shell{padding:8px 10px 20px}
  .revision-hero{padding:18px 16px;border-radius:18px}
  .revision-hero h2{font-size:1.6rem}
  .revision-hero p{font-size:.92rem}
  .revision-panel-card{padding:18px 16px;border-radius:18px}
  .revision-panel-card__head h3{font-size:1.1rem}
  .revision-summary-row strong{font-size:1.08rem}
  .revision-next-box strong{font-size:1rem}
  .revision-doc-card{grid-template-columns:1fr;align-items:flex-start}
  .revision-doc-card__icon{display:none}
  .revision-doc-card__side{justify-content:flex-start}
}


/* REVISION · SOLO ESTA VISTA */
body.revision-page-body.revision-safe-compact{
  background:#dfe7f1;
  color:#334a62;
  font-family:Inter,"Segoe UI",Arial,sans-serif;
}

body.revision-page-body.revision-safe-compact .top-header{
  padding:12px 14px 6px;
}

body.revision-page-body.revision-safe-compact .top-header__inner{
  max-width:1080px;
  border-radius:20px;
  padding:14px 18px;
  box-shadow:none;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
}

body.revision-page-body.revision-safe-compact .top-header .brand{
  min-width:0;
}

body.revision-page-body.revision-safe-compact .brand__text{
  min-width:0;
}

body.revision-page-body.revision-safe-compact .brand__logo{
  width:50px;
  height:50px;
}

body.revision-page-body.revision-safe-compact .brand__kicker{
  font-size:11px;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .brand__text h1{
  font-size:1.1rem;
  line-height:1.15;
  font-weight:600;
  letter-spacing:-.02em;
  color:#1f456e;
}

body.revision-page-body.revision-safe-compact .brand__text p{
  font-size:.81rem;
  color:#667b91;
  font-weight:400;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:nowrap;
  justify-content:flex-end;
  margin-left:0;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__page{
  max-width:930px;
  padding-top:12px;
  padding-bottom:20px;
  display:grid;
  gap:10px;
}

body.revision-page-body.revision-safe-compact .card{
  border-radius:20px;
  padding:12px 14px;
  box-shadow:none;
  overflow:visible;
}

body.revision-page-body.revision-safe-compact .button-secondary,
body.revision-page-body.revision-safe-compact .admin-link{
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__flow-head{
  margin-bottom:8px;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__flow-head h2,
body.revision-page-body.revision-safe-compact .revision-safe-compact__hero h2,
body.revision-page-body.revision-safe-compact .revision-safe-panel__head h3{
  margin:0 0 4px;
  color:#21466f;
  letter-spacing:-.02em;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__flow-head h2,
body.revision-page-body.revision-safe-compact .revision-safe-compact__hero h2{
  font-size:1rem;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-safe-panel__head h3{
  font-size:.94rem;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__flow-head p,
body.revision-page-body.revision-safe-compact .revision-safe-compact__hero p,
body.revision-page-body.revision-safe-compact .revision-safe-panel__head p{
  margin:0;
  color:#667b91;
  font-size:.8rem;
  font-weight:400;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__steps{
  position:relative;
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:8px;
  padding:4px 2px 10px;
  align-items:start;
  overflow:visible;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__steps-line{
  position:absolute;
  left:10%;
  right:10%;
  top:17px;
  height:2px;
  background:#ccd7e4;
  z-index:0;
}

body.revision-page-body.revision-safe-compact .revision-safe-step{
  position:relative;
  z-index:1;
  display:grid;
  justify-items:center;
  gap:7px;
  text-align:center;
  min-width:0;
}

body.revision-page-body.revision-safe-compact .revision-safe-step__circle{
  width:28px;
  height:28px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#fff;
  border:2px solid #cbd7e4;
  color:#6a8197;
  font-size:.78rem;
  font-weight:600;
  position:relative;
  z-index:2;
}

body.revision-page-body.revision-safe-compact .revision-safe-step__label{
  font-size:.75rem;
  color:#5f768d;
  font-weight:500;
}

body.revision-page-body.revision-safe-compact .revision-safe-step.is-done .revision-safe-step__circle,
body.revision-page-body.revision-safe-compact .revision-safe-step.is-active .revision-safe-step__circle{
  background:#2f5d93;
  border-color:#2f5d93;
  color:#fff;
}

body.revision-page-body.revision-safe-compact .revision-safe-step.is-done .revision-safe-step__label,
body.revision-page-body.revision-safe-compact .revision-safe-step.is-active .revision-safe-step__label{
  color:#21466f;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__main{
  display:grid;
  gap:10px;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px;
  align-items:start;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:0 10px;
  border-radius:999px;
  background:#eef4fa;
  border:1px solid #dbe6f0;
  color:#35587f;
  font-size:.72rem;
  font-weight:600;
  margin-bottom:7px;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-label{
  font-size:.69rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:#6a8095;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-status{
  display:grid;
  gap:6px;
  justify-items:end;
}

body.revision-page-body.revision-safe-compact .revision-status-pill{
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:.79rem;
  font-weight:600;
  border:1px solid #d9e3ee;
}

body.revision-page-body.revision-safe-compact .revision-status-pill--pending{
  background:#f3f6f9;
  color:#61778d;
}

body.revision-page-body.revision-safe-compact .revision-status-pill--review{
  background:#ebf2fb;
  color:#2f5d93;
}

body.revision-page-body.revision-safe-compact .revision-status-pill--ok{
  background:#eaf5ef;
  color:#2f735e;
}

body.revision-page-body.revision-safe-compact .revision-status-pill--warn{
  background:#fdf5e2;
  color:#8b6a1b;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__next{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-radius:16px;
  background:linear-gradient(180deg,#fbfdff 0%,#f7fbfe 100%);
  border:1px solid #dce6f0;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__next strong{
  display:block;
  margin-bottom:3px;
  color:#21466f;
  font-size:.9rem;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__next p{
  margin:0;
  color:#657b90;
  font-size:.8rem;
  line-height:1.42;
  font-weight:400;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__summary{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}

body.revision-page-body.revision-safe-compact .revision-safe-data{
  padding:11px 12px;
  border-radius:16px;
  background:#fbfdff;
  border:1px solid #dce6f0;
  display:grid;
  gap:3px;
}

body.revision-page-body.revision-safe-compact .revision-safe-data--wide{
  grid-column:1 / -1;
}

body.revision-page-body.revision-safe-compact .revision-safe-data span{
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:#6a8095;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-safe-data strong{
  color:#21466f;
  font-size:.95rem;
  line-height:1.25;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-safe-data small{
  color:#6a7f94;
  font-size:.79rem;
  font-weight:400;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__content{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:10px;
  align-items:start;
}

body.revision-page-body.revision-safe-compact .revision-safe-panel{
  padding:12px;
  border-radius:18px;
  background:#fbfdff;
  border:1px solid #dce6f0;
  display:grid;
  gap:9px;
  align-self:start;
}

body.revision-page-body.revision-safe-compact .revision-safe-note{
  min-height:68px;
  padding:12px;
  border-radius:14px;
  background:#fff;
  border:1px solid #e2ebf3;
  color:#657b90;
  line-height:1.5;
  font-size:.82rem;
  font-weight:400;
}

body.revision-page-body.revision-safe-compact .revision-doc-list{
  display:grid;
  gap:8px;
  max-height:152px;
  overflow:auto;
  padding-right:4px;
}


body.revision-page-body.revision-safe-compact .revision-doc-list::-webkit-scrollbar{
  width:8px;
}

body.revision-page-body.revision-safe-compact .revision-doc-list::-webkit-scrollbar-thumb{
  background:#d4dfeb;
  border-radius:999px;
}

body.revision-page-body.revision-safe-compact .revision-doc-card{

  display:grid;
  grid-template-columns:34px minmax(0,1fr) auto;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid #e1eaf2;
  background:#fff;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__icon{
  width:34px;
  height:34px;
  border-radius:10px;
  display:grid;
  place-items:center;
  background:#eef4fa;
  color:#35587f;
  font-size:.92rem;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__body strong{
  display:block;
  margin-bottom:3px;
  color:#21466f;
  font-size:.87rem;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__body p{
  margin:0;
  color:#667b91;
  font-size:.78rem;
  line-height:1.4;
  font-weight:400;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__side{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:26px;
  padding:0 10px;
  border-radius:999px;
  font-size:.72rem;
  font-weight:600;
  background:#eef4fa;
  color:#61778d;
  border:1px solid #d9e4ef;
}

body.revision-page-body.revision-safe-compact .revision-doc-card--empty{
  grid-template-columns:1fr;
}

body.revision-page-body.revision-safe-compact .revision-doc-card--empty strong{
  display:block;
  margin-bottom:5px;
  font-weight:600;
}

body.revision-page-body.revision-safe-compact .mensaje{
  margin-top:0;
  font-size:.79rem;
  font-weight:400;
}

@media (max-width: 820px){
  body.revision-page-body.revision-safe-compact .top-header__inner{
    grid-template-columns:1fr;
    align-items:flex-start;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__actions{
    width:100%;
    justify-content:flex-start;
    flex-wrap:wrap;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__hero,

  body.revision-page-body.revision-safe-compact .revision-safe-compact__next,
  body.revision-page-body.revision-safe-compact .revision-safe-compact__content{
    grid-template-columns:1fr;
    display:grid;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-status{
    justify-items:start;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__summary{
    grid-template-columns:1fr;
  }

  body.revision-page-body.revision-safe-compact .revision-doc-card{
    grid-template-columns:34px 1fr;
    align-items:start;
  }

  body.revision-page-body.revision-safe-compact .revision-doc-card__side{
    grid-column:2;
    justify-content:flex-start;
  }
}

@media (max-width: 680px){
  body.revision-page-body.revision-safe-compact .revision-safe-compact__steps{
    gap:6px;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-step__label{
    font-size:.66rem;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__steps-line{
    left:8%;
    right:8%;
  }
}

/* DOCUMENTOS  */

/* Tipografía */
body {
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 400;
  letter-spacing: -0.01em;
}

/* TITULOS */
.documentos-simple-head h3 {
  font-weight: 600;
  letter-spacing: -0.02em;
}

/* Quitar exceso de negrita de todo el sistema*/
strong {
  font-weight: 600;
}

/* Subtitulos */
.documentos-simple-head p {
  font-weight: 400;
  color: var(--text-soft);
}

/* STRIP (Estado, Licencia, etc) */
.documentos-strip__item span {
  font-weight: 600;
  color: var(--text-muted);
}

.documentos-strip__item strong {
  font-weight: 500;
  color: var(--primary-strong);
}

/* Consejo */
.documentos-helper {
  font-weight: 400;
}

/* FILA DOCUMENTO */
.doc-row__head h4 {
  font-weight: 600;
  letter-spacing: -0.01em;
}

.doc-row__head p {
  font-weight: 400;
  color: var(--text-soft);
}

/* Badge obligatorio */
.documento-item__tag {
  font-weight: 600;
  font-size: 10px;
}

/* Botón archivo */
.doc-upload-box__button {
  font-weight: 500;
}

/* Nombre archivo */
.doc-upload-box__name {
  font-weight: 500;
}

/* Estado (pendiente / cargado) */
.doc-row__status {
  font-weight: 500;
  font-size: 12px;
}

/* Seguimiento (bloque derecho) */
.summary-item strong {
  font-weight: 600;
}

.summary-item p {
  font-weight: 400;
}

/* Título grande arriba */
.progress-header h2 {
  font-weight: 600;
}

/* Texto pasos */
.step span {
  font-weight: 500;
}

@media (max-width: 760px){
  body.revision-page-body.revision-safe-compact .revision-safe-compact__page{
    padding-top:14px;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__flow{
    overflow:visible;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__steps{
    gap:6px;
    padding-bottom:12px;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-step__label{
    font-size:.72rem;
  }
}


/* Agenda calendario */
.agenda-calendar-card{margin-bottom:14px;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fbfdff;display:grid;gap:12px}
.agenda-calendar-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.agenda-calendar-card__title{display:grid;gap:4px;justify-items:center;text-align:center;flex:1}
.agenda-calendar-card__title p{margin:0;color:var(--text-soft);font-size:.82rem}
.agenda-calendar-weekdays,.agenda-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}
.agenda-calendar-weekdays span{padding:6px 0;text-align:center;font-size:.75rem;font-weight:700;color:var(--text-soft)}
.agenda-calendar-day{min-height:82px;padding:10px;border-radius:16px;border:1px solid #dfe8f1;background:#fff;display:grid;align-content:space-between;gap:8px;text-align:left}
.agenda-calendar-day:hover{background:var(--primary-soft);border-color:#bfd0e4;transform:translateY(-1px)}
.agenda-calendar-day.is-other-month{opacity:.45}
.agenda-calendar-day.has-events{border-color:#bfd4ea;background:linear-gradient(180deg,#fff 0%,#f5f9fe 100%)}
.agenda-calendar-day.is-selected{border-color:var(--primary);box-shadow:0 0 0 2px rgba(31,79,143,.12)}
.agenda-calendar-day__number{font-size:1rem;font-weight:700;color:var(--primary-strong)}
.agenda-calendar-day__meta{font-size:.74rem;color:var(--text-soft)}
@media (max-width: 820px){.agenda-calendar-weekdays,.agenda-calendar-grid{gap:6px}.agenda-calendar-day{min-height:70px;padding:8px}.agenda-calendar-day__meta{font-size:.68rem}}


/* Agenda completa funcionario */
body.agenda-pro-body{margin:0;font-family:"Poppins","Inter",system-ui,sans-serif;background:#0b1220;color:#e8eef8}
.agenda-pro-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr;background:radial-gradient(circle at top left,rgba(47,104,182,.18),transparent 22%),linear-gradient(180deg,#0d1525 0%,#09101d 100%)}
.agenda-pro-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 24px;border-bottom:1px solid rgba(148,163,184,.16);background:rgba(9,16,29,.82);backdrop-filter:blur(10px);position:sticky;top:0;z-index:30}
.agenda-pro-topbar__left,.agenda-pro-topbar__right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.agenda-pro-brand{display:flex;align-items:center;gap:12px;color:#f8fbff}
.agenda-pro-brand img{width:42px;height:42px;border-radius:12px;background:#fff;object-fit:contain;padding:4px}
.agenda-pro-brand strong{display:block;font-size:1.02rem}
.agenda-pro-brand span{display:block;color:#94a8c6;font-size:.78rem}
.agenda-pro-btn,.agenda-pro-select{min-height:42px;border-radius:14px;border:1px solid rgba(148,163,184,.22);background:rgba(18,28,48,.92);color:#edf4ff;padding:0 14px;font-weight:600}
.agenda-pro-btn:hover,.agenda-pro-select:hover{background:rgba(30,43,70,.96)}
.agenda-pro-btn--primary{background:#1f5fbf;border-color:#2e73dc;color:#fff}
.agenda-pro-btn--ghost{background:transparent}
.agenda-pro-title{display:flex;align-items:center;gap:14px}
.agenda-pro-title h1{margin:0;font-size:1.65rem;letter-spacing:-.04em;color:#f4f8ff}
.agenda-pro-title p{margin:2px 0 0;color:#92a3bf;font-size:.82rem}
.agenda-pro-layout{display:grid;grid-template-columns:280px minmax(0,1fr) 320px;gap:18px;padding:18px}
.agenda-pro-card{background:rgba(12,20,34,.86);border:1px solid rgba(148,163,184,.16);border-radius:24px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.agenda-sidebar{padding:18px;display:grid;gap:16px;align-content:start}
.agenda-sidebar__month-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.agenda-sidebar__month-head strong{font-size:1.05rem}
.agenda-mini-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.agenda-mini-weekday,.agenda-mini-day{aspect-ratio:1/1;display:grid;place-items:center}
.agenda-mini-weekday{font-size:.68rem;font-weight:700;color:#8395b2;text-transform:uppercase}
.agenda-mini-day{border:none;border-radius:12px;background:transparent;color:#dce7f7;font-weight:600;position:relative}
.agenda-mini-day:hover{background:rgba(56,86,138,.24)}
.agenda-mini-day.is-other-month{color:#60708b}
.agenda-mini-day.is-today{box-shadow:inset 0 0 0 1px rgba(92,168,255,.55)}
.agenda-mini-day.is-selected{background:#8ab4f8;color:#07111f}
.agenda-mini-day.has-events::after{content:"";width:6px;height:6px;border-radius:50%;background:#6fb1ff;position:absolute;bottom:7px;left:50%;transform:translateX(-50%)}
.agenda-sidebar__section{display:grid;gap:12px}
.agenda-sidebar__section h3,.agenda-day-panel__head h3{margin:0;font-size:1rem}
.agenda-filter-list{display:grid;gap:10px}
.agenda-filter-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 12px;border-radius:16px;border:1px solid rgba(148,163,184,.14);background:rgba(13,21,36,.86);color:#e8eef8;font-weight:600}
.agenda-filter-btn small{color:#86a1c7;font-weight:500}
.agenda-filter-btn.is-active{background:rgba(39,94,184,.24);border-color:rgba(99,160,255,.35)}
.agenda-filter-btn:hover{background:rgba(31,47,77,.92)}
.agenda-chip-row{display:flex;flex-wrap:wrap;gap:10px}
.agenda-chip-dark{display:inline-flex;align-items:center;gap:8px;padding:8px 11px;border-radius:999px;background:rgba(17,29,49,.95);border:1px solid rgba(148,163,184,.14);font-size:.76rem;color:#aec1de}
.agenda-main{padding:14px;display:grid;grid-template-rows:auto auto 1fr;gap:12px;overflow:hidden}
.agenda-weekbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 6px 4px}
.agenda-weekbar__nav{display:flex;align-items:center;gap:8px}
.agenda-weekbar__range strong{display:block;font-size:1.16rem}
.agenda-weekbar__range p{margin:2px 0 0;color:#8ca2c5;font-size:.8rem}
.agenda-weekdays-pro{display:grid;grid-template-columns:70px repeat(7,minmax(120px,1fr));gap:0;padding:0 6px}
.agenda-weekdays-pro__spacer{height:54px}
.agenda-weekday-col{display:grid;justify-items:center;align-content:center;padding:6px 0 10px;border-bottom:1px solid rgba(148,163,184,.15);cursor:pointer}
.agenda-weekday-col small{color:#8ca2c5;font-weight:700;letter-spacing:.08em}
.agenda-weekday-col strong{margin-top:8px;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:1.55rem;font-weight:500;color:#eaf2ff}
.agenda-weekday-col.is-today strong{background:#8ab4f8;color:#09111d}
.agenda-weekday-col.is-selected{background:rgba(26,38,63,.65);border-radius:20px 20px 0 0}
.agenda-weekday-col.is-selected strong{box-shadow:inset 0 0 0 2px rgba(138,180,248,.35)}
.agenda-week-grid{position:relative;display:grid;grid-template-columns:70px repeat(7,minmax(120px,1fr));min-height:672px;overflow:auto;border-radius:22px;background:rgba(7,13,24,.7);border:1px solid rgba(148,163,184,.12)}
.agenda-hours-col,.agenda-grid-body{position:relative}
.agenda-hours-col{z-index:2;background:rgba(7,13,24,.88)}
.agenda-hour-label{height:56px;padding:0 10px 0 0;text-align:right;color:#91a7c8;font-size:.73rem;border-top:1px solid rgba(148,163,184,.08);display:flex;align-items:flex-start;justify-content:flex-end;transform:translateY(-7px)}
.agenda-grid-body{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));grid-column:2/span 7}
.agenda-day-column{position:relative;border-left:1px solid rgba(148,163,184,.1)}
.agenda-day-column::before{content:"";position:absolute;left:0;right:0;top:0;bottom:0;background:repeating-linear-gradient(to bottom,transparent 0,transparent 55px,rgba(148,163,184,.08) 55px,rgba(148,163,184,.08) 56px)}
.agenda-event{position:absolute;left:8px;right:8px;border:none;border-radius:14px;padding:8px 10px;background:linear-gradient(180deg,#f16d67 0%,#d24b4c 100%);color:#fff;text-align:left;box-shadow:0 12px 24px rgba(210,75,76,.28);overflow:hidden}
.agenda-event:hover{filter:brightness(1.04)}
.agenda-event--done{background:linear-gradient(180deg,#2d8b6d 0%,#246e58 100%);box-shadow:0 12px 24px rgba(36,110,88,.26)}
.agenda-event--approved{background:linear-gradient(180deg,#4587ea 0%,#2d66bf 100%);box-shadow:0 12px 24px rgba(45,102,191,.26)}
.agenda-event__time{display:block;font-size:.72rem;font-weight:700;opacity:.9;margin-bottom:3px}
.agenda-event__title{display:block;font-size:.85rem;font-weight:700;line-height:1.25}
.agenda-event__meta{display:block;font-size:.73rem;opacity:.92;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.agenda-day-panel{padding:18px;display:grid;grid-template-rows:auto auto 1fr;gap:14px}
.agenda-day-panel__head p{margin:6px 0 0;color:#93a5c4;font-size:.82rem}
.agenda-day-panel__list{display:grid;gap:12px;align-content:start;max-height:calc(100vh - 260px);overflow:auto;padding-right:4px}
.agenda-day-card{padding:14px;border-radius:18px;background:rgba(17,28,46,.92);border:1px solid rgba(148,163,184,.14);display:grid;gap:10px}
.agenda-day-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.agenda-day-card h4{margin:0;font-size:.95rem}
.agenda-day-card p{margin:2px 0 0;color:#91a6c8;font-size:.78rem}
.agenda-day-card__meta{display:grid;gap:7px;font-size:.77rem;color:#dbe6f8}
.agenda-state-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 9px;border-radius:999px;font-size:.7rem;font-weight:700;background:rgba(77,95,126,.32);color:#dce7f8;border:1px solid rgba(148,163,184,.14)}
.agenda-state-pill.is-approved{background:rgba(69,135,234,.2);color:#9dc1ff}
.agenda-state-pill.is-review{background:rgba(143,170,214,.16);color:#cedcf4}
.agenda-state-pill.is-rejected{background:rgba(219,110,96,.17);color:#ffb1a6}
.agenda-state-pill.is-done{background:rgba(45,139,109,.2);color:#9dd7c6}
.agenda-empty-dark{padding:18px;border-radius:18px;background:rgba(12,20,34,.82);border:1px dashed rgba(148,163,184,.18);text-align:center;color:#92a7c6}
.agenda-empty-dark strong{display:block;color:#eef4ff;margin-bottom:6px}
.agenda-modal-pro{position:fixed;inset:0;background:rgba(2,6,12,.66);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:18px;z-index:60}
.agenda-modal-pro.is-open{display:flex}
.agenda-modal-pro__card{width:min(720px,100%);background:#0d1525;border:1px solid rgba(148,163,184,.16);border-radius:28px;box-shadow:0 25px 80px rgba(0,0,0,.45);overflow:hidden}
.agenda-modal-pro__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 24px 18px;border-bottom:1px solid rgba(148,163,184,.12)}
.agenda-modal-pro__head h3{margin:8px 0 0;font-size:1.3rem}
.agenda-modal-pro__head p{margin:6px 0 0;color:#90a5c6;font-size:.84rem}
.agenda-modal-pro__body{padding:22px 24px 24px;display:grid;gap:14px}
.agenda-modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.agenda-modal-item{padding:14px;border-radius:18px;background:rgba(15,26,43,.92);border:1px solid rgba(148,163,184,.14)}
.agenda-modal-item span{display:block;font-size:.72rem;color:#89a0c3;text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px}
.agenda-modal-item strong{display:block;font-size:.95rem;color:#f3f7ff}
.agenda-modal-item p{margin:6px 0 0;color:#9bb0cf;font-size:.79rem}
.agenda-modal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
@media (max-width: 1280px){.agenda-pro-layout{grid-template-columns:260px minmax(0,1fr)}.agenda-day-panel{grid-column:1/-1;max-height:none}.agenda-day-panel__list{max-height:none}}
@media (max-width: 920px){.agenda-pro-layout{grid-template-columns:1fr}.agenda-sidebar{order:2}.agenda-weekdays-pro,.agenda-week-grid{min-width:980px}.agenda-main{overflow:auto}}
@media (max-width: 640px){.agenda-pro-topbar{padding:14px 16px}.agenda-pro-layout{padding:12px}.agenda-modal-grid{grid-template-columns:1fr}.agenda-pro-title h1{font-size:1.28rem}}

/* === Panel agenda con mini calendario a la derecha === */
.agenda-dashboard{display:grid;grid-template-columns:minmax(0,1fr) 290px;gap:14px;align-items:start}
.agenda-dashboard__main{display:grid;gap:10px;min-width:0}
.agenda-dashboard__side{display:grid;gap:12px}

.agenda-day-summary{padding:14px;border:1px solid #dbe7f1;border-radius:18px;background:#fbfdff}
.agenda-day-summary__head{margin-bottom:8px}
.agenda-day-summary h3{margin:0 0 4px;font-size:1.04rem;color:var(--primary-strong)}
.agenda-day-summary p{margin:0;color:var(--text-soft);font-size:.8rem}

.agenda-mini-card,.agenda-hours-card{padding:12px;border:1px solid var(--line);border-radius:18px;background:#fbfdff}
.agenda-mini-card__head,.agenda-hours-card__head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.agenda-mini-card__nav{display:flex;gap:8px}
.agenda-mini-card__month{display:block;margin-bottom:10px;font-size:1rem;color:var(--primary-strong)}
.btn-mini--icon{min-width:34px;padding:0}
.agenda-mini-weekdays,.agenda-mini-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.agenda-mini-weekdays{margin-bottom:8px}
.agenda-mini-weekdays span{text-align:center;font-size:.72rem;font-weight:700;color:var(--text-soft)}
.agenda-mini-grid .agenda-calendar-day{position:relative;min-height:auto;padding:0;height:34px;border-radius:11px;display:grid;place-items:center;gap:0;text-align:center}
.agenda-mini-grid .agenda-calendar-day__number{font-size:.88rem}
.agenda-mini-grid .agenda-calendar-day__meta{display:none}
.agenda-mini-grid .agenda-calendar-day.has-events::after{content:"";position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--primary)}
.agenda-mini-grid .agenda-calendar-day.is-selected{background:var(--primary);border-color:var(--primary);box-shadow:none}
.agenda-mini-grid .agenda-calendar-day.is-selected .agenda-calendar-day__number{color:#fff}
.agenda-mini-grid .agenda-calendar-day.is-selected.has-events::after{background:#fff}
.agenda-mini-grid .agenda-calendar-day.is-other-month{opacity:.4}
.agenda-mini-legend{margin-top:10px;padding-top:10px;border-top:1px solid #e3ebf3;display:grid;gap:8px}
.agenda-mini-legend span{display:flex;align-items:center;gap:6px;font-size:.76rem;color:var(--text-soft)}
.agenda-mini-legend span i{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--primary)}
.agenda-mini-legend small{color:var(--text-soft);font-size:.75rem;line-height:1.35}

.agenda-hours-card__summary{font-size:.77rem;color:var(--text-soft);margin-bottom:10px;line-height:1.35}
.agenda-hours-list{display:grid;gap:8px}
.agenda-hour-chip{padding:10px 11px;border-radius:14px;border:1px solid #dfe8f1;background:#fff;text-align:left;display:grid;gap:2px}
.agenda-hour-chip:hover{background:var(--primary-soft);border-color:#bfd0e4}
.agenda-hour-chip strong{font-size:.9rem;color:var(--primary-strong)}
.agenda-hour-chip span{font-size:.74rem;color:var(--text-soft);line-height:1.25}
.agenda-hour-chip.is-selected{background:linear-gradient(180deg,#f4f8fd 0%,#edf4fb 100%);border-color:#9fc0e6;box-shadow:0 0 0 2px rgba(31,79,143,.08)}
.agenda-hours-empty{padding:12px;border-radius:14px;background:#fff;border:1px dashed #d6e3ef}
.agenda-hours-empty strong{display:block;margin-bottom:3px;font-size:.82rem;color:var(--primary-strong)}
.agenda-hours-empty p{margin:0;font-size:.74rem;color:var(--text-soft)}

.agenda-item--selected{border-color:#9fc0e6;box-shadow:0 0 0 2px rgba(31,79,143,.08);background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)}

@media (max-width: 980px){
  .agenda-dashboard{grid-template-columns:1fr}
}

/* ===== Refresh vista documentos ===== */
.page--docs-refresh .progress-card{margin-bottom:16px}
.documentos-refresh-card{padding:20px;background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);border-color:#dce7f2}
.documentos-refresh-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.documentos-refresh-head h3{margin:6px 0 6px;font-size:1.7rem;line-height:1.02;letter-spacing:-.04em;color:var(--primary-strong)}
.documentos-refresh-head p{margin:0;color:var(--text-soft);max-width:780px}
.documentos-refresh-hero{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}
.documentos-resumen-card{padding:16px;border-radius:18px;border:1px solid #dce7f2;background:#fff;box-shadow:var(--shadow-sm);display:grid;gap:8px;min-width:0}
.documentos-resumen-card--estado{background:linear-gradient(180deg,#f8fbff 0%,#eef5fd 100%)}
.documentos-resumen-card__label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:800;color:var(--text-soft)}
.documentos-resumen-card strong{font-size:1.02rem;line-height:1.2;color:var(--primary-strong);word-break:break-word}
.documentos-resumen-card p{margin:0;color:var(--text-soft);font-size:.82rem;line-height:1.45}
.documentos-helper--refresh{margin-bottom:14px;padding:12px 14px;border-radius:16px;background:linear-gradient(180deg,#eef5fe 0%,#e8f1fb 100%);border:1px solid #d7e4f3}
.documentos-refresh-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.85fr);gap:16px;align-items:start}
.documentos-main-panel,.documentos-side-panel{background:#fff;border:1px solid #dce7f2;border-radius:20px;padding:16px;box-shadow:var(--shadow-sm)}
.documentos-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.documentos-panel-head h4{margin:0 0 4px;font-size:1.05rem;color:var(--primary-strong)}
.documentos-panel-head p{margin:0;color:var(--text-soft);font-size:.83rem}
.documentos-panel-chip{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:999px;background:var(--primary-soft);border:1px solid #d7e4f1;color:var(--primary);font-size:.78rem;font-weight:800;white-space:nowrap}
.documentos-refresh-list{display:grid;gap:12px}
.doc-row--refresh{grid-template-columns:48px minmax(0,1.5fr) minmax(240px,.95fr);gap:16px;padding:16px;border-radius:20px;border:1px solid #dbe6f0;background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);box-shadow:none;transition:.18s ease}
.doc-row--refresh:hover{border-color:#c7d9eb;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.doc-row--refresh .doc-row__index{width:48px;height:48px;border-radius:16px;background:linear-gradient(180deg,#eff5fd 0%,#e5eef9 100%);font-size:1rem}
.doc-row__head--refresh{align-items:flex-start}
.doc-row__title-line{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.doc-row__meta--refresh{row-gap:8px}
.doc-row__upload--refresh{justify-items:stretch;align-self:stretch}
.doc-upload-box--refresh{min-height:56px;display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;padding:10px 12px;border-radius:16px;border:1px dashed #bfd1e3;background:#fbfdff;transition:.18s ease}
.doc-upload-box--refresh:hover{border-color:#9fb9d4;background:#f7fbff}
.doc-upload-box--refresh input{display:none}
.doc-upload-box--refresh .doc-upload-box__button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:12px;border:1px solid #bfd0e4;background:#fff;color:var(--primary-strong);font-weight:700;white-space:nowrap}
.doc-upload-box--refresh .doc-upload-box__name{min-width:0;color:var(--text-soft);font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.documentos-info-list{display:grid;gap:12px}
.info-license-card{padding:14px;border-radius:18px;background:linear-gradient(180deg,#f8fbff 0%,#eef5fd 100%);border:1px solid #d7e4f3;display:grid;gap:8px}
.info-license-card__label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:800;color:var(--text-soft)}
.info-license-card strong{font-size:1rem;color:var(--primary-strong)}
.info-license-card p{margin:0;color:var(--text-soft);font-size:.82rem;line-height:1.45}
.info-requisito-card{display:grid;grid-template-columns:38px 1fr;gap:12px;padding:14px;border-radius:18px;border:1px solid #dce7f2;background:#fff}
.info-requisito-card__index{width:38px;height:38px;border-radius:13px;display:grid;place-items:center;background:#f1f6fc;color:var(--primary);font-weight:800}
.info-requisito-card__body{display:grid;gap:8px;min-width:0}
.info-requisito-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.info-requisito-card__top strong{font-size:.94rem;color:var(--primary-strong)}
.info-requisito-card__body p{margin:0;color:var(--text-soft);font-size:.81rem;line-height:1.48}
.documentos-empty-state,.documentos-info-empty{padding:16px;border-radius:18px;border:1px dashed #c8d8e8;background:#f9fbfe;color:var(--text-soft)}
.documentos-empty-state strong,.documentos-info-empty strong{display:block;margin-bottom:4px;color:var(--primary-strong)}
.documentos-empty-state p,.documentos-info-empty p{margin:0;font-size:.82rem}
.actions--documentos-refresh{margin-top:16px}

@media (max-width: 1080px){
  .documentos-refresh-hero{grid-template-columns:repeat(2,minmax(0,1fr))}
  .documentos-refresh-layout{grid-template-columns:1fr}
}

@media (max-width: 780px){
  .documentos-refresh-card{padding:16px}
  .documentos-refresh-head h3{font-size:1.38rem}
  .documentos-refresh-hero{grid-template-columns:1fr}
  .doc-row--refresh{grid-template-columns:1fr;gap:12px}
  .doc-row--refresh .doc-row__index{width:40px;height:40px;border-radius:14px}
  .doc-upload-box--refresh{grid-template-columns:1fr}
  .doc-upload-box--refresh .doc-upload-box__name{white-space:normal}
  .info-requisito-card{grid-template-columns:1fr}
}

/* === Documentos compactos v2 === */
.page--docs-refresh{max-width:940px}
.page--docs-refresh .progress-card{padding:12px 14px;gap:10px;align-items:center}
.page--docs-refresh .progress-header h2{font-size:.92rem}
.page--docs-refresh .progress-header p{font-size:.77rem}
.page--docs-refresh .summary-item{margin:0!important;padding:12px 13px;border-radius:16px}
.page--docs-refresh .summary-item span{font-size:.63rem}
.page--docs-refresh .summary-item strong{font-size:.9rem;margin-bottom:4px}
.page--docs-refresh .summary-item p{font-size:.76rem}

.documentos-refresh-card{padding:16px 16px 14px;border-radius:18px;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)}
.documentos-refresh-head--compact{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:12px;align-items:start;margin-bottom:12px}
.documentos-refresh-head--compact h3{margin:6px 0 4px;font-size:1.38rem;line-height:1.05}
.documentos-refresh-head--compact p{font-size:.82rem;max-width:none}
.documentos-refresh-head__tip{display:grid;gap:3px;padding:11px 12px;border-radius:16px;background:#f4f8fc;border:1px solid #dce7f2}
.documentos-refresh-head__tip strong{font-size:.84rem;color:var(--primary-strong)}
.documentos-refresh-head__tip span{font-size:.76rem;color:var(--text-soft);line-height:1.35}

.documentos-refresh-hero{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:10px}
.documentos-resumen-card{padding:11px 12px;border-radius:16px;min-height:auto;gap:3px}
.documentos-resumen-card__label{font-size:.64rem;letter-spacing:.08em}
.documentos-resumen-card strong{font-size:.95rem;line-height:1.2}
.documentos-resumen-card p{margin:1px 0 0;font-size:.75rem;line-height:1.35}
.documentos-helper--refresh{margin-bottom:10px;padding:10px 12px;border-radius:14px;font-size:.78rem}

.documentos-refresh-layout{grid-template-columns:minmax(0,1.5fr) minmax(260px,.8fr);gap:12px}
.documentos-main-panel,.documentos-side-panel{padding:12px;border-radius:18px;background:#fff;border:1px solid #dce7f2}
.documentos-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.documentos-panel-head h4{margin:0 0 3px;font-size:.96rem;line-height:1.15}
.documentos-panel-head p{margin:0;color:var(--text-soft);font-size:.76rem;line-height:1.35}
.documentos-panel-chip{min-height:28px;padding:0 10px;border-radius:999px;background:#eef4fb;border:1px solid #d5e2ef;color:var(--primary-strong);font-size:.72rem;font-weight:700;white-space:nowrap}
.documentos-refresh-list{gap:8px}

.doc-row--refresh{display:grid;grid-template-columns:36px minmax(0,1fr);gap:10px;padding:10px 11px;border-radius:16px;align-items:start}
.doc-row--refresh .doc-row__index{width:36px;height:36px;border-radius:12px;font-size:.84rem}
.doc-row__main{gap:7px}
.doc-row__head--refresh{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.doc-row__title-block{min-width:0}
.doc-row__title-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:3px}
.doc-row__title-line h4{margin:0;font-size:.9rem;line-height:1.25}
.doc-row__head--refresh p{margin:0;color:var(--text-soft);font-size:.76rem;line-height:1.35}
.doc-row__meta--refresh{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.doc-row__formats{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#f5f8fb;border:1px solid #dce7f2;color:var(--text-soft);font-size:.72rem}
.doc-row__template{min-height:28px;padding:0 10px;font-size:.72rem}
.doc-row__upload--refresh{display:block}
.doc-upload-box--refresh{min-height:46px;grid-template-columns:auto 1fr;gap:8px;padding:7px 9px 7px 7px;border-radius:14px}
.doc-upload-box--refresh .doc-upload-box__button{min-height:32px;padding:0 11px;font-size:.75rem;border-radius:10px}
.doc-upload-box--refresh .doc-upload-box__name{font-size:.76rem}
.doc-row__status{padding:4px 9px;font-size:.69rem;min-height:26px}

.documentos-info-list{display:grid;gap:8px}
.info-license-card,.info-requisito-card,.documentos-info-empty{padding:10px 11px;border-radius:15px;background:#fbfdff;border:1px solid #dce7f2}
.info-license-card{display:grid;gap:5px}
.info-license-card__label{font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;font-weight:800;color:var(--text-soft)}
.info-license-card strong{font-size:.92rem;line-height:1.2;color:var(--primary-strong)}
.info-license-card p{margin:0;color:var(--text-soft);font-size:.75rem;line-height:1.35}
.info-license-card__chips{display:flex;flex-wrap:wrap;gap:6px}
.info-license-chip{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;background:#eef4fb;border:1px solid #d5e2ef;color:var(--primary-strong);font-size:.69rem;font-weight:700}
.info-requisito-card{display:grid;grid-template-columns:28px 1fr;gap:9px;align-items:start}
.info-requisito-card__index{width:28px;height:28px;border-radius:10px;display:grid;place-items:center;background:#eef4fb;color:var(--primary);font-size:.74rem;font-weight:800}
.info-requisito-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:3px}
.info-requisito-card__top strong{font-size:.84rem;line-height:1.25;color:var(--primary-strong)}
.info-requisito-card p,.documentos-info-empty p{margin:0;color:var(--text-soft);font-size:.74rem;line-height:1.35}
.documentos-info-empty strong{display:block;margin-bottom:3px;font-size:.85rem}
.actions--documentos-refresh{margin-top:12px}
.actions--documentos-refresh .muted-text{font-size:.77rem}
.actions--documentos-refresh button{min-height:36px}

@media (max-width: 980px){
  .documentos-refresh-head--compact{grid-template-columns:1fr}
  .documentos-refresh-hero{grid-template-columns:repeat(2,minmax(0,1fr))}
  .documentos-refresh-layout{grid-template-columns:1fr}
}

@media (max-width: 640px){
  .page--docs-refresh .progress-card{padding:10px}
  .documentos-refresh-card{padding:12px}
  .documentos-refresh-head--compact h3{font-size:1.2rem}
  .documentos-refresh-hero{grid-template-columns:1fr}
  .doc-row--refresh{grid-template-columns:1fr;gap:8px}
  .doc-row--refresh .doc-row__index{width:32px;height:32px;border-radius:10px}
  .doc-row__head--refresh{flex-direction:column;align-items:flex-start}
  .doc-upload-box--refresh{grid-template-columns:1fr}
  .doc-upload-box--refresh .doc-upload-box__name{white-space:normal}
}

.week-nav:disabled{
  opacity:.45 !important;
  cursor:not-allowed !important;
  transform:none !important;
}

.cita-week-head .week-nav{
  min-width:42px !important;
  min-height:42px !important;
  border-radius:14px !important;
}

.cita-day{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease !important;
}

.cita-day:hover:not(:disabled){
  transform:translateY(-1px) !important;
  box-shadow:0 10px 22px rgba(16,45,80,.08) !important;
}


.documentos-panel-chip.is-neutral{background:#eef4fb;border-color:#d5e2ef;color:var(--primary-strong)}
.documentos-panel-chip.is-review{background:#ebf3ff;border-color:#c8daf9;color:#2156a5}
.documentos-panel-chip.is-success{background:var(--success-soft);border-color:#cfe6dc;color:var(--success)}
.documentos-panel-chip.is-danger{background:var(--danger-soft);border-color:#ebd3d3;color:var(--danger)}

.doc-row--approved{border-color:#cfe6dc;background:linear-gradient(180deg,#ffffff 0%,#f3fbf6 100%)}
.doc-row--rejected{border-color:#efcdcd;background:linear-gradient(180deg,#ffffff 0%,#fff6f6 100%)}
.doc-row__status.is-approved{background:var(--success-soft);border-color:#d4e7df;color:var(--success)}
.doc-row__status.is-error{background:var(--danger-soft);border-color:#ebd3d3;color:var(--danger)}
.doc-row__warning,.doc-row__success,.doc-row__info{padding:10px 12px;border-radius:14px;font-size:.78rem;line-height:1.45;border:1px solid transparent}
.doc-row__warning{background:var(--danger-soft);border-color:#ebd3d3;color:var(--danger)}
.doc-row__warning strong,.doc-row__warning span{display:block}
.doc-row__success{background:var(--success-soft);border-color:#cfe6dc;color:var(--success)}
.doc-row__info{background:#eef4fb;border-color:#d5e2ef;color:#35587f}

.revision-doc-card.is-approved{border-color:#cfe6dc;background:linear-gradient(180deg,#ffffff 0%,#f3fbf6 100%)}
.revision-doc-card.is-rejected{border-color:#efcdcd;background:linear-gradient(180deg,#ffffff 0%,#fff6f6 100%)}
.revision-doc-card.is-review{border-color:#c8daf9;background:linear-gradient(180deg,#ffffff 0%,#f2f7ff 100%)}
.revision-doc-card__status.is-approved{background:var(--success-soft);color:var(--success);border:1px solid #cfe6dc}
.revision-doc-card__status.is-rejected{background:var(--danger-soft);color:var(--danger);border:1px solid #ebd3d3}
.revision-doc-card__status.is-review{background:#ebf3ff;color:#2156a5;border:1px solid #c8daf9}
.revision-doc-card__status.is-pending{background:#eff4f8;color:#607487;border:1px solid #d8e3ef}
.revision-doc-card__detail{margin-top:8px;padding:9px 10px;border-radius:12px;font-size:.78rem;line-height:1.45;border:1px solid transparent}
.revision-doc-card__detail.is-approved{background:var(--success-soft);border-color:#cfe6dc;color:var(--success)}
.revision-doc-card__detail.is-rejected{background:var(--danger-soft);border-color:#ebd3d3;color:var(--danger)}
.revision-doc-card__detail.is-review{background:#ebf3ff;border-color:#c8daf9;color:#2156a5}
.revision-doc-card__detail.is-pending{background:#eff4f8;border-color:#d8e3ef;color:#607487}

body.revision-page-body.revision-safe-compact .revision-doc-card.is-approved{border-color:#cfe6dc;background:linear-gradient(180deg,#ffffff 0%,#f3fbf6 100%)}
body.revision-page-body.revision-safe-compact .revision-doc-card.is-rejected{border-color:#efcdcd;background:linear-gradient(180deg,#ffffff 0%,#fff6f6 100%)}
body.revision-page-body.revision-safe-compact .revision-doc-card.is-review{border-color:#c8daf9;background:linear-gradient(180deg,#ffffff 0%,#f2f7ff 100%)}
body.revision-page-body.revision-safe-compact .revision-doc-card__status.is-approved{background:var(--success-soft);border-color:#cfe6dc;color:var(--success)}
body.revision-page-body.revision-safe-compact .revision-doc-card__status.is-rejected{background:var(--danger-soft);border-color:#ebd3d3;color:var(--danger)}
body.revision-page-body.revision-safe-compact .revision-doc-card__status.is-review{background:#ebf3ff;border-color:#c8daf9;color:#2156a5}
body.revision-page-body.revision-safe-compact .revision-doc-card__status.is-pending{background:#eef4fa;border-color:#d9e4ef;color:#61778d}
body.revision-page-body.revision-safe-compact .revision-doc-card__detail{margin-top:7px;padding:8px 9px;border-radius:10px;font-size:.72rem;line-height:1.4;border:1px solid transparent}
body.revision-page-body.revision-safe-compact .revision-doc-card__detail.is-approved{background:var(--success-soft);border-color:#cfe6dc;color:var(--success)}
body.revision-page-body.revision-safe-compact .revision-doc-card__detail.is-rejected{background:var(--danger-soft);border-color:#ebd3d3;color:var(--danger)}
body.revision-page-body.revision-safe-compact .revision-doc-card__detail.is-review{background:#ebf3ff;border-color:#c8daf9;color:#2156a5}
body.revision-page-body.revision-safe-compact .revision-doc-card__detail.is-pending{background:#eef4fa;border-color:#d9e4ef;color:#61778d}

/* BOTÓN GUARDAR BONITO */
.btnGuardarRevision {
  width: 100%;
  margin-top: 14px;
  height: 42px;
  border-radius: 12px;
  border: none;
  background: linear-gradient(135deg, #1f4f8f, #2c6ed5);
  color: #fff;
  font-weight: 700;
  font-size: 0.9rem;
  box-shadow: 0 8px 18px rgba(31, 79, 143, 0.25);
  transition: all 0.2s ease;
}

.btnGuardarRevision:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(31, 79, 143, 0.3);
}

.btnGuardarRevision:active {
  transform: scale(0.98);
}


/* REVISION MÁS COMPACTA */
body.revision-page-body.revision-safe-compact .page.revision-safe-compact__page{
  max-width: 980px;
  padding-top: 6px;
  padding-bottom: 16px;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__flow{
  padding: 10px 14px;
  margin-bottom: 12px;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__flow-head{
  display:none;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__steps{
  min-height: 40px;
  gap: 8px;
}

body.revision-page-body.revision-safe-compact .revision-safe-step{
  gap: 4px;
}

body.revision-page-body.revision-safe-compact .revision-safe-step__circle{
  width: 26px;
  height: 26px;
  font-size: 11px;
}

body.revision-page-body.revision-safe-compact .revision-safe-step__label{
  font-size: 11px;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__main{
  padding: 14px;
  gap: 12px;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__hero--tight{
  grid-template-columns: minmax(0,1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-copy{
  min-width: 0;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__eyebrow{
  margin-bottom: 6px;
  padding: 5px 12px;
  font-size: .74rem;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__hero h2{
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.2;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__hero p{
  margin-top: 4px;
  font-size: .8rem;
  line-height: 1.35;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-side{
  display: grid;
  justify-items: end;
  gap: 10px;
}

body.revision-page-body.revision-safe-compact .revision-status-pill{
  min-height: 38px;
  padding: 0 14px;
  font-size: .86rem;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__actions--tight{
  gap: 8px;
  justify-content: flex-end;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__actions--tight .button-secondary{
  min-height: 38px;
  padding: 0 14px;
  border-radius: 12px;
  font-size: .82rem;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__next--hidden{
  display: none;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__summary{
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 10px;
}

body.revision-page-body.revision-safe-compact .revision-safe-data,
body.revision-page-body.revision-safe-compact .revision-safe-data--wide{
  grid-column: auto;
  min-height: 84px;
  padding: 12px 14px;
  border-radius: 16px;
}

body.revision-page-body.revision-safe-compact .revision-safe-data span{
  margin-bottom: 6px;
  font-size: .72rem;
}

body.revision-page-body.revision-safe-compact .revision-safe-data strong{
  font-size: .95rem;
  line-height: 1.25;
}

body.revision-page-body.revision-safe-compact .revision-safe-data small{
  margin-top: 3px;
  font-size: .76rem;
}

body.revision-page-body.revision-safe-compact .revision-safe-compact__content{
  grid-template-columns: 1fr;
  gap: 12px;
}

body.revision-page-body.revision-safe-compact .revision-safe-panel{
  padding: 14px;
  border-radius: 18px;
}

body.revision-page-body.revision-safe-compact .revision-safe-panel__head{
  margin-bottom: 10px;
}

body.revision-page-body.revision-safe-compact .revision-safe-panel__head h3{
  font-size: .98rem;
  margin: 0 0 4px;
}

body.revision-page-body.revision-safe-compact .revision-safe-panel__head p{
  font-size: .76rem;
}

body.revision-page-body.revision-safe-compact .revision-safe-note{
  padding: 12px 14px;
  border-radius: 14px;
  font-size: .8rem;
}

body.revision-page-body.revision-safe-compact .revision-safe-docs{
  gap: 10px;
}

body.revision-page-body.revision-safe-compact .revision-doc-card{
  grid-template-columns: 34px minmax(0,1fr) auto;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__icon{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  font-size: .95rem;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__body strong{
  font-size: .88rem;
  line-height: 1.25;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__body p{
  margin-top: 2px;
  font-size: .74rem;
  line-height: 1.3;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__side{
  gap: 7px;
  align-items: center;
}

body.revision-page-body.revision-safe-compact .revision-doc-card__status{
  min-height: 30px;
  padding: 0 12px;
  font-size: .74rem;
}

body.revision-page-body.revision-safe-compact .admin-link{
  min-height: 32px;
  padding: 0 12px;
  border-radius: 10px;
  font-size: .76rem;
}

body.revision-page-body.revision-safe-compact .revision-feedback{
  margin-top: 2px;
}

@media (max-width: 860px){
  body.revision-page-body.revision-safe-compact .revision-safe-compact__hero--tight{
    grid-template-columns: 1fr;
    align-items: start;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-side{
    justify-items: start;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__actions--tight{
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__summary{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 640px){
  body.revision-page-body.revision-safe-compact .revision-safe-compact__main{
    padding: 12px;
  }

  body.revision-page-body.revision-safe-compact .revision-safe-compact__summary{
    grid-template-columns: 1fr;
  }

  body.revision-page-body.revision-safe-compact .revision-doc-card{
    grid-template-columns: 1fr;
    gap: 8px;
  }

  body.revision-page-body.revision-safe-compact .revision-doc-card__icon{
    display: none;
  }

  body.revision-page-body.revision-safe-compact .revision-doc-card__side{
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
  }
}

/* Documentos limpio compacto */
.documentos-clean-card{padding:18px 18px 16px}
.documentos-clean-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.documentos-clean-head h3{margin:6px 0 4px;font-size:1.45rem;letter-spacing:-.03em}
.documentos-clean-head p{margin:0;color:var(--text-soft);font-size:.88rem}
.documentos-clean-resumen{display:grid;grid-template-columns:2fr 1.4fr .8fr 1.8fr;gap:10px;margin-bottom:12px}
.documentos-clean-pill{padding:12px 14px;border:1px solid #dce7f2;border-radius:16px;background:#fbfdff;min-width:0}
.documentos-clean-pill span{display:block;font-size:.7rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--primary);margin-bottom:6px}
.documentos-clean-pill strong{display:block;font-size:.98rem;line-height:1.35;color:var(--primary-strong);word-break:break-word}
.documentos-clean-pill small{display:block;margin-top:4px;font-size:.78rem;line-height:1.45;color:var(--text-soft)}
.documentos-clean-pill--tiny strong{font-size:1.15rem}
.documentos-clean-alert{margin-bottom:12px}
.documentos-clean-alert__inner{display:grid;grid-template-columns:38px 1fr;gap:12px;padding:12px 14px;border-radius:16px;border:1px solid #f0d9a4;background:linear-gradient(180deg,#fffaf0 0%,#fff7e8 100%)}
.documentos-clean-alert__icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:#fff3d0;border:1px solid #efd28c;font-size:1.05rem}
.documentos-clean-alert__content strong{display:block;font-size:.95rem;color:#7a5800;margin-bottom:4px}
.documentos-clean-alert__content p{margin:0;color:#775f24;font-size:.83rem;line-height:1.5}
.documentos-clean-alert__items{display:flex;flex-wrap:wrap;gap:8px;margin-top:9px}
.documentos-clean-alert__items span{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#fff;border:1px solid #ead5a1;color:#6d540d;font-size:.78rem;font-weight:700}
.documentos-clean-panel{border:1px solid #dce7f2;border-radius:18px;background:#fff;padding:14px}
.documentos-clean-panel__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.documentos-clean-panel__head h4{margin:0 0 3px;font-size:1.05rem}
.documentos-clean-panel__head p{margin:0;color:var(--text-soft);font-size:.82rem}
.documentos-clean-help{padding:7px 10px;border-radius:999px;background:#f4f8fc;border:1px solid #dbe7f1;color:var(--text-soft);font-size:.75rem;font-weight:700;white-space:nowrap}
.documentos-clean-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;flex-wrap:wrap}
.documentos-clean-note{font-size:.8rem;color:var(--text-soft)}

@media (max-width: 980px){
  .documentos-clean-resumen{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 640px){
  .documentos-clean-card{padding:14px}
  .documentos-clean-head{flex-direction:column}
  .documentos-clean-resumen{grid-template-columns:1fr}
  .documentos-clean-panel__head,.documentos-clean-footer{flex-direction:column;align-items:flex-start}
  .documentos-clean-help{white-space:normal}
}


/* Revision resumen bonito v2 */
body.revision-page-body.revision-safe-compact .revision-safe-compact__hero--tight{
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(180deg,#ffffff 0%,#f8fbfe 100%);
  border: 1px solid #dde7f0;
}
body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-copy--pretty h2{
  margin: 0 0 4px;
  font-size: 1.55rem;
  line-height: 1.05;
}
body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-copy--pretty p{
  max-width: 560px;
}
body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-side--pretty{
  display: grid;
  gap: 10px;
  justify-items: end;
}
body.revision-page-body.revision-safe-compact .revision-safe-compact__actions--pretty{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
body.revision-page-body.revision-safe-compact .revision-safe-compact__actions--pretty .button-secondary{
  min-height:36px;
  padding:0 13px;
}
body.revision-page-body.revision-safe-compact .revision-status-pill{
  position:relative;
  padding-left:34px;
  min-height:38px;
  font-weight:700;
}
body.revision-page-body.revision-safe-compact .revision-status-pill::before{
  content:"•";
  position:absolute;
  left:13px;
  top:50%;
  transform:translateY(-50%);
  font-size:16px;
  line-height:1;
}
body.revision-page-body.revision-safe-compact .revision-status-pill--ok::before{content:"✓";}
body.revision-page-body.revision-safe-compact .revision-status-pill--review::before{content:"◔";}
body.revision-page-body.revision-safe-compact .revision-status-pill--warn::before{content:"!";}
body.revision-page-body.revision-safe-compact .revision-status-pill--pending::before{content:"…";}

body.revision-page-body.revision-safe-compact .revision-safe-compact__summary--pretty{
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap:10px;
}
body.revision-page-body.revision-safe-compact .revision-safe-data{
  display:flex;
  align-items:flex-start;
  gap:10px;
  min-height:104px;
  padding:14px;
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
  border:1px solid #dbe6f0;
  box-shadow:0 8px 18px rgba(16,45,80,.04);
}
body.revision-page-body.revision-safe-compact .revision-safe-data--solicitante{
  grid-column: span 1;
}
body.revision-page-body.revision-safe-compact .revision-safe-data__icon{
  width:40px;
  height:40px;
  flex:0 0 40px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:#edf4fb;
  border:1px solid #d9e6f2;
  font-size:18px;
}
body.revision-page-body.revision-safe-compact .revision-safe-data__body{
  display:grid;
  gap:4px;
  min-width:0;
}
body.revision-page-body.revision-safe-compact .revision-safe-data strong{
  font-size:1rem;
  line-height:1.3;
  overflow-wrap:anywhere;
}
body.revision-page-body.revision-safe-compact .revision-safe-data small{
  font-size:.8rem;
}
body.revision-page-body.revision-safe-compact .revision-safe-panel{
  border-radius:18px;
}
body.revision-page-body.revision-safe-compact .revision-safe-note{
  min-height:84px;
  background:linear-gradient(180deg,#fff 0%,#fbfdff 100%);
}
body.revision-page-body.revision-safe-compact .revision-doc-card{
  border-radius:16px;
}
@media (max-width: 920px){
  body.revision-page-body.revision-safe-compact .revision-safe-compact__hero{
    grid-template-columns:1fr;
  }
  body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-side--pretty{
    justify-items:start;
  }
  body.revision-page-body.revision-safe-compact .revision-safe-compact__actions--pretty{
    justify-content:flex-start;
  }
  body.revision-page-body.revision-safe-compact .revision-safe-compact__summary--pretty{
    grid-template-columns: repeat(2,minmax(0,1fr));
  }
}
@media (max-width: 560px){
  body.revision-page-body.revision-safe-compact .revision-safe-compact__hero-copy--pretty h2{
    font-size:1.28rem;
  }
  body.revision-page-body.revision-safe-compact .revision-safe-compact__summary--pretty{
    grid-template-columns: 1fr;
  }
  body.revision-page-body.revision-safe-compact .revision-safe-data{
    min-height:auto;
    padding:12px;
  }
}


/* Home refinado: misma estructura, más lindo */
.portal-body--refined .top-header__inner{box-shadow:0 12px 30px rgba(15,23,42,.05);}
.portal-body--refined .portal-panel--single{position:relative;overflow:hidden;}
.portal-body--refined .portal-panel--single::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,#1f4f8f 0%,#8fb2dc 100%);opacity:.9;}
.portal-body--refined .portal-panel-head{align-items:center;margin-bottom:10px;}
.portal-body--refined .portal-panel h2{letter-spacing:-.04em;}
.portal-body--refined .button-secondary--icon,.portal-body--refined .tab-btn--icon,.portal-body--refined .small-badge--icon{display:inline-flex;align-items:center;gap:8px;}
.portal-body--refined .btn-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:13px;}
.portal-body--refined .portal-tabs{background:#edf3fa;border-color:#d7e3ef;box-shadow:inset 0 1px 0 rgba(255,255,255,.6);}
.portal-body--refined .tab-btn--icon span:first-child{font-size:14px;line-height:1;}
.portal-body--refined .tab-btn{display:inline-flex;align-items:center;gap:8px;}
.portal-body--refined .tab-btn.is-active{box-shadow:0 6px 14px rgba(31,79,143,.08);}
.portal-inline-tip{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:10px 12px;margin-bottom:12px;border:1px solid #dfe9f3;border-radius:14px;background:linear-gradient(180deg,#fbfdff 0%,#f4f8fc 100%);color:#5d728a;font-size:.78rem;}
.portal-inline-tip__item{display:inline-flex;align-items:center;gap:8px;}
.portal-inline-tip__item span:first-child{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#fff;border:1px solid #d8e4ef;font-size:12px;}
.portal-inline-tip__dot{width:4px;height:4px;border-radius:50%;background:#b9c9da;}
.portal-body--refined .portal-form-card--single{background:linear-gradient(180deg,#fbfdff 0%,#f8fbfe 100%);}
.portal-body--refined .field{position:relative;}
.portal-body--refined label{display:inline-flex;align-items:center;gap:7px;}
.portal-body--refined label[for="nombre_completo"]::before{content:"👤";}
.portal-body--refined label[for="rut"]::before{content:"🪪";}
.portal-body--refined label[for="telefono"]::before{content:"📱";}
.portal-body--refined label[for="correo"]::before{content:"✉️";}
.portal-body--refined label[for="direccion"]::before{content:"📍";}
.portal-body--refined label[for="rutContinuar"]::before{content:"🔎";}
.portal-body--refined input{background:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.65);}
.portal-body--refined input::placeholder{color:#8ea0b2;}
.portal-body--refined .actions--stack-mobile{padding-top:4px;border-top:1px dashed #dbe6f0;}
.portal-body--refined .actions--stack-mobile .muted-text{display:inline-flex;align-items:center;gap:7px;}
.portal-body--refined .actions--stack-mobile .muted-text::before{content:"➡️";}
@media (max-width:760px){
  .portal-inline-tip{align-items:flex-start;gap:8px;}
  .portal-inline-tip__dot{display:none;}
  .portal-body--refined .portal-panel-head{align-items:flex-start;}
}




/* ===== Licencias refinado con misma base visual ===== */
.licencias-summary-item{
  margin: 8px 0 0;
}
.licencias-card-refined{
  overflow:hidden;
}
.licencias-head-refined{
  margin-bottom:12px;
}
.licencias-head-refined h3{
  display:flex;
  align-items:center;
  gap:8px;
}
.licencias-head-refined h3::before{
  content:"🚘";
  font-size:1rem;
}
.licencias-helper-strip{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin-bottom:12px;
}
.licencias-helper-strip__item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:12px 13px;
  border:1px solid #dbe6f0;
  border-radius:16px;
  background:linear-gradient(180deg,#fbfdff 0%,#f5f9fd 100%);
}
.licencias-helper-strip__icon{
  width:34px;
  height:34px;
  border-radius:11px;
  display:grid;
  place-items:center;
  background:#eaf1fb;
  font-size:15px;
  flex:0 0 auto;
}
.licencias-helper-strip__item strong{
  display:block;
  margin-bottom:3px;
  font-size:.88rem;
  color:var(--primary-strong);
}
.licencias-helper-strip__item p{
  margin:0;
  color:var(--text-soft);
  font-size:.78rem;
  line-height:1.45;
}
.licencias-toolbar--refined{
  background:#f8fbfe;
  border:1px solid #e1ebf4;
  border-radius:16px;
  padding:10px 12px;
}
.licencias-toolbar--refined .toolbar-text{
  text-align:center;
}
.licencias-track{
  padding:4px 2px;
}
.licencia-card--icon{
  position:relative;
  overflow:hidden;
  border:1px solid #dbe6f0;
  box-shadow:0 10px 24px rgba(16,45,80,.05);
}
.licencia-card--icon::after{
  content:"";
  position:absolute;
  right:-28px;
  top:-28px;
  width:88px;
  height:88px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(31,79,143,.10), transparent 72%);
}
.licencia-card--selected{
  border-color:#b9cce2;
  background:linear-gradient(180deg,#fafdff 0%,#eef5fd 100%);
  box-shadow:0 14px 28px rgba(31,79,143,.08);
}
.licencia-card__toprow{
  position:relative;
  z-index:1;
}
.licencia-card__lefthead{
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.licencia-card__icon{
  width:46px;
  height:46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:#edf3fb;
  font-size:22px;
  flex:0 0 auto;
}
.licencia-card__headcopy{
  display:grid;
  gap:3px;
}
.licencia-card__headbadges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.licencia-card__mini,
.licencia-card__mini2{
  font-size:.72rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--text-soft);
  font-weight:700;
}
.licencia-card__mini2{
  color:var(--primary);
}
.licencia-card__content,
.licencia-card__chips,
.licencia-card__footer{
  position:relative;
  z-index:1;
}
.licencia-card__content h4{
  margin:0 0 7px;
  font-size:1.02rem;
  line-height:1.28;
  color:var(--primary-strong);
}
.licencia-card__content p{
  font-size:.81rem;
  line-height:1.52;
}
.licencia-card__chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.licencia-chip--soft{
  background:#f1f6fb;
  border-color:#dbe6f0;
  color:#456686;
}
.licencia-card__btn--primary{
  width:100%;
}
#btnCrearSolicitud{
  margin-top:14px;
  min-height:38px;
  padding:0 16px;
  border-radius:12px;
}
#seleccionResumen{
  margin-top:12px;
}
@media (max-width: 760px){
  .licencias-helper-strip{
    grid-template-columns:1fr;
  }
}
