/* ==========================================================
   CPC Details Modal (scoped) — Bootstrap-friendly, mobile-safe
   Applies ONLY inside .cpc-details-modal-root
========================================================== */

.cpc-details-modal-root{
  --cpc-ink: #0b3460;
  --cpc-border: #d7dee7;
  --cpc-surface: #ffffff;
  --cpc-header: #f8fafc;
  --cpc-accent: #D3F49E;

  /* Bootstrap 5 / bslib uses this var for modal width */
  --bs-modal-width: 860px;
}

/* --- modal shell ----------------------------------------------------- */
.cpc-details-modal-root .modal-dialog{
  width: calc(100% - 24px);
  max-width: var(--bs-modal-width);
  margin: 16px auto;
}

@media (min-width: 768px){
  .cpc-details-modal-root .modal-dialog{
    width: calc(100% - 48px);
    margin: 24px auto;
  }
}

.cpc-details-modal-root .modal-content{
  border: 0;
  border-radius: 18px;
  overflow: hidden;
  background: var(--cpc-surface);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
  min-height: 78vh;          /* opens tall */
}

.cpc-details-modal-root .modal-header{
  padding: 16px 18px;
  background: var(--cpc-header);
  border-bottom: 1px solid rgba(0,0,0,0.08);
  align-items: flex-end;
}

@media (min-width: 768px){
  .cpc-details-modal-root .modal-header{ padding: 18px 22px 12px 22px; }
}

.cpc-details-modal-root .modal-title{
  font-weight: 800;
  color: var(--cpc-ink);
  letter-spacing: .02em;
}

.cpc-details-modal-root .modal-body{
  padding: 0; /* panel provides padding */
  background: var(--cpc-surface);
}

/* --- inner panel layout --------------------------------------------- */
.cpc-details-modal-root .cpc-panel{
  display: flex;
  flex-direction: column;
  min-height: 78vh;
  max-height: calc(100vh - 48px);
}

.cpc-details-modal-root .cpc-panel-body{
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 16px 18px 10px 18px;
}

@media (min-width: 768px){
  .cpc-details-modal-root .cpc-panel-body{
    padding: 22px 26px 14px 26px;
  }
}

/* centered form column (still responsive) */
.cpc-details-modal-root .cpc-form-inner{
  max-width: 760px;
  width: 100%;
  margin: 0 auto;
}

/* --- sections -------------------------------------------------------- */
.cpc-details-modal-root .cpc-section{
  border: 1px solid var(--cpc-border);
  border-radius: 16px;
  padding: 14px;
  background: var(--cpc-surface);
  margin-bottom: 14px;
}

@media (min-width: 768px){
  .cpc-details-modal-root .cpc-section{ padding: 18px; margin-bottom: 16px; }
}

.cpc-details-modal-root .cpc-section-title{
  margin: 0 0 10px 0;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(11, 52, 96, 0.85);
}

/* --- tabs (tabsetPanel) --------------------------------------------- */
.cpc-details-modal-root .nav-tabs{
  border-bottom: 1px solid rgba(0,0,0,.08);
  padding: 0 10px;
  background: #fff;
}

.cpc-details-modal-root .nav-tabs .nav-link{
  border: 0 !important;
  background: transparent !important;
  color: rgba(11, 52, 96, 0.70) !important;
  font-weight: 800;
  padding: 10px 12px;
  margin: 0 6px 0 0;
  border-radius: 12px 12px 0 0;
  transition: background .15s ease, color .15s ease;
}

.cpc-details-modal-root .nav-tabs .nav-link:hover{
  background: rgba(11, 52, 96, 0.06) !important;
  color: var(--cpc-ink) !important;
}

.cpc-details-modal-root .nav-tabs .nav-link.active{
  color: var(--cpc-ink) !important;
  background: #fff !important;
  box-shadow: 0 -3px 0 var(--cpc-accent) inset;
}

.cpc-details-modal-root .tab-content{ padding-top: 12px; }

/* --- field header (optional badges removed) -------------------------- */
.cpc-details-modal-root .cpc-field-header{
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 12px 0 8px;
}

.cpc-details-modal-root .cpc-field-title{
  font-size: 14px;
  font-weight: 650;
  color: #111827;
  line-height: 1.3;
}

.cpc-details-modal-root .cpc-field-meta{ display: none; } /* removes Optional + hints */

/* --- inputs ---------------------------------------------------------- */
.cpc-details-modal-root input.form-control,
.cpc-details-modal-root textarea.form-control,
.cpc-details-modal-root .selectize-input{
  border-radius: 10px !important;
  border: 1px solid rgba(0,0,0,0.16) !important;
  box-shadow: none !important;
}

.cpc-details-modal-root input.form-control:focus,
.cpc-details-modal-root textarea.form-control:focus,
.cpc-details-modal-root .selectize-input.focus{
  border-color: rgba(11, 52, 96, 0.45) !important;
  box-shadow: 0 0 0 3px rgba(11, 52, 96, 0.12) !important;
}

/* --- sticky footer --------------------------------------------------- */
.cpc-details-modal-root .cpc-panel-footer{
  flex: 0 0 auto;
  position: sticky;
  bottom: 0;
  z-index: 5;
  background: rgba(248, 250, 252, 0.96);
  backdrop-filter: blur(6px);
  border-top: 1px solid var(--cpc-border);
  padding: 12px 14px;
}

.cpc-details-modal-root .cpc-footer-row{
  max-width: 760px;
  margin: 0 auto;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 10px;
}

.cpc-details-modal-root .cpc-btn-next{
  min-width: 110px;
  border-radius: 12px;
  padding: 10px 18px;
  font-weight: 800;
}

/* --- tile grid (only inside this modal) ------------------------------ */
.cpc-details-modal-root .cpc-tile-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 10px;
}

@media (min-width: 768px){
  .cpc-details-modal-root .cpc-tile-grid{ grid-template-columns: 1fr 1fr; }
}

.cpc-details-modal-root .cpc-tile{
  width: 100%;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid var(--cpc-border);
  color: var(--cpc-ink);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease, transform .05s ease;
  text-align: left;
}

/* reduce bootstrap button fight */
.cpc-details-modal-root .cpc-tile.btn,
.cpc-details-modal-root .cpc-tile.btn:focus,
.cpc-details-modal-root .cpc-tile.btn:active{
  outline: none !important;
  box-shadow: none !important;
}

.cpc-details-modal-root .cpc-tile:hover{
  border-color: rgba(11, 52, 96, 0.45);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
  background: #f8fbff;
}

.cpc-details-modal-root .cpc-tile.is-active{
  border-color: rgba(11, 52, 96, 0.70);
  background: rgba(211, 244, 158, 0.22);
  box-shadow: 0 0 0 3px rgba(11, 52, 96, 0.18);
}

/* optional header close button polish */
.cpc-details-modal-root .modal-header .btn-close{
  opacity: .55;
}
.cpc-details-modal-root .modal-header .btn-close:hover{
  opacity: .85;
}
