/* ==========================================================================
   Resumen · Overlay (PRO) — Layout / Panels / KPI / Cats / Activity / Table
   - inline-compact · sin lift · glass consistente · DRY en hover/containers
   - Depende de tokens: --pd-panel-bg/--pd-panel-bg2/--pd-card-shadow/--pd-card-shadow-strong/--pd-pill-*
   ========================================================================== */

/* ==========================================================================
   00) Resumen · Shell
   ========================================================================== */
.pd-dash{padding:0;}
.pd-dash-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:0;}
.pd-dash-title{font-size:14px;font-weight:700;color:rgba(2,6,23,.86);}
.pd-dash-sub{margin-top:4px;font-size:12.5px;line-height:1.5;color:rgba(15,23,42,.58);}

/* columna izquierda: apila tarjetas de Resumen */
.pd-maincol{display:grid;gap:12px;min-width:0;}

/* ==========================================================================
   01) Panel base (head + actions)
   ========================================================================== */
.pd-panel{
  background:var(--pd-panel-bg);
  border:0;border-radius:16px;
  box-shadow:var(--pd-card-shadow-strong);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  overflow:hidden;background-clip:padding-box;
}
.pd-panel-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 14px;
  border-bottom:1px solid rgba(15,23,42,.08);
  background:linear-gradient(180deg,color-mix(in oklch,var(--surface,#fff) 65%,transparent),color-mix(in oklch,var(--surface,#fff) 40%,transparent));
}
.pd-panel-title{font-size:13px;font-weight:750;letter-spacing:-.01em;color:rgba(2,6,23,.88);}
.pd-panel-actions{display:flex;align-items:center;gap:10px;}
.pd-mini{font-size:12px;color:rgba(15,23,42,.55);}

/* ==========================================================================
   01.1) Resumen · Spacing entre paneles (split Resumen QuVi)
   ========================================================================== */
.pd-mainrow > .pd-panel + .pd-panel{margin-top:12px;}

/* ==========================================================================
   02) Resumen · KPI grid
   ========================================================================== */
.pd-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:12px;}
.pd-kpi{
  background:var(--pd-panel-bg2);
  border:0;border-radius:16px;
  padding:12px 14px;
  box-shadow:var(--pd-card-shadow);
  overflow:hidden;background-clip:padding-box;
}
@media (hover:hover){.pd-kpi:hover{box-shadow:var(--pd-card-shadow);}}
.pd-kpi-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;}
.pd-kpi-label{font-size:12px;color:rgba(15,23,42,.60);}

/* ==========================================================================
   03) Resumen · Categories (tone bar + bullets)
   ========================================================================== */
