
.cp-portal-shell{display:flex; min-height:100vh; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial;}

/* Menú lateral "manteca" */
:root{--cp-menu-bg:#f5efeb; --cp-menu-border:#e6ddd8; --cp-menu-hover:#c8d9e7; --cp-menu-active:#c8d9e7;}
.cp-portal-nav{width:280px; background:var(--cp-menu-bg); color:#0f172a; padding:18px; display:flex; flex-direction:column; gap:14px; border-right:1px solid var(--cp-menu-border); height:100vh; overflow-y:auto;}
.cp-portal-brand{font-weight:700; font-size:18px;}
.cp-portal-user{opacity:.85; font-size:13px; padding-bottom:10px; border-bottom:1px solid rgba(0,0,0,.08);}

/* Portal Paciente: bloque de bienvenida (se muestra especialmente en mobile) */
.cp-pac-welcome{display:none; padding:12px 14px; border:1px solid var(--cp-menu-border); border-radius:16px; background:#fff;}
.cp-pac-welcome-title{font-weight:800; font-size:16px; line-height:1.15;}
.cp-pac-welcome-sub{margin-top:6px; font-weight:700; opacity:.85;}

/* Portal Paciente: menú en grilla (debajo de la bienvenida, sólo mobile) */
.cp-pac-home-menu{display:none; margin-top:16px; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px;}
.cp-pac-home-btn{display:flex; align-items:center; justify-content:center; text-align:center; padding:18px 14px; border-radius:18px; background:#f5efeb; border:1px solid var(--cp-menu-border); color:#0f172a; text-decoration:none; font-weight:800; font-size:18px; line-height:1.15;}
.cp-pac-home-btn:hover{background:var(--cp-menu-hover);}
.cp-pac-home-logout{display:none; margin-top:18px; width:100%; box-sizing:border-box; padding:16px 14px; border-radius:18px; background:var(--cp-menu-hover); border:1px solid var(--cp-menu-border); color:#0f172a; text-decoration:none; font-weight:800; font-size:18px; text-align:center;}

/* Portal Profesional: Home mobile con botones grandes */
.cp-pro-welcome{display:none; padding:12px 14px; border:1px solid var(--cp-menu-border); border-radius:16px; background:#fff; margin-bottom:14px;}
.cp-pro-welcome-title{font-weight:900; font-size:16px; line-height:1.15;}
.cp-pro-welcome-sub{margin-top:6px; font-weight:800; opacity:.85;}
.cp-pro-home-menu{display:none; margin-top:16px; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px;}
.cp-pro-home-btn{display:flex !important; align-items:center; justify-content:center; text-align:center; padding:16px 12px !important; border-radius:18px !important; background:#c8d9e7 !important; border:1px solid #b7cddd !important; color:#0f172a !important; text-decoration:none !important; font-weight:900 !important; font-size:16px !important; line-height:1.15; min-height:54px; box-sizing:border-box;}
.cp-pro-home-btn:hover{background:#bcd0e0 !important;}
.cp-pro-home-logout{display:none; margin-top:16px; width:100%; box-sizing:border-box; padding:16px 14px !important; border-radius:18px !important; background:#c8d9e7 !important; border:1px solid #b7cddd !important; color:#0f172a !important; text-decoration:none !important; font-weight:900 !important; font-size:16px !important; text-align:center;}

/* Ítems alineados: mismo ancho/alto/padding en todos */
.cp-nav-item{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  width:100%;
  box-sizing:border-box;
  padding:12px 14px;
  border-radius:12px;
  color:#0f172a;
  text-decoration:none;
  opacity:.92;
}
.cp-nav-item:hover{background:var(--cp-menu-hover); opacity:1;}
.cp-nav-item.active{background:var(--cp-menu-active); opacity:1;}
.cp-nav-label{font-weight:650;}
.cp-logout{margin-top:auto; background:var(--cp-menu-hover);}
.cp-portal-main{flex:1; background:#fbfbfd;}
.cp-portal-inner{padding:22px;}
.cp-tiles{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; margin-top:14px;}
.cp-tile{background:#fff; border:1px solid #e7e8ef; border-radius:16px; padding:16px; text-decoration:none; color:#111827; display:flex; align-items:center;}
.cp-tile:hover{box-shadow:0 8px 20px rgba(0,0,0,.06);}
.cp-tile-title{font-weight:600;}
.cp-tile-logout{border-style:dashed;}
.cp-logout-inline{font-weight:700; text-decoration:none; color:#111827; opacity:.8;}
.cp-logout-inline:hover{opacity:1;}
.cp-toolbar{display:flex; align-items:center; gap:12px; margin-bottom:10px;}
.cp-back{text-decoration:none; color:#111827; font-weight:600;}
.cp-frame{width:100%; height:80vh; border:1px solid #e7e8ef; border-radius:16px; background:#fff;}
@media(max-width:900px){
  .cp-portal-nav{width:220px; padding:14px;}
  .cp-portal-brand{font-size:16px;}
}

/*
  IMPORTANTE:
  En algunos entornos móviles el viewport puede quedar en ~980px.
  Para asegurar que el portal se vea realmente responsive, activamos el “modo mobile” de
  Paciente/Profesional hasta 1024px.
*/
@media(max-width:1024px){
  /* Portal Paciente: home mobile */
  .cp-portal-shell.cp-role-paciente .cp-portal-nav{display:none !important;}
  .cp-portal-shell.cp-role-paciente .cp-pac-home-menu{display:grid !important;}
  .cp-portal-shell.cp-role-paciente .cp-pac-home-logout{display:block !important;}

  /* Portal Profesional: home mobile (2 columnas) */
  .cp-portal-shell.cp-role-profesional .cp-portal-nav{display:none !important;}
  .cp-portal-shell.cp-role-profesional .cp-pro-welcome{display:block !important;}
  .cp-portal-shell.cp-role-profesional .cp-pro-home-menu{display:grid !important;}
  .cp-portal-shell.cp-role-profesional .cp-pro-home-logout{display:block !important;}
}

@media(max-width:760px){
  .cp-portal-shell{flex-direction:column;}
  .cp-portal-nav{width:auto; flex-direction:row; overflow:auto; gap:8px; border-radius:0;}
  .cp-portal-nav .cp-nav-item{padding:10px;}
  .cp-portal-inner{padding:14px;}
  .cp-grid-2,.cp-grid-3{grid-template-columns:1fr;}
  .cp-table{min-width:680px;}
}
.cp-card-lite{background:#fff; border:1px solid #e7e8ef; border-radius:16px; padding:16px;}
.cp-muted{color:#6b7280; font-size:13px;}
.cp-list{margin:10px 0 0 0; display:flex; flex-direction:column; gap:10px;}
.cp-list-item{display:flex; gap:12px; align-items:center; justify-content:space-between; padding:12px 14px; border:1px solid #e7e8ef; border-radius:14px; background:#fff;}
.cp-list-title{font-weight:800; color:#111827;}

/* Componentes (para formularios dentro del portal) */
.cp-card{background:#fff; border:1px solid #e7e8ef; border-radius:16px; padding:18px;}
.cp-card h2{margin:0 0 8px 0;}

/* Portal Paciente: configuración (admin) */
.cp-portal-pac-config{max-width:980px; margin:0 auto;}
.cp-portal-pac-config h2{margin-bottom:12px;}
.cp-portal-pac-config h3{font-size:18px;}
.cp-portal-pac-config .cp-field label{font-weight:700;}
.cp-form{margin-top:14px;}
.cp-field{display:flex; flex-direction:column; gap:8px;}
.cp-field{margin-bottom:6px;}
.cp-field label{font-weight:600; color:#111827;}
.cp-form input[type="text"],
.cp-form input[type="email"],
.cp-form input[type="date"],
.cp-form select,
.cp-form textarea{padding:10px 12px; border:1px solid #d1d5db; border-radius:12px; background:#fff; font-size:14px;}
.cp-form input[type="file"]{padding:8px 0;}
.cp-form textarea{min-height:110px; resize:vertical;}
.cp-grid-2{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px;}
.cp-grid-3{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px;}
.cp-grid-1{display:grid; grid-template-columns:1fr; gap:14px;}
.cp-inline{display:flex; gap:10px; align-items:center; flex-wrap:wrap;}
.cp-btn{display:inline-flex; justify-content:center; align-items:center; padding:12px 16px;   font-weight:700; cursor:pointer; text-decoration:none;; background:#c8d9e7 !important; border:1px solid #b7cddd !important; color:#0f172a !important;}
/* Botón primario (celeste) */
.cp-btn-primary{background:#c8d9e7 !important; color:#0f172a !important; border-color:#b7cddd !important;}
.cp-btn-primary:hover{background:#bcd0e0 !important;}

/* Impresiones: botón chico, alineado a la derecha del ítem */
.cp-impresiones .cp-list-item{align-items:center;}
.cp-impresiones .cp-list-item > div{flex:1; min-width:0;}
.cp-impresiones .cp-list-title{white-space:normal;}
.cp-impresiones .cp-list-item > a.cp-btn,
.cp-impresiones .cp-list-item > span.cp-btn{
  min-width:110px !important;
  width:auto !important;
  flex:0 0 auto;
  display:inline-flex !important;
  padding:8px 12px !important;
  border-radius:12px !important;
  font-size:13px !important;
}

/* Fuerza celeste en el botón de Impresiones (evita overrides de temas/plugins) */
.cp-impresiones a.cp-btn.cp-btn-primary{background:#c8d9e7 !important; color:#0f172a !important; border-color:#b7cddd !important;}
.cp-impresiones a.cp-btn.cp-btn-primary:hover{background:#bcd0e0 !important;}

.cp-btn-lite{background:#c8d9e7 !important; border-color:#b7cddd !important; color:#0f172a !important;}
.cp-btn-danger{background:#b91c1c; color:#fff;}
.cp-btn:disabled{opacity:.55; cursor:not-allowed;}
.cp-actions{display:flex; gap:10px; flex-wrap:wrap; align-items:center;}
.cp-alert{border-radius:14px; padding:12px 14px; margin:10px 0; border:1px solid #e7e8ef; background:#fff;}
.cp-alert-ok,.cp-alert-success{border-color:#bbf7d0; background:#f0fdf4;}
.cp-alert-warn{border-color:#fde68a; background:#fffbeb;}
.cp-alert-error{border-color:#fecaca; background:#fef2f2;}
.cp-table-wrap{overflow:auto; border:1px solid #e7e8ef; border-radius:14px; margin-top:10px;}
.cp-table{width:100%; border-collapse:separate; border-spacing:0; min-width:760px;}
.cp-table th,.cp-table td{padding:10px 12px; border-bottom:1px solid #eef0f6; text-align:left; font-size:14px;}
.cp-table th{background:#f8fafc; font-weight:800; color:#111827;}
.cp-table tr:last-child td{border-bottom:0;}

/* Bloqueo de widgets / popups externos dentro del portal */
.joinchat, .joinchat__button, .joinchat__box,
.ht-ctc-chat, #ht-ctc-chat, .ht-ctc-chatbox,
.wa__popup, .wa__button, .wa__widget,
.wp-social-chat, .wptwa-toggle, .wptwa-panel,
.floating-whatsapp, .whatsapp-widget,
.wafp-widget, .wafp-popup,
#wpadminbar{display:none !important;}

/* Algunos popups se montan como iframes fijos */
iframe[src*="web.whatsapp.com" i],iframe[src*="api.whatsapp.com" i]{display:none !important;}
.cp-preview img{display:block; border:1px solid #e5e7eb; border-radius:12px; padding:8px; background:#fff;}

@media(max-width:900px){
  .cp-grid-2,.cp-grid-3{grid-template-columns:1fr;}
  .cp-table{min-width:560px;}
}

/* Ocultar widgets/flotantes externos dentro del Portal (WhatsApp / chat / etc.) */
.cp-blank .joinchat,
.cp-blank #joinchat,
.cp-blank .joinchat__button,
.cp-blank .ht-ctc-chat,
.cp-blank .ht-ctc-chat-style,
.cp-blank .wa__btn_popup,
.cp-blank .wa__btn_popup_txt,
.cp-blank .wa__popup_chat_box,
.cp-blank a[href*="wa.me"],
.cp-blank a[href*="whatsapp"],
.cp-blank .whatsapp,
.cp-blank .whatsapp-button,
.cp-blank .whtsp,
.cp-blank #chaty-widget,
.cp-blank .chaty-widget,
.cp-blank .wptwa-container,
.cp-blank .wptwa-toggle,
.cp-blank .wptwa-icon,
.cp-blank .wa__widget_container,
.cp-blank .wawp-floating,
.cp-blank .wawp-widget,
.cp-blank .wawp-button,
.cp-blank .wawp-popup,
.cp-blank .whatsapp-widget,
.cp-blank .whatsapp-chat-widget,
.cp-blank .whatsapp__widget,
.cp-blank .whatsapp-float,
.cp-blank .whatsapp-floating,
.cp-blank .wachat,
.cp-blank .wppwhatsapp,
.cp-blank .wpwa,
.cp-blank [id*="whatsapp" i],
.cp-blank [class*="whatsapp" i],
.cp-blank [id*="wa" i][style*="position: fixed" i],
.cp-blank [class*="wa" i][style*="position: fixed" i]{
  display:none !important;
}

/* Extra: si un plugin inyecta un iframe o contenedor flotante */
.cp-blank iframe[src*="web.whatsapp.com" i],
.cp-blank iframe[src*="api.whatsapp.com" i],
.cp-blank iframe[src*="wa.me" i]{
  display:none !important;
}


/* Hardening: ocultar widgets externos (WhatsApp/chat) dentro del portal */
.cp-blank .joinchat,
.cp-blank #joinchat,
.cp-blank .ht-ctc-chat,
.cp-blank .wa__btn_popup,
.cp-blank .wa__popup_chat_box,
.cp-blank #chaty-widget,
.cp-blank .chaty-widget,
.cp-blank [id*="whatsapp"],
.cp-blank [class*="whatsapp"],
.cp-blank [id*="WhatsApp"],
.cp-blank [class*="WhatsApp"]{
  display:none !important;
}


/* Ocultar widgets flotantes (WhatsApp / chats) dentro del portal */
.joinchat,.joinchat__button,.qlwapp,.qlwapp-container,#qlwapp,.wa__btn_popup,.wa__popup_chat_box,.ht-ctc-chat,.ht_ctc_chat,.wp-social-chat,.wpmobilechat,.floating-wpp,.wa__btn{display:none !important;}

/* Sueldos (empleado): 2 columnas (Recibos / Aportes) */
.cp-suel-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start;}
.cp-suel-col{background:#fff;border:1px solid #e7e8ef;border-radius:16px;padding:14px;}
.cp-suel-title{margin:0 0 8px 0;font-size:16px;font-weight:700;color:#111827;}
.cp-suel-col .cp-list{margin:10px 0 0 0;}
@media(max-width:760px){
  .cp-suel-grid{grid-template-columns:1fr;}
}

.cp-portal-powered{margin-top:auto;padding-top:10px;border-top:1px solid rgba(0,0,0,.08);font-size:12px;opacity:.85;position:sticky;bottom:0;background:var(--cp-menu-bg);}
.cp-portal-powered a{text-decoration:none; color:inherit;}

/* ===== Certificados (empleado) ===== */
.cp-cert-doc{background:#fff;border:1px solid #e7e8ef;border-radius:12px;overflow:hidden;}
.cp-cert-header img{display:block; width:100%; height:auto;}
.cp-cert-body{padding:18px 18px 6px 18px;}
.cp-cert-prof-header{text-align:center;margin:8px 0 16px;font-size:13.5px;line-height:1.35;color:#111827;}
.cp-cert-search{margin:0 0 10px 0;}
.cp-cert-search-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.cp-cert-search-row input{max-width:420px; flex:1 1 320px;}
.cp-cert-search-row button{flex:0 0 auto; min-width:160px; width:auto !important;}
.cp-cert-body h3{margin:0 0 10px 0;font-size:18px;}
.cp-cert-text{margin-top:10px;line-height:1.55;}
.cp-cert-form textarea{width:100%; min-height:160px; font-family:inherit;}
.cp-cert-actions .cp-btn{min-width:200px;}
.cp-cert-sign{margin-top:22px;display:flex;justify-content:space-between;gap:16px;align-items:flex-end;}
.cp-cert-sign-right{justify-content:flex-end;}
.cp-cert-sign-right{justify-content:flex-end;}
.cp-cert-firma{max-width:220px;max-height:110px;object-fit:contain;}
.cp-cert-firma-line{width:220px;border-bottom:1px solid #111827;height:1px;margin-bottom:6px;}
.cp-cert-prof{font-size:12.5px;line-height:1.35;text-align:left;}
.cp-cert-footer{border-top:1px solid #e7e8ef;padding:10px 14px;font-size:12px;color:#374151;}

@media print{
  /* Oculta UI del portal y deja solo el documento */
  .cp-portal-nav, .cp-portal-topbar, .cp-cert-wrap > h2, .cp-cert-wrap > form, .cp-cert-wrap .cp-notice{display:none !important;}
  .cp-portal-inner{padding:0 !important;}
  .cp-card-lite{border:0 !important; box-shadow:none !important; padding:0 !important;}
  .cp-cert-doc{border:0 !important; border-radius:0 !important;}
}

.cp-form .cp-readonly{padding:10px 12px;border:1px solid rgba(0,0,0,0.08);border-radius:10px;background:rgba(255,255,255,0.7);}
.cp-form textarea{width:100%;max-width:100%;}
.cp-form select{width:100%;}
.cp-grid{display:grid;gap:14px;}
.cp-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));}
@media(max-width:720px){.cp-grid-2{grid-template-columns:1fr;}}
.cp-notice{padding:10px 12px;border-radius:10px;margin:10px 0;border:1px solid rgba(0,0,0,0.08);}
.cp-notice-success{background:rgba(46, 204, 113, 0.10);}
.cp-notice-error{background:rgba(231, 76, 60, 0.10);}
.cp-req{color:#c0392b;}

.cp-btn-lite:hover{background:#bcd0e0 !important;}

.cp-portal-shell .cp-btn, .cp-portal-shell a.cp-btn, .cp-portal-shell button.cp-btn{background:#c8d9e7 !important; border:1px solid #b7cddd !important; color:#0f172a !important;}


/* ===== Recordatorios WA full-screen embed (v0.4.54) ===== */
.cp-portal-main-wa,
.cp-portal-main-wa .cp-portal-inner{
  padding-top: 0 !important;
  padding-right: 0 !important;
  padding-left: 0 !important;
  margin: 0 !important;
}
.cp-portal-main-wa .cpwa-embed-wrap{
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.cp-portal-main-wa .cpwa-embed-iframe{
  width: 100% !important;
  height: calc(100vh - 90px) !important; /* deja lugar para header del portal */
  border: 0 !important;
  display: block !important;
  background: #fff !important;
}
/*test*/

/* Modal (Empleados - sesiones) */
.cp-modal{position:fixed; inset:0; display:none; z-index:99999;}
.cp-modal[aria-hidden="false"]{display:block;}
.cp-modal__overlay{position:absolute; inset:0; background:rgba(0,0,0,.35);}
.cp-modal__dialog{position:relative; max-width:900px; width:calc(100% - 32px); margin:60px auto; background:#fff; border-radius:16px; box-shadow:0 20px 60px rgba(0,0,0,.25); overflow:hidden;}
.cp-modal__header{display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid rgba(0,0,0,.06);}
.cp-modal__body{padding:14px 16px; max-height:70vh; overflow:auto;}
.cp-modal__close{border:0; background:transparent; font-size:28px; line-height:1; cursor:pointer; padding:0 6px; opacity:.7;}
.cp-modal__close:hover{opacity:1;}
body.cp-modal-open{overflow:hidden;}

/* ===== Empleados (portal admin) - botones más proporcionados ===== */
.cp-empleados .cp-btn,
.cp-empleados a.cp-btn,
.cp-empleados button.cp-btn{
  padding: 8px 16px !important;
  min-height: auto !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
  border-radius: 18px !important;
}

.cp-empleados .cp-btn.cp-btn-primary{
  padding: 7px 14px !important;
  font-size: 13px !important;
}

.cp-empleados .cp-btn.cp-btn-danger{
  padding: 9px 18px !important;
  font-size: 14px !important;
}

/* Botón del detalle (Ver sesiones) */
.cp-empleados .cp-emp-sessions-btn{
  padding: 7px 14px !important;
  font-size: 13px !important;
}


/* Pedidos recepción – botones en línea */
.cp-actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px;}
.cp-actions-row .cp-btn{flex:1 1 220px;padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.2;}
@media (max-width:768px){.cp-actions-row .cp-btn{flex:1 1 calc(50% - 12px);}}
@media (max-width:520px){.cp-actions-row .cp-btn{flex:1 1 100%;}}


/* Estudios (Paciente > Descargar) */
.cp-paciente-estudios .cp-list{display:flex; flex-direction:column; gap:10px;}
.cp-paciente-estudios .cp-list-item{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 14px; border:1px solid rgba(0,0,0,.06); border-radius:14px; background:#fff;}
.cp-paciente-estudios .cp-list-item__title{font-size:14px; font-weight:600; color:#2c3e50;}
.cp-paciente-estudios .cp-btn{font-size:14px; padding:10px 14px; border-radius:12px;}
/* Modal de estudio: sólo visor */
.cp-estudio-modal__dialog{max-width:1100px; width:calc(100% - 24px); margin:28px auto; border-radius:16px;}
.cp-estudio-modal__body{padding:0; max-height:none; overflow:hidden;}
.cp-estudio-modal__body iframe{width:100%; height:78vh; border:0; display:block;}
.cp-estudio-modal__close{position:absolute; top:10px; right:10px; width:34px; height:34px; border-radius:999px; background:#fff; box-shadow:0 10px 25px rgba(0,0,0,.15); opacity:1;}

/* =====================
   Responsive improvements (Portal Paciente)
   ===================== */
@media(max-width:640px){
  /* Evita zoom en iOS y mejora tactil */
  .cp-form input[type="text"],
  .cp-form input[type="email"],
  .cp-form input[type="date"],
  .cp-form input[type="url"],
  .cp-form select,
  .cp-form textarea{font-size:16px;}

  /* Toolbars y acciones en columna */
  .cp-toolbar{flex-direction:column; align-items:flex-start;}
  .cp-actions{flex-direction:column; align-items:stretch;}
  .cp-inline{flex-direction:column; align-items:stretch;}
  .cp-inline > *{width:100%; max-width:none !important;}

  /* Botones full-width */
  a.cp-btn, button.cp-btn, input.cp-btn{width:100%;}

  /* Menú: más compacto */
  .cp-portal-nav{padding:10px;}
  .cp-portal-nav .cp-nav-item{padding:10px 12px; border-radius:12px;}

  /* Tablas: modo tarjeta cuando se usa .cp-table--stack */
  .cp-table--stack{min-width:0 !important;}
  .cp-table--stack thead{display:none;}
  .cp-table--stack, .cp-table--stack tbody, .cp-table--stack tr, .cp-table--stack td{display:block; width:100%;}
  .cp-table--stack tr{border:1px solid #e7e8ef; border-radius:14px; background:#fff; margin:10px 0; overflow:hidden;}
  .cp-table--stack td{border:0; border-bottom:1px solid #eef0f6; padding:10px 12px; display:flex; gap:10px; align-items:flex-start;}
  .cp-table--stack td:last-child{border-bottom:0;}
  .cp-table--stack td::before{content:attr(data-label); font-weight:800; color:#111827; min-width:110px; flex:0 0 auto;}
}
