/*
 * Contratos Digitales Campus v1.1.1
 * Estética institucional premium, responsive, sin dependencias externas.
 */
:root{
  --ct-ink:#0f172a;
  --ct-muted:#64748b;
  --ct-line:#dbe4ef;
  --ct-soft:#f8fafc;
  --ct-card:#ffffff;
  --ct-brand:#0f3a5f;
  --ct-brand-2:#0ea5e9;
  --ct-gold:#c79a2b;
  --ct-danger:#dc2626;
  --ct-success:#16a34a;
  --ct-shadow:0 24px 70px rgba(15,23,42,.14);
  --ct-radius:24px;
}

.contrato-shell{max-width:1180px;margin:28px auto;padding:0 16px;color:var(--ct-ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
.contrato-hero{position:relative;overflow:hidden;display:flex;justify-content:space-between;gap:24px;align-items:center;padding:30px;border-radius:var(--ct-radius);background:linear-gradient(135deg,#0f3a5f 0%,#0b192e 58%,#111827 100%);box-shadow:var(--ct-shadow);color:#fff;margin-bottom:22px}
.contrato-hero:before{content:"";position:absolute;right:-80px;top:-120px;width:310px;height:310px;border-radius:50%;background:rgba(14,165,233,.22)}
.contrato-hero:after{content:"";position:absolute;left:-60px;bottom:-120px;width:260px;height:260px;border-radius:50%;background:rgba(199,154,43,.18)}
.contrato-hero>*{position:relative;z-index:1}
.contrato-eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:10px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:#bae6fd}
.contrato-eyebrow:before{content:"";width:10px;height:10px;border-radius:999px;background:var(--ct-gold);box-shadow:0 0 0 6px rgba(199,154,43,.18)}
.contrato-hero h1{margin:0;font-size:clamp(28px,4vw,46px);line-height:1.05;color:#fff;font-weight:900;letter-spacing:-.04em}
.contrato-hero p{max-width:670px;margin:12px 0 0;color:#dbeafe;font-size:16px;line-height:1.6}
.contrato-hero-card{min-width:210px;padding:18px;border:1px solid rgba(255,255,255,.22);border-radius:20px;background:rgba(255,255,255,.10);backdrop-filter:blur(10px)}
.contrato-hero-card span{display:block;color:#bfdbfe;font-size:12px;text-transform:uppercase;font-weight:800;letter-spacing:.08em;margin-bottom:6px}
.contrato-hero-card strong{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;font-size:16px;color:#fff}

.contrato-layout{display:grid;grid-template-columns:minmax(0,1.12fr) minmax(360px,.88fr);gap:22px;align-items:start}
.contrato-card{background:var(--ct-card);border:1px solid var(--ct-line);border-radius:var(--ct-radius);box-shadow:0 16px 50px rgba(15,23,42,.08);overflow:hidden}
.section-head{display:flex;gap:14px;align-items:flex-start;padding:22px 24px;border-bottom:1px solid var(--ct-line);background:linear-gradient(180deg,#fff,#f8fafc)}
.step-number{flex:0 0 auto;width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#e0f2fe;color:#075985;font-weight:900;border:1px solid #bae6fd}
.section-head h2,.section-mini-head h3{margin:0;color:var(--ct-ink);font-size:20px;letter-spacing:-.02em}
.section-head p,.section-mini-head p{margin:5px 0 0;color:var(--ct-muted);font-size:13px;line-height:1.5}
.contrato-body{padding:24px}
.contrato-scroll{max-height:760px;overflow:auto;scrollbar-width:thin;background:linear-gradient(180deg,#fff 0%,#fbfdff 100%)}
.contrato-scroll::-webkit-scrollbar{width:9px}.contrato-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}

.cci-contrato-html{font-family:Georgia,"Times New Roman",serif;color:#182234;line-height:1.62}
.cci-doc-cover{text-align:center;padding:10px 0 18px;margin-bottom:12px;border-bottom:2px solid #e2e8f0}
.cci-kicker{margin:0 0 6px;text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:900;color:var(--ct-brand)}
.cci-doc-cover h2{margin:0;color:#0f172a;font-size:28px;line-height:1.12;text-transform:uppercase;letter-spacing:-.02em}
.cci-subtitle{margin:8px 0 0;font-size:16px;font-weight:800;color:#334155}
.cci-legal-id{margin:4px 0 0;color:#64748b;font-size:13px}
.cci-intro{padding:14px 16px;background:#f8fafc;border-left:4px solid var(--ct-brand-2);border-radius:14px;font-weight:600;color:#334155}
.cci-rules-list{counter-reset:rules;margin:18px 0 0;padding:0;list-style:none}
.cci-rules-list li{position:relative;margin:0 0 10px;padding:14px 16px 14px 54px;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 6px 18px rgba(15,23,42,.035)}
.cci-rules-list li:before{counter-increment:rules;content:counter(rules);position:absolute;left:14px;top:14px;width:28px;height:28px;border-radius:10px;background:#eff6ff;color:#1d4ed8;font-family:Inter,system-ui,sans-serif;font-weight:900;display:grid;place-items:center;font-size:13px;border:1px solid #bfdbfe}
.cci-approval-box{margin-top:18px;padding:18px;border-radius:18px;background:#ecfdf5;border:1px solid #bbf7d0;color:#14532d;text-align:center;font-size:16px}

.contrato-form{padding:24px}.form-grid{display:grid;gap:16px}.two-cols{grid-template-columns:1fr 1fr}
.kv{margin:0 0 16px}.contrato-form label{display:block;font-weight:800;margin-bottom:7px;color:#1e293b;font-size:13px}
.contrato-form input[type=text]{width:100%;border:1px solid #cbd5e1;border-radius:14px;min-height:48px;padding:0 14px;background:#fff;box-shadow:inset 0 1px 0 rgba(15,23,42,.02);font-size:15px;color:var(--ct-ink)}
.contrato-form input[type=text]:focus{outline:none;border-color:var(--ct-brand-2);box-shadow:0 0 0 4px rgba(14,165,233,.14)}
.biometria-section,.firma-box{margin:20px 0;padding:18px;border-radius:22px;background:#f8fafc;border:1px solid var(--ct-line)}
.section-mini-head{margin-bottom:16px}.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.upload-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:18px;box-shadow:0 12px 32px rgba(15,23,42,.05)}
.upload-icon{width:46px;height:46px;border-radius:16px;background:#eff6ff;display:grid;place-items:center;font-size:24px;margin-bottom:12px}.upload-card h4{margin:0;color:#0f172a;font-size:16px}.upload-card p{margin:5px 0 14px;color:var(--ct-muted);font-size:13px}.upload-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.btn-camara,.btn-capturar,.file-label,.firma-actions button,.print-actions button,.print-actions .button,.btn-firmar{border:0;border-radius:14px;padding:11px 15px;cursor:pointer;font-weight:800;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;line-height:1.2}.btn-camara{background:#0f172a;color:#fff}.btn-capturar{background:var(--ct-danger);color:#fff;margin-top:10px}.file-label{background:#e0f2fe;color:#075985;border:1px solid #bae6fd}.file-label input{display:none}.cam-wrapper{display:none;margin-top:12px;background:#020617;text-align:center;padding:12px;border-radius:18px}.cam-video{width:100%;max-width:420px;height:auto;border-radius:14px;border:2px solid rgba(255,255,255,.88)}.preview-img{display:none;margin-top:14px;max-width:180px;border:4px solid #dcfce7;border-radius:16px;box-shadow:0 8px 22px rgba(15,23,42,.12)}
#firmaPad{width:100%;height:180px;border:2px dashed #94a3b8;border-radius:18px;background:#fff;cursor:crosshair;touch-action:none;box-shadow:inset 0 0 0 1px #f1f5f9}.firma-actions{margin-top:10px}.firma-actions button{background:#fff;border:1px solid #cbd5e1;color:#334155}.accept-box{margin:18px 0;padding:14px 16px;border-radius:18px;background:#fff7ed;border:1px solid #fed7aa;color:#7c2d12}.btn-firmar{width:100%;min-height:56px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;font-size:17px;box-shadow:0 18px 36px rgba(22,163,74,.24)}.btn-firmar:hover{filter:brightness(.98);transform:translateY(-1px)}
.contrato-alert{max-width:980px;margin:20px auto;padding:16px 18px;border-radius:16px;background:#fef2f2;color:#991b1b;border:1px solid #fecaca;font-weight:800}.contrato-confirm{max-width:920px;margin:20px auto;display:flex;gap:16px;align-items:flex-start;background:#f0fdf4;border:1px solid #bbf7d0;color:#14532d;padding:18px;border-radius:20px;box-shadow:0 14px 38px rgba(22,163,74,.12)}.contrato-confirm h3{margin:0 0 4px}.confirm-badge{display:grid;place-items:center;width:44px;height:44px;border-radius:14px;background:#16a34a;color:#fff;font-weight:900;font-size:24px}.print-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.print-actions button,.print-actions .button{background:#0f172a;color:#fff!important}.print-actions .button-primary{background:#2563eb!important}

/* Vista final / impresión */
.contrato-preview{background:#fff;border:1px solid var(--ct-line);border-radius:18px;box-shadow:0 12px 40px rgba(15,23,42,.08);margin:20px auto;overflow:hidden}.contrato-doc{font:13.8px/1.55 Georgia,Cambria,"Times New Roman",serif;color:#111827;background:#fff}.contrato-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 22px;border-bottom:3px solid #0f3a5f;background:linear-gradient(180deg,#f8fafc,#fff)}.ch-brand{font-weight:900;letter-spacing:.2px;text-transform:uppercase}.ch-sub{color:#64748b;font-size:12px}.ch-meta{font-size:12px;color:#111827;text-align:right}.ch-meta span{color:#64748b;margin-right:6px}.contrato-title{text-align:center;font-size:22px;margin:16px 0 8px;padding:0 22px;text-transform:uppercase;letter-spacing:-.02em}.contrato-body-text{padding:0 22px 12px}.contrato-partes{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:12px 22px;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;background:#f8fafc}.contrato-partes .kv{display:flex;gap:8px;align-items:center;margin:0;font-size:13px}.contrato-partes .kv span{color:#64748b;min-width:90px;text-transform:uppercase;font-size:11px;letter-spacing:.02em}.evidencia-grid{display:grid;grid-template-columns:1.4fr .7fr 1fr;gap:14px;padding:18px 22px}.evidencia-card{border:1px solid #e2e8f0;border-radius:16px;padding:12px;text-align:center;page-break-inside:avoid}.evidencia-card strong{display:block;margin-bottom:10px;font-family:Inter,system-ui,sans-serif;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#334155}.evidencia-card img{max-width:100%;border-radius:10px}.evidencia-card:not(.firma-final-card) img{max-height:150px;object-fit:cover}.firma-line{min-height:90px;display:flex;align-items:end;justify-content:center;border-bottom:1px solid #111827;margin-bottom:6px}.firma-line img{max-width:100%;max-height:86px}.contrato-footer{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 22px;border-top:1px dashed #cbd5e1;font-size:12px;color:#475569}.cf-right{text-align:right;min-width:160px}
.a4 .contrato-preview{width:210mm}.w58 .contrato-preview{width:58mm;font:12px/1.35 ui-monospace,Menlo,Consolas,monospace}.w45 .contrato-preview{width:45mm;font:11px/1.25 ui-monospace,Menlo,Consolas,monospace}.w58 .contrato-header,.w45 .contrato-header{display:block;padding:6px 8px}.w58 .contrato-title,.w45 .contrato-title{font-size:14px;padding:0 8px}.w58 .contrato-body-text,.w45 .contrato-body-text,.w58 .contrato-partes,.w45 .contrato-partes,.w58 .evidencia-grid,.w45 .evidencia-grid,.w58 .contrato-footer,.w45 .contrato-footer{padding-left:8px;padding-right:8px}.w58 .contrato-partes,.w45 .contrato-partes,.w58 .evidencia-grid,.w45 .evidencia-grid{grid-template-columns:1fr}.w58 .cci-rules-list li,.w45 .cci-rules-list li{padding:8px 6px 8px 34px;border-radius:8px}.w58 .cci-rules-list li:before,.w45 .cci-rules-list li:before{left:6px;top:8px;width:20px;height:20px;border-radius:6px;font-size:10px}

.contratos-admin-editor .wp-editor-wrap{max-width:1100px}.contratos-admin-editor textarea.large-text{max-width:1100px}

@media (max-width:900px){.contrato-hero,.contrato-layout{display:block}.contrato-hero-card{margin-top:18px}.contrato-document-card{margin-bottom:18px}.two-cols,.upload-grid,.contrato-partes,.evidencia-grid{grid-template-columns:1fr}.contrato-scroll{max-height:none}.contrato-hero{padding:24px}.contrato-body,.contrato-form{padding:18px}.section-head{padding:18px}.cci-doc-cover h2{font-size:22px}}
@page{size:A4;margin:12mm}
@media print{body *{visibility:hidden!important}.printable,.printable *{visibility:visible!important}.printable{position:absolute;left:0;top:0;width:auto;box-shadow:none!important;border:0!important;margin:0!important}#adminmenumain,#wpadminbar,#wpfooter,.notice,.wrap>h1,.no-print,.print-actions{display:none!important}.contrato-title{page-break-after:avoid}.contrato-footer,.evidencia-grid{page-break-inside:avoid}.cci-rules-list li{box-shadow:none}}

/* =========================================================
   AJUSTE WP-CTO: UI institucional con logos y contraste
   ========================================================= */
.contrato-shell{
  max-width:1180px;
  margin:34px auto;
  padding:0 16px;
  color:#102033;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

.contrato-hero{
  min-height:230px;
  align-items:center;
  background:
    radial-gradient(circle at right 18%, rgba(34,211,238,.22), transparent 32%),
    linear-gradient(135deg,#0b3152 0%,#0d2038 58%,#07111f 100%) !important;
  border:1px solid rgba(255,255,255,.14);
}

.contrato-hero h1{
  max-width:760px;
  color:#f8fafc !important;
  text-shadow:0 2px 18px rgba(0,0,0,.28);
  font-size:clamp(34px,4.3vw,62px);
  line-height:.96;
  font-weight:950;
  letter-spacing:-.055em;
}

.contrato-hero p{
  color:#dbeafe !important;
  font-size:17px;
  font-weight:600;
}

.contrato-eyebrow{
  color:#bff5ff !important;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  padding:7px 11px;
}

.contrato-hero-brand{
  flex:0 0 245px;
  min-height:150px;
  padding:24px;
  border:1px solid rgba(255,255,255,.24);
  border-radius:26px;
  background:rgba(255,255,255,.12);
  box-shadow:0 20px 48px rgba(0,0,0,.22);
  display:flex;
  align-items:center;
  justify-content:center;
  backdrop-filter:blur(10px);
}

.contrato-hero-logo{
  width:100%;
  max-width:195px;
  height:auto;
  display:block;
  object-fit:contain;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.18));
}

.contrato-hero-card{display:none!important;}

.section-head h2,
.section-mini-head h3,
.upload-card h4,
.contrato-form label{
  color:#172033 !important;
}

.section-head p,
.section-mini-head p,
.upload-card p{
  color:#5f6f86 !important;
}

.contrato-card{
  border-color:#dce6f2;
  box-shadow:0 18px 54px rgba(15,23,42,.09);
}

.section-head{
  background:linear-gradient(180deg,#ffffff 0%,#f6f9fc 100%);
}

.step-number{
  background:#e8f7ff;
  color:#075985;
  border-color:#bae6fd;
}

.contrato-scroll{
  color:#172033;
  background:#fff;
}

.contrato-body,
.cci-contrato-html,
.contrato-body p,
.contrato-body li{
  color:#182234;
}

.cci-doc-cover h2,
.contrato-body h1,
.contrato-body h2,
.contrato-body h3{
  color:#101827 !important;
}

.contrato-form input[type=text]{
  color:#101827;
  background:#fff;
  border-color:#d5dfeb;
}

.biometria-section,
.firma-box{
  background:#f7fafc;
}

.upload-card{
  background:#ffffff;
}

.accept-box{
  background:#fff8ed;
  color:#713f12;
}

.btn-firmar{
  background:linear-gradient(135deg,#0f8f4b,#0f6f3f) !important;
  color:#ffffff !important;
}

.contrato-mini-footer{
  margin-top:22px;
  padding:16px 20px;
  border:1px solid #dce6f2;
  border-radius:22px;
  background:linear-gradient(180deg,#fff,#f8fafc);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.contrato-mini-footer-text strong{
  display:block;
  color:#102033;
  font-size:13px;
  font-weight:900;
}

.contrato-mini-footer-text span{
  display:block;
  margin-top:3px;
  color:#64748b;
  font-size:12px;
}

.contrato-footer-logo{
  width:96px;
  max-height:42px;
  object-fit:contain;
  opacity:.92;
}

.print-brand-block{
  display:flex;
  align-items:center;
  gap:12px;
}

.print-main-logo{
  width:58px;
  height:auto;
  object-fit:contain;
}

.print-campus-logo{
  width:72px;
  height:auto;
  margin-top:6px;
  opacity:.88;
}

@media (max-width:900px){
  .contrato-hero{
    display:block;
    text-align:left;
  }

  .contrato-hero-brand{
    margin-top:22px;
    max-width:240px;
    min-height:120px;
  }

  .contrato-hero h1{
    font-size:clamp(30px,9vw,44px);
  }

  .contrato-mini-footer{
    flex-direction:column;
    text-align:center;
  }
}

@media print{
  .contrato-mini-footer{display:none!important;}
  .print-main-logo{width:44px;}
  .print-campus-logo{width:54px;}
}