.pd-cats-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin:12px 0 10px;}
.pd-cats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.pd-cat{
  position:relative;
  padding:10px;border:0;border-radius:14px;
  background:color-mix(in oklch,var(--surface,#fff) 62%,transparent);
  box-shadow:var(--pd-card-shadow);
  overflow:hidden;background-clip:padding-box;
}
@media (hover:hover){.pd-cat:hover{box-shadow:var(--pd-card-shadow);}}
.pd-cat::before{
  content:"";display:block;height:3px;margin-bottom:10px;border-radius:999px;
  background:rgba(15,23,42,.12);
}
.pd-cat-title{margin:0 0 8px;font-size:12.5px;font-weight:760;letter-spacing:-.01em;color:rgba(2,6,23,.86);}

.pd-cats-grid .pd-cat:nth-child(1)::before{background:linear-gradient(90deg,var(--pd-tone-good-a),var(--pd-tone-good-b));}
.pd-cats-grid .pd-cat:nth-child(2)::before{background:linear-gradient(90deg,var(--pd-tone-risk-a),var(--pd-tone-risk-b));}
.pd-cats-grid .pd-cat:nth-child(3)::before{background:linear-gradient(90deg,var(--pd-tone-rec-a),var(--pd-tone-rec-b));}
.pd-cats-grid .pd-cat:nth-child(4)::before{background:linear-gradient(90deg,var(--pd-tone-ctx-a),var(--pd-tone-ctx-b));}

.pd-bullets{margin:0;padding:0;list-style:none;display:grid;gap:0;}
.pd-bullets li{
  position:relative;
  display:flex;gap:10px;
  padding:9px 0;
  font-size:12.8px;line-height:1.5;
  color:rgba(15,23,42,.76);
}
.pd-bullets li+li{border-top:1px dashed rgba(15,23,42,.16);}
.pd-bullets li::before{
  content:"";
  width:2px;height:14px;flex:0 0 2px;
  margin-top:.35em;border-radius:999px;
  background:rgba(15,23,42,.22);
}
.pd-cat-empty{padding:2px 0 0;font-size:12.6px;line-height:1.55;color:rgba(15,23,42,.58);}

/* ==========================================================================
   04) Resumen · Activity (timeline + today + pills + 1 button)
   ========================================================================== */
.pd-activity{padding:12px 14px;display:grid;gap:12px;}
.pd-activity-box{
  border:0;border-radius:16px;
  background:color-mix(in oklch,var(--surface,#fff) 62%,transparent);
  box-shadow:var(--pd-card-shadow);
  overflow:hidden;background-clip:padding-box;
}
.pd-activity-box--recent{padding:10px 12px 12px;}
.pd-activity-box--today{padding:12px 12px 12px;}

/* timeline list */
.pd-activity-list{
  --tl-x:12px;--tl-dot:8px;
  position:relative;
  display:grid;gap:0;
  padding:2px 0 0;
}
.pd-activity-list::before{
  content:"";
  position:absolute;left:var(--tl-x);top:12px;bottom:12px;
  width:1px;transform:translateX(-50%);
  background:rgba(15,23,42,.12);
}
.pd-activity-item{
  position:relative;
  padding:10px 0 10px calc(var(--tl-x) + 14px);
  display:grid;gap:2px;
  border:0;background:transparent;border-radius:0;box-shadow:none;
}
.pd-activity-item+.pd-activity-item::after{
  content:"";
  position:absolute;left:calc(var(--tl-x) + 14px);right:0;top:0;
  border-top:1px dashed rgba(15,23,42,.08);
  pointer-events:none;
}
.pd-activity-item::before{
  content:"";
  position:absolute;left:var(--tl-x);top:18px;
  width:var(--tl-dot);height:var(--tl-dot);
  border-radius:999px;transform:translate(-50%,-50%);
  background:rgb(148,163,184);
  z-index:2;
}
.pd-activity-title{font-size:12.6px;font-weight:720;color:rgba(2,6,23,.88);}
.pd-activity-sub{font-size:11.8px;color:rgba(15,23,42,.60);}
.pd-activity-time{font-size:11px;color:rgba(15,23,42,.45);}

/* one CTA */
.pd-activity-actions{display:flex;justify-content:center;padding:10px 0 0;}
.pd-activity-more{width:100%;}

/* today box */
.pd-activity-today-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;}
.pd-activity-today-title{font-size:13px;font-weight:780;letter-spacing:-.01em;color:rgba(2,6,23,.88);}
.pd-activity-today-kpis{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;padding:2px 2px 0;}
.pd-activity-today-left{display:grid;gap:4px;}
.pd-activity-today-value{font-size:30px;font-weight:820;letter-spacing:-.02em;line-height:1;color:rgba(2,6,23,.92);font-variant-numeric:tabular-nums;}
.pd-activity-today-foot{font-size:12px;color:rgba(15,23,42,.58);}
.pd-activity-today-right{display:grid;gap:4px;justify-items:end;text-align:right;}
.pd-activity-today-label{font-size:12px;color:rgba(15,23,42,.55);}
.pd-activity-today-ago{font-size:14px;font-weight:780;color:rgba(2,6,23,.88);}
.pd-activity-today-divider{height:1px;background:rgba(15,23,42,.10);margin:12px 0 10px;}

/* pills */
.pd-activity-kpi-pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;}
.pd-activity-kpi-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 8px;border-radius:var(--rad-pill,9999px);
  border:1px solid var(--pd-pill-border);
  background:var(--pd-pill-bg);
  box-shadow:none;
  font-size:11.5px;color:rgba(2,6,23,.76);
}

/* ==========================================================================
   05) Resumen · Table (Coberturas por prestador)
   - rows: cards (sin acción) · head: uppercase
   ========================================================================== */
.pd-table{padding:8px 10px 12px;}
.pd-tr{display:grid;gap:10px;padding:10px 12px;border-radius:12px;}
.pd-table--cov .pd-tr:not(.pd-th){padding-top:8px;padding-bottom:8px;}
.pd-th{
  padding-top:12px;padding-bottom:8px;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(15,23,42,.52);
}
.pd-tr:not(.pd-th){
  margin-top:8px;
  border:0;
  background:color-mix(in oklch,var(--surface,#fff) 62%,transparent);
  box-shadow:var(--pd-card-shadow);
  overflow:hidden;background-clip:padding-box;
  font-size:12.5px;color:rgba(2,6,23,.78);
}
@media (hover:hover){.pd-tr:not(.pd-th):hover{box-shadow:var(--pd-card-shadow);}}

.pd-table--cov .pd-tr,.pd-table--cov .pd-th{grid-template-columns:2.2fr repeat(4,1fr);align-items:center;}
.pd-table--cov .pd-th>div:nth-child(n+2):nth-child(-n+4),
.pd-table--cov .pd-tr:not(.pd-th)>div:nth-child(n+2):nth-child(-n+4){text-align:center;}
.pd-table--cov .pd-th>div:nth-child(5),
.pd-table--cov .pd-tr:not(.pd-th)>div:nth-child(5){text-align:right;}

.pd-cell-prestador{display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.pd-ok{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;flex:0 0 auto;
  border-radius:999px;border:1px solid rgba(34,197,94,.18);
  background:rgba(34,197,94,.12);
  color:rgba(22,163,74,1);
  font-size:12px;line-height:1;
}

/* spacing edges */
.pd-table--cov .pd-tr:not(.pd-th)>div:nth-child(5) .pd-pill-uf{margin-left:auto;}
.pd-table--cov .pd-th>div:first-child,.pd-table--cov .pd-tr>.pd-cell-prestador{padding-left:8px;}
.pd-table--cov .pd-th>div:last-child,.pd-table--cov .pd-tr>div:last-child{padding-right:10px;}
.pd-table--cov .pd-tr:not(.pd-th)>div:last-child .pd-pill-uf{margin-right:2px;}

/* ==========================================================================
   06) Resumen · More row (footer natural)
   ========================================================================== */
.pd-moreRow{
  margin-top:10px;
  padding:12px 12px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border:0;border-radius:12px;
  background:rgba(255,255,255,.28);
  box-shadow:none;
  border-top:1px dashed rgba(15,23,42,.14);
  overflow:hidden;background-clip:padding-box;
}
.pd-moreLeft{min-width:0;}
.pd-moreTitle{font-weight:750;font-size:13px;line-height:1.2;color:rgba(2,6,23,.82);}
.pd-moreSub{margin-top:3px;font-size:12px;color:rgba(15,23,42,.60);}
.pd-moreRow .pd-btn-ghost{padding:10px 12px;font-size:12.5px;border-radius:14px;}

/* ==========================================================================
   07) Resumen · Activity reveal (stagger)
   ========================================================================== */
.pd-activity--ready .pd-activity-item,.pd-activity--ready .pd-activity-kpi{
  opacity:0;transform:translateY(6px);
  transition:opacity .22s ease,transform .22s cubic-bezier(.16,1,.3,1);
}
.pd-activity--ready.is-in .pd-activity-item,.pd-activity--ready.is-in .pd-activity-kpi{opacity:1;transform:translateY(0);}
.pd-activity--ready.is-in .pd-activity-item:nth-child(1){transition-delay:0ms;}
.pd-activity--ready.is-in .pd-activity-item:nth-child(2){transition-delay:40ms;}
.pd-activity--ready.is-in .pd-activity-item:nth-child(3){transition-delay:80ms;}
.pd-activity--ready.is-in .pd-activity-kpi{transition-delay:120ms;}

/* ==========================================================================
   08) Responsive (panel + resumen)
   ========================================================================== */
@media (max-width:860px){
  .plan-detail-panel{max-width:100%;border-left:0;border-right:0;border-radius:16px 16px 0 0;}
  .plan-detail-body{grid-template-columns:1fr;}
  .plan-detail-sidebar{
    padding:10px var(--pd-pad-x);
    position:sticky;top:0;z-index:2;
    background:var(--surface,#fff);
    border-right:0;border-bottom:0;
  }
  .plan-detail-nav{
    flex-direction:row;gap:6px;overflow:auto;
    padding:2px 0 8px;border-bottom:0;
    -webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;
  }
  .plan-detail-navitem{white-space:nowrap;scroll-snap-align:start;padding:8px 10px;border-radius:999px;width:auto;}
  .plan-detail-sidebar-card{padding-top:8px;border-top:0;grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;}
  .plan-detail-cta{grid-column:1/-1;}
  .pd-view{padding-top:12px;}
}
@media (max-width:980px){
  .pd-kpis{grid-template-columns:repeat(2,minmax(0,1fr));}
  .pd-mainrow{grid-template-columns:1fr;}
  .pd-cats-grid{grid-template-columns:1fr;}
}