html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: none !important;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 60px;
}

.form-group {
  margin-bottom: 1rem !important;
}

.register-wrap h3 {
  font-size: 20px;
  margin: 0;
  color: #1D1D1D;
  font-weight: 400;
}

.register-wrap h3 i {
  margin-right: 10px;
}

.sidebar-search form {
  position: relative;
}

.sidebar-search form input {
  background-color: transparent;
  color: #262626;
  height: 41px;
  border: 1px solid #cdcdcd;
  padding: 2px 40px 2px 10px;
  font-size: 12px;
}

.sidebar-search form input::-moz-input-placeholder {
  color: #262626;
  opacity: 1;
}

.sidebar-search form input::-webkit-input-placeholder {
  color: #262626;
  opacity: 1;
}

.sidebar-search form .button-search {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  color: #2f2f2f;
  background-color: transparent;
  border: none;
  padding: 5px 20px;
  transition: all 0.3s ease 0s;
}

.sidebar-search form .button-search:hover {
  color: #2f2f2f;
}

.error-input{
  border: 1px solid #f5c6cb !important;
}

.error-input-2{
  border: 2px solid #f5c6cb !important;
}

.form-wrap input {
  background: transparent;
  border: 1px solid #CDCDCD;
  color: #777;
  border-radius: 0px;
}

.form-wrap input:focus {
  border:1px solid #000;
}

.form-wrap textarea {
  background: transparent;
  border: 1px solid #CDCDCD;
  color: #777;
  border-radius: 0px;
  resize: none;
}

.form-wrap textarea:focus {
  border:1px solid #000;
}

.form-wrap select {
  background: transparent;
  border: 1px solid #CDCDCD;
  color: #777;
  border-radius: 0px;
  box-shadow: none;
  appearance: none;
  padding: 10px 20px !important;
}

.form-wrap select:focus {
  border:1px solid #000 !important;
}

.label-click{
  text-decoration: underline;
  cursor: pointer;
}

.cursor-pointer{
  cursor: pointer !important;
}

.no-padding{
  padding: 0px !important;
  margin: 0px !important;
}

#contextMenu{
  font-size: 12px !important;
}

.fc-event-ac31aa{
  background-color: #ac31aa !important;
  color: #ffffff !important;
}

.fc-event-c2002f{
  background-color: #c2002f !important;
  color: #ffffff !important;
}

.fc-event-093071{
  background-color: #093071 !important;
  color: #ffffff !important;
}

.fc-event-008c99{
  background-color: #008c99 !important;
  color: #ffffff !important;
}

.fc-event-555559{
  background-color: #555559 !important;
  color: #ffffff !important;
}

.fc-event-ef7a3d{
  background-color: #ef7a3d !important;
  color: #ffffff !important;
}

.fc-event-2E4A93{
  background-color: #2E4A93 !important;
  color: #ffffff !important;
}

.fc-event-9fc63b{
  background-color: #9fc63b !important;
  color: #ffffff !important;
}

.fc-event-007AC2{
  background-color: #007AC2 !important;
  color: #ffffff !important;
}

.fc-event-0a3c53{
  background-color: #0a3c53 !important;
  color: #ffffff !important;
}

.fc-event-F7DC6F{
  background-color: #F7DC6F !important;
  color: #ffffff !important;
}

.fc-event-F38A00{
  background-color: #F38A00 !important;
  color: #ffffff !important;
}

.p-20{
  padding: 20px;
}

.sidebar-search form {
  position: relative;
}

.sidebar-search form input {
  background-color: transparent;
  color: #262626;
  height: 41px;
  border: 1px solid #cdcdcd;
  padding: 2px 40px 2px 10px;
  font-size: 12px;
}

.sidebar-search form input::-moz-input-placeholder {
  color: #262626;
  opacity: 1;
}

.sidebar-search form input::-webkit-input-placeholder {
  color: #262626;
  opacity: 1;
}

.sidebar-search form .button-search {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  color: #2f2f2f;
  background-color: transparent;
  border: none;
  padding: 5px 20px;
  transition: all 0.3s ease 0s;
}

.sidebar-search form .button-search:hover {
  color: #2f2f2f;
}

.ui-autocomplete-loading {
  background: #fff url(/assets/images/ajax-loader.gif) no-repeat 95% !important;
}

.login-form-movil .input {
  width: 50% !important;
}

.no-margin {
  margin: 0 !important;
}

.login-register-form-wrap .content2 h1 {
  font-weight: 300;
  line-height: 1;
  margin-bottom: 15px;
}

.login-register-form-wrap .content2 p {
  margin-bottom: 30px;
}

.show-overflow-x{
  overflow-x: auto; 
  overflow-y: hidden;
}

.content-list {
  height: 116px;
  overflow: auto;
  border: 1px solid #CDCDCD;
  padding: 10px 20px;
}

.mb-1rem{
  margin-bottom: 1rem !important;
}

.mb-2rem{
  margin-bottom: 2rem !important;
}

.plan-active{
  border: 10px solid;
}

.overflow-y-hidden{
  overflow-y: hidden;
}

input[name="email"] {
  text-transform: lowercase;
}

.p10{
  padding: 10px 10px;
}

.header-section {
  background-image: url(/assets/images/header/header_brokware.jpg) !important;
}

.top-report .head h4 {
  color: #8C8C22 !important;
}

h1, h2, h3, h4, h5, h6 {
  color: #445363 !important;
}

.top-report .footer .progess .progess-bar {
  background: linear-gradient(to right, #CA003D 0%, #FFC844 100%) !important;
}

.adomx-dropdown-menu li a:hover {
  color: #FE3B1F !important;
}

.dropdown-menu-user .head .name a:hover {
  color: #FE3B1F !important;
}

.dropdown-menu-user .head .mail:hover {
  color: #FE3B1F !important;
}

.side-header-toggle:hover {
  color: #FE3B1F !important;
}

.side-header-menu > ul > li.active > a, .side-header-menu > ul > li:hover > a {
  color: #FE3B1F !important;
}

.side-header-menu > ul > li > a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 0;
  background-color: #FE3B1F !important;
}

.side-header-menu > ul > li.active > a, .side-header-menu > ul > li > a.active {
  color: #FE3B1F !important;
  text-decoration: underline;
}

.button-brokware, .swal-modal .swal-footer .button-brokware, #toast-container .toast .toast-message .btn.btn-brokware, .dataTables_wrapper .dt-buttons .dt-button, .footable.table thead tr th .footable-filtering-search .input-group .input-group-btn .btn, .footable.table thead tr th .footable-filtering-search .input-group .input-group-btn .btn.btn-brokware, .footable.table tbody tr td.footable-editing .btn-group .btn.footable-edit, .footable.table tfoot tr.footable-editing td .btn.btn-brokware, .smart-wizard .sw-toolbar .sw-btn-group .btn {
  background-color: #BACF5E !important;
  border-color: #BACF5E !important;
  color: #ffffff !important;
}.button-brokware.button-outline, .swal-modal .swal-footer .button-outline.button-brokware, #toast-container .toast .toast-message .button-outline.btn.btn-brokware, #toast-container .toast .toast-message .footable.table tfoot tr.footable-editing td .btn.btn-brokware.footable-hide, .footable.table tfoot tr.footable-editing td #toast-container .toast .toast-message .btn.btn-brokware.footable-hide, .dataTables_wrapper .dt-buttons .button-outline.dt-button, .dataTables_wrapper .dt-buttons .footable.table tfoot tr.footable-editing td .dt-button.btn.footable-hide, .footable.table tfoot tr.footable-editing td .dataTables_wrapper .dt-buttons .dt-button.btn.footable-hide, .footable.table thead tr th .footable-filtering-search .input-group .input-group-btn .button-outline.btn, .footable.table thead tfoot tr.footable-editing th .footable-filtering-search .input-group .input-group-btn td .btn.footable-hide, .footable.table tfoot thead tr.footable-editing th .footable-filtering-search .input-group .input-group-btn td .btn.footable-hide, .footable.table thead tfoot tr.footable-editing td th .footable-filtering-search .input-group .input-group-btn .btn.footable-hide, .footable.table tfoot thead tr.footable-editing td th .footable-filtering-search .input-group .input-group-btn .btn.footable-hide, .footable.table thead tfoot tr.footable-editing th .footable-filtering-search .input-group .input-group-btn td .btn.btn-brokware.footable-hide, .footable.table tfoot thead tr.footable-editing th .footable-filtering-search .input-group .input-group-btn td .btn.btn-brokware.footable-hide, .footable.table thead tfoot tr.footable-editing td th .footable-filtering-search .input-group .input-group-btn .btn.btn-brokware.footable-hide, .footable.table tfoot thead tr.footable-editing td th .footable-filtering-search .input-group .input-group-btn .btn.btn-brokware.footable-hide, .footable.table tbody tr td.footable-editing .btn-group .button-outline.btn.footable-edit, .footable.table tbody tfoot tr.footable-editing td.footable-editing .btn-group .btn.footable-edit.footable-hide, .footable.table tfoot tbody tr.footable-editing td.footable-editing .btn-group .btn.footable-edit.footable-hide, .footable.table tfoot tr.footable-editing td .button-outline.btn.btn-brokware, .footable.table tfoot tr.footable-editing td .btn.btn-brokware.footable-hide, .footable.table tfoot tr.footable-editing td .button-brokware.btn.footable-hide, .smart-wizard .sw-toolbar .sw-btn-group .button-outline.btn, .smart-wizard .sw-toolbar .sw-btn-group .footable.table tfoot tr.footable-editing td .btn.footable-hide, .footable.table tfoot tr.footable-editing td .smart-wizard .sw-toolbar .sw-btn-group .btn.footable-hide {
  background-color: transparent !important;
  color: #BACF5E !important;
}.button-brokware.button-outline:hover, #toast-container .toast .toast-message .button-outline.btn.btn-brokware:hover, #toast-container .toast .toast-message .footable.table tfoot tr.footable-editing td .btn.btn-brokware.footable-hide:hover, .footable.table tfoot tr.footable-editing td #toast-container .toast .toast-message .btn.btn-brokware.footable-hide:hover, .dataTables_wrapper .dt-buttons .button-outline.dt-button:hover, .dataTables_wrapper .dt-buttons .footable.table tfoot tr.footable-editing td .dt-button.btn.footable-hide:hover, .footable.table tfoot tr.footable-editing td .dataTables_wrapper .dt-buttons .dt-button.btn.footable-hide:hover, .footable.table thead tr th .footable-filtering-search .input-group .input-group-btn .button-outline.btn:hover, .footable.table thead tfoot tr.footable-editing th .footable-filtering-search .input-group .input-group-btn td .btn.footable-hide:hover, .footable.table tfoot thead tr.footable-editing th .footable-filtering-search .input-group .input-group-btn td .btn.footable-hide:hover, .footable.table thead tfoot tr.footable-editing td th .footable-filtering-search .input-group .input-group-btn .btn.footable-hide:hover, .footable.table tfoot thead tr.footable-editing td th .footable-filtering-search .input-group .input-group-btn .btn.footable-hide:hover, .footable.table thead tfoot tr.footable-editing th .footable-filtering-search .input-group .input-group-btn td .btn.btn-brokware.footable-hide:hover, .footable.table tfoot thead tr.footable-editing th .footable-filtering-search .input-group .input-group-btn td .btn.btn-brokware.footable-hide:hover, .footable.table thead tfoot tr.footable-editing td th .footable-filtering-search .input-group .input-group-btn .btn.btn-brokware.footable-hide:hover, .footable.table tfoot thead tr.footable-editing td th .footable-filtering-search .input-group .input-group-btn .btn.btn-brokware.footable-hide:hover, .footable.table tbody tr td.footable-editing .btn-group .button-outline.btn.footable-edit:hover, .footable.table tbody tfoot tr.footable-editing td.footable-editing .btn-group .btn.footable-edit.footable-hide:hover, .footable.table tfoot tbody tr.footable-editing td.footable-editing .btn-group .btn.footable-edit.footable-hide:hover, .footable.table tfoot tr.footable-editing td .button-outline.btn.btn-brokware:hover, .footable.table tfoot tr.footable-editing td .btn.btn-brokware.footable-hide:hover, .footable.table tfoot tr.footable-editing td .button-brokware.btn.footable-hide:hover, .smart-wizard .sw-toolbar .sw-btn-group .button-outline.btn:hover, .smart-wizard .sw-toolbar .sw-btn-group .footable.table tfoot tr.footable-editing td .btn.footable-hide:hover, .footable.table tfoot tr.footable-editing td .smart-wizard .sw-toolbar .sw-btn-group .btn.footable-hide:hover {
  background-color: #BACF5E !important;
  border-color: #BACF5E !important;
  color: #ffffff !important;
}.button-brokware:hover, .swal-modal .swal-footer .button-brokware:hover, #toast-container .toast .toast-message .btn.btn-brokware:hover, .dataTables_wrapper .dt-buttons .dt-button:hover, .footable.table thead tr th .footable-filtering-search .input-group .input-group-btn .btn:hover, .footable.table tbody tr td.footable-editing .btn-group .btn.footable-edit:hover, .footable.table tfoot tr.footable-editing td .btn.btn-brokware:hover, .smart-wizard .sw-toolbar .sw-btn-group .btn:hover {
  background-color: #BACF5E !important;
  border-color: #BACF5E !important;
  color: #ffffff !important;
}

.button, .fullcalendar .fc-toolbar .fc-button, #toast-container .toast .toast-message .btn, .dataTables_wrapper .dt-buttons .dt-button, .footable.table thead tr th .footable-filtering-search .input-group .input-group-btn .btn, .footable.table tbody tr td.footable-editing .btn-group .btn, .footable.table tfoot tr.footable-editing td .btn, .smart-wizard .sw-toolbar .sw-btn-group .btn {
  background-color: #BACF5E !important;
  border-color: #BACF5E !important;
  color: #ffffff !important;
}

.btn-outline-brokware{
  color:#BACF5E !important;
  border-color:#BACF5E !important;
}.btn-outline-brokware:hover{
  color:#fff !important;
  background-color:#BACF5E !important;
  border-color:#BACF5E !important;
}.btn-outline-brokware.focus,.btn-outline-brokware:focus{
  box-shadow:0 0 0 .2rem rgba(186,207,94,.5) !important;
}.btn-outline-brokware.disabled,.btn-outline-brokware:disabled{
  color:#BACF5E !important;
  background-color:transparent !important;
}.btn-outline-brokware:not(:disabled):not(.disabled).active,.btn-outline-brokware:not(:disabled):not(.disabled):active,.show>.btn-outline-brokware.dropdown-toggle{
  color:#fff !important;
  background-color:#BACF5E !important;
  border-color:#BACF5E !important;
}.btn-outline-brokware:not(:disabled):not(.disabled).active:focus,.btn-outline-brokware:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-brokware.dropdown-toggle:focus{
  box-shadow:0 0 0 .2rem rgba(186,207,94,.5) !important;
}

.btn-brokware{
  color:#fff !important;
  background-color:#BACF5E !important;
  border-color:#BACF5E !important;
}.btn-brokware:hover{
  color:#fff !important;
  background-color:#BACF5E !important;
  border-color:#BACF5E !important;
}.btn-brokware.focus,.btn-brokware:focus{
  box-shadow:0 0 0 .2rem rgba(186,207,94,.5) !important;
}.btn-brokware.disabled,.btn-brokware:disabled{
  color:#fff !important;
  background-color:#BACF5E !important;
  border-color:#BACF5E !important;
}.btn-brokware:not(:disabled):not(.disabled).active,.btn-brokware:not(:disabled):not(.disabled):active,.show>.btn-brokware.dropdown-toggle{
  color:#fff !important;
  background-color:#BACF5E !important;
  border-color:#BACF5E !important;
}.btn-brokware:not(:disabled):not(.disabled).active:focus,.btn-brokware:not(:disabled):not(.disabled):active:focus,.show>.btn-brokware.dropdown-toggle:focus{
  box-shadow:0 0 0 .2rem rgba(186,207,94,.5) !important;
}

.footable-pagination-wrapper .pagination li.active a, .footable-pagination-wrapper .pagination li.active a:focus, .footable-pagination-wrapper .pagination li.active a:hover {
  background-color: #BACF5E !important;
  border-color: #BACF5E !important;
  color: #ffffff;
}

.footable-pagination-wrapper .pagination li a:hover {
  background-color: #BACF5E !important;
  border-color: #BACF5E !important;
  color: #ffffff;
}

.footable-pagination-wrapper .pagination li.disabled a {
  background-color: transparent !important;
}

.login-register-form a {
  color: #BACF5E !important;
}

.btn-link{
  font-weight:400 !important;
  color:#BACF5E !important;
  text-decoration:none;
}.btn-link:hover{
  color:#BACF5E !important;
  text-decoration:underline !important;
}.btn-link.focus,.btn-link:focus{
  text-decoration:underline !important;
  box-shadow:none !important;
}.btn-link.disabled,.btn-link:disabled{
  color:#6c757d !important;
  pointer-events:none !important;
}

.button-brokware-ft {
  background-color: #F18A00 !important;
  border-color: #F18A00 !important;
  color: #ffffff !important;
  margin-bottom: 0px !important;
  border-radius: 0px !important;
}.button-brokware-ft:hover{
  background-color: #F18A00 !important;
  border-color: #F18A00 !important;
  color: #ffffff !important;
}

.pb-3rem{
  padding-bottom: 3rem !important;
}

.input-group-text-custom-border{
  border-top: 1px solid #ced4da !important;
  border-bottom: 1px solid #ced4da !important;
  border-right: 0px !important;
  border-left: 0px !important;
}

.progress-pie-chart {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background-color: #E5E5E5;
  position: relative;
}
.progress-pie-chart.gt-50 {
  background-color: #81CE97;
}

.ppc-progress {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 100px);
  top: calc(50% - 100px);
  width: 200px;
  height: 200px;
  clip: rect(0, 200px, 200px, 100px);
}
.ppc-progress .ppc-progress-fill {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 100px);
  top: calc(50% - 100px);
  width: 200px;
  height: 200px;
  clip: rect(0, 100px, 200px, 0);
  background: #81CE97;
  transform: rotate(60deg);
}
.gt-50 .ppc-progress {
  clip: rect(0, 100px, 200px, 0);
}
.gt-50 .ppc-progress .ppc-progress-fill {
  clip: rect(0, 200px, 200px, 100px);
  background: #E5E5E5;
}

.ppc-percents {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 173.91304px/2);
  top: calc(50% - 173.91304px/2);
  width: 173.91304px;
  height: 173.91304px;
  background: #fff;
  text-align: center;
  display: table;
}
.ppc-percents span {
  display: block;
  font-size: 2.6em;
  font-weight: bold;
  color: #81CE97;
}

.pcc-percents-wrapper {
  display: table-cell;
  vertical-align: middle;
}

.progress-pie-chart {
  margin: 0px auto 0;
}

.p-05{
  padding: 5px !important;
}

.no-border-top-td{
  
}
.td-pendiente{
  /* padding: 0.25rem !important; */
  padding-top: 0px !important;
  border-top: 0px !important;
}

.li-pendiente{
  /* padding: 0.25rem !important; */
  padding: 5px !important;
}

.progress-pie-chart {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background-color: #E5E5E5;
  position: relative;
}
.progress-pie-chart.gt-50 {
  background-color: #81CE97;
}
.ppc-progress {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 100px);
  top: calc(50% - 100px);
  width: 200px;
  height: 200px;
  clip: rect(0, 200px, 200px, 100px);
}
.ppc-progress .ppc-progress-fill {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 100px);
  top: calc(50% - 100px);
  width: 200px;
  height: 200px;
  clip: rect(0, 100px, 200px, 0);
  background: #81CE97;
  transform: rotate(60deg);
}
.gt-50 .ppc-progress {
  clip: rect(0, 100px, 200px, 0);
}
.gt-50 .ppc-progress .ppc-progress-fill {
  clip: rect(0, 200px, 200px, 100px);
  background: #E5E5E5;
}
.ppc-percents {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 173.91304px/2);
  top: calc(50% - 173.91304px/2);
  width: 173.91304px;
  height: 173.91304px;
  background: #fff;
  text-align: center;
  display: table;
}
.ppc-percents span {
  display: block;
  font-size: 2.6em;
  font-weight: bold;
  color: #81CE97;
}
.pcc-percents-wrapper {
  display: table-cell;
  vertical-align: middle;
}
.progress-pie-chart {
  margin: 0px auto 0;
}
.progressbar-text{
  color: #81CE97;
  font-size: 1.3em;
  font-weight: bold;
}

.mt-30{
  margin-top: 30px;
}

.p-0-30{
  padding: 0 30px;
}

.sidebar-search div {
  position: relative;
}

.sidebar-search div input {
  /* background-color: transparent;
  color: #262626; */
  height: 41px;
  /* border: 1px solid #cdcdcd; */
  padding: 2px 40px 2px 10px;
  /* font-size: 12px; */
}

.sidebar-search div input::-moz-input-placeholder {
  /* color: #262626; */
  opacity: 1;
}

.sidebar-search div input::-webkit-input-placeholder {
  /* color: #262626; */
  opacity: 1;
}

.sidebar-search div .button-search {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  /* color: #2f2f2f; */
  background-color: transparent;
  border: none;
  padding: 5px 20px;
  transition: all 0.3s ease 0s;
}

.sidebar-search div .button-search:hover {
  /* color: #2f2f2f; */
}




.cotizador-container {
  position: relative;
  background: url('tu-imagen-auto.svg') no-repeat center right;
  background-size: cover;
  border-top: 6px solid #BFD730; /* Línea verde tipo Brokware */
  border-radius: 15px;
  padding: 60px 0;
  margin-top: 30px;
  min-height: 450px;
}

.cotizador-card {
  display: flex;
  justify-content: flex-end; /* Empuja el formulario a la derecha */
  align-items: center;
  height: 100%;
}

.cotizador-form {
  background-color: rgba(255, 255, 255, 0.9);
  border-radius: 20px;
  padding: 40px;
  width: 420px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
  backdrop-filter: blur(8px);
}

.btn-cotizar {
  background: linear-gradient(90deg, #BFD730, #A2C123);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-weight: 600;
  transition: all 0.3s ease;
}

.btn-cotizar:hover {
  background: linear-gradient(90deg, #A2C123, #91B31B);
}

/* SKELETON */
.skeleton-container {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 30px;
}

/* Estructura del card */
.skeleton-card {
  width: 250px;
  /* height: 200px; */
  border-radius: 4px;
  background: #fff;
  padding: 20px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}

/* Elementos internos tipo “líneas” */
.skeleton-line {
  height: 20px;
  /* background: #f2f2f2; */
  background: #d5e29e;
  border-radius: 4px;
  margin-bottom: 10px;
  overflow: hidden;
  position: relative;
}

/* Efecto shimmer (barrido de luz) */
.skeleton-line::after {
  content: "";
  position: absolute;
  top: 0;
  left: -150px;
  height: 100%;
  width: 150px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
  animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
  0% { left: -150px; }
  100% { left: 100%; }
}

/* Tamaños variables */
.skeleton-line.short { width: 40%; }
.skeleton-line.medium { width: 70%; }
.skeleton-line.long { width: 100%; }

.card-real {
  width: 250px;
  /* height: 200px; */
  border-radius: 4px;
  background: white;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  padding: 20px;

  transition: 0.3s;
}

.card-real img {
  width: 80px;
  height: auto;
  margin-bottom: 10px;
}

.skeleton-select {
  height: 40px; /* Altura aproximada de un select */
  border-radius: 4px;
  background: #d5e29e;
  margin-bottom: 10px;
  position: relative;
  overflow: hidden;
}

.skeleton-select::after {
  content: "";
  position: absolute;
  top: 0;
  left: -150px;
  height: 100%;
  width: 150px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
  animation: shimmer 1.5s infinite; /* Usa tu misma animación */
}

.skeleton-button {
  width: 50%;
  height: 40px; /* Altura aproximada de un select */
  border-radius: 4px;
  background: #d5e29e;
  margin-bottom: 10px;
  position: relative;
  overflow: hidden;
}

.skeleton-button::after {
  content: "";
  position: absolute;
  top: 0;
  left: -150px;
  height: 100%;
  width: 150px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
  animation: shimmer 1.5s infinite; /* Usa tu misma animación */
}

.form-skeletons {
  padding: 5px 20px;
  margin-top: 30px;
}

.form-reales {
  padding: 5px 20px;
  margin-top: 30px;
}

.form-cotizador input,
.form-cotizador select {
  background-color: #fff;
}

.coberturas-container {
  /* margin-top: 30px; */
}

.card-real2 {
  /* Base de la tarjeta */
  position: relative;
  width: 255px; /* Un poco más ancha para el contenido */
  border-radius: 4px;
  background-color: white;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  padding: 20px; /* Más padding para aire */
  display: flex; /* Usamos flexbox para organizar los elementos */
  flex-direction: column; /* Apilarlos verticalmente */
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; /* Fuente más común y limpia */
}

/* Contenedor del encabezado (logo + textos superiores) */
.card-real2 .header-content {
  display: flex; /* Para poner el logo al lado del texto */
  align-items: center; /* Alinear verticalmente al centro */
  margin-bottom: 15px; /* Separación del resto del contenido */
}

/* Estilo del logo circular */
.card-real2 .logo-aseguradora-circle {
  width: 65px; /* Tamaño del círculo */
  height: 65px;
  border-radius: 50%; /* Hacerlo circular */
  border: 0px solid #BACF5E; /* Borde de color verde */
  overflow: hidden; /* Cortar cualquier parte de la imagen que se salga */
  margin-right: 15px; /* Espacio entre el logo y el texto */
  /* background-color: #f0f0f0;  */
  background-size: cover; /* Ajustar el logo sin cortarlo si es cuadrado */
  background-repeat: no-repeat;
  background-position: center; /* Centrar el logo dentro del círculo */
  /* Aquí se establecerá la imagen de fondo con JavaScript */
  flex-shrink: 0; /* Asegura que el logo no se encoja */
}

.card-real2 .text-header {
  display: flex;
  flex-direction: column;
  justify-content: center; /* Centrar verticalmente si hay espacio */
}

.card-real2 h4 {
  color: #333; /* Gris oscuro para el nombre de la compañía */
  font-size: 1.3em; /* Un poco más grande */
  margin: 0 0 3px 0;
  font-weight: 700;
  line-height: 1.2; /* Espaciado entre líneas */
}

.card-real2 .nombre-producto {
  color: #BACF5E !important; 
  font-size: 1em;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0;
  line-height: 1.2;
}

/* Títulos para Primer Pago y Pagos Subsecuentes */
.card-real2 .label-pago {
  color: #666; /* Gris más suave */
  font-size: 0.9em;
  margin-top: 5px; /* Espacio sobre cada sección de pago */
  margin-bottom: 5px;
  font-weight: 500;
}

/* Precio del primer pago */
.card-real2 .importe-primer-pago {
  color: #F18A00; /* NARANJA para el precio fuerte */
  font-size: 2em; /* Muy grande para que destaque */
  font-weight: 800; /* Extra bold */
  margin: 0 0 15px 0; /* Quitar márgenes por defecto */
  line-height: 1; /* Asegurar que no haya espacio extra */
}

/* Sección de pagos subsecuentes */
.card-real2 .subsecuente-pago-container {
  display: flex;
  align-items: baseline; /* Alinea el texto en la línea base */
  margin-top: 5px; /* Espacio después del primer pago */
  padding-top: 10px;
  border-top: 1px solid #eee; /* Separador sutil */
}

.card-real2 .subsecuente-pago-label {
  color: #666;
  font-size: 0.9em;
  font-weight: 500;
  margin-right: 5px; /* Espacio entre el label y el monto */
}

.card-real2 .subsecuente-pago-monto {
  color: #555; /* Un gris un poco más oscuro para el monto */
  font-size: 1em; /* Normal, legible */
  font-weight: 600;
}

.card-real2 .icono-menorPrecio {
  position: absolute;
  top: 10px;
  right: 10px;
  color: #FFD700;
  font-size: 27px;
}

.card-real2-skeleton {
  /* Replicamos los estilos del contenedor de la tarjeta final */
  width: 250px;
  border-radius: 4px;
  background-color: white; 
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  padding: 20px;
  display: flex;
  flex-direction: column;
}

.card-real2-skeleton .header-content {
  display: flex; 
  align-items: center;
  margin-bottom: 15px;
}

.skeleton-circle {
  /* Estilos de forma para el logo */
  width: 65px;
  height: 65px;
  border-radius: 50%; /* ¡La clave para que se vea circular! */
  margin-right: 15px;
  flex-shrink: 0;
  /* Aplicar estilos de skeleton-line para el color y shimmer */
  background: #d5e29e; 
  position: relative;
  overflow: hidden;
}

.card-real2-skeleton .text-header {
  /* Esta línea es crucial: le dice que use el espacio restante */
  flex-grow: 1; 
  
  /* Asegura que haya espacio para las líneas */
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* 2. Nombre de la aseguradora */
.skeleton-line.long-header { 
  width: 90%;
  height: 18px; /* Un poco más alta que el texto normal */
  margin-bottom: 8px;
}

/* 3. Nombre del producto */
.skeleton-line.short-header { 
  width: 40%;
  height: 14px; 
  margin-bottom: 0;
}

/* 4. Etiqueta "Primer Pago:" */
.skeleton-line.micro-label { 
  width: 30%;
  height: 12px;
  margin-top: 15px;
  margin-bottom: 5px;
}

/* 5. Línea de Precio Principal */
.skeleton-line.large-price { 
  width: 55%;
  height: 28px; /* Muy alta para simular un precio grande */
  margin-bottom: 25px;
}

.skeleton-line.large-button { 
  width: 100%;
  height: 40px; /* Muy alta para simular un precio grande */
}

.tabla-coberturas th {
  border-top: 0px solid #dee2e6 !important;
}

.tabla-coberturas .logo-aseguradora-circle {
  width: 50px; /* Tamaño del círculo */
  height: 50px;
  border-radius: 50%; /* Hacerlo circular */
  border: 0px solid #BACF5E; /* Borde de color verde */
  overflow: hidden; /* Cortar cualquier parte de la imagen que se salga */
  /* background-color: #f0f0f0;  */
  background-size: cover; /* Ajustar el logo sin cortarlo si es cuadrado */
  background-repeat: no-repeat;
  background-position: center; /* Centrar el logo dentro del círculo */
  /* Aquí se establecerá la imagen de fondo con JavaScript */
  flex-shrink: 0; /* Asegura que el logo no se encoja */
}

.btn-custom-emitir {
  color: #333333; /* Color de texto más oscuro para contraste */
  background-color: #BACF5E; /* Tu color deseado */
  border-color: #A0C24B; /* Un borde un poco más oscuro que el fondo */
  font-weight: 600; /* Texto en semi-negrita para que destaque */
  padding: 8px 20px; /* Ajuste de padding para un tamaño cómodo */
  border-radius: 6px; /* Bordes ligeramente redondeados */
  transition: all 0.2s ease-in-out; /* Transición suave al pasar el mouse */
}

.btn-custom-emitir {
  color: #333333; /* Color de texto más oscuro para contraste */
  background-color: #BACF5E; /* Tu color deseado */
  border-color: #A0C24B; /* Un borde un poco más oscuro que el fondo */
  font-weight: 600; /* Texto en semi-negrita para que destaque */
  padding: 8px 20px; /* Ajuste de padding para un tamaño cómodo */
  border-radius: 6px; /* Bordes ligeramente redondeados */
  transition: all 0.2s ease-in-out; /* Transición suave al pasar el mouse */
}

.btn-link-custom {
  color: #BACF5E !important; 
  text-decoration: underline; 
  transition: color 0.2s ease-in-out; 
}

.btn-link-custom:hover {
  color: #A0C24B !important; 
  text-decoration: none;
}

.btn-link-custom:focus {
  color: #A0C24B !important; 
  text-decoration: underline;
}


/* WIZZARD */
.wizard-container {
  margin: 30px auto;
  padding: 20px;
}

.progress-indicator {
  display: flex; 
  justify-content: space-between;
  margin-bottom: 30px;
  gap: 10px; 
}

.progress-step {
  flex-grow: 1; 
  height: 5px;
  background-color: #e0e0e0; 
  border-radius: 0px;
  transition: background-color 0.4s ease;
}

.progress-step.active {
  background-color: #BACF5E; 
}

.step-content {
  display: none;
  padding: 10px 20px 20px 20px;
}

.step-content.active {
  display: block;
}

.wizard-controls {
  display: flex;
  justify-content: flex-end;
  gap: 5px;
  margin-top: 20px;
  padding: 0 20px;
}

.btn-wizard {
  padding: 10px 20px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-weight: bold;
  background-color: #BACF5E; 
  color: #ffffff;
}

#btn-anterior {
  background-color: transparent;
  border: 2px solid #BACF5E;
  color: #BACF5E;
}

.wizard-controls .button-brokware:disabled {
  background-color: #cccccc !important;
  border-color: #cccccc !important;
  cursor: not-allowed;
}

.bg-white {
  background-color: fff;
}

/* --- Estilos de la Pantalla Final --- */
.final-screen-container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 80vh; /* Para centrar verticalmente en la vista */
  background-color: #f4f6f8;
}

.success-box {
  padding: 40px;
  text-align: center;
}

/* --- Icono de Checkmark (SVG) --- */
.success-icon-container {
  margin-bottom: 20px;
}

.success-check {
  width: 80px;
  height: 80px;
  display: block;
  margin: 0 auto;
}
.success-check circle {
  stroke-width: 4;
  stroke: #28a745; /* Verde Bootstrap/Éxito */
  fill: none;
  transition: stroke-dasharray 0.5s ease 0.1s;
}
.success-check path {
  stroke-width: 4;
  stroke: #ffffff;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: stroke-dasharray 0.3s ease 0.4s;
  /* Animación inicial (se manejará con JS para simplificar) */
}

/* --- Textos --- */
.title-success {
  color: #28a745;
  font-size: 28px;
  margin-bottom: 5px;
}
.subtitle-success {
  color: #6c757d;
  font-size: 16px;
  margin-bottom: 30px;
}

/* --- Número de Póliza --- */
.policy-label {
  color: #343a40;
  font-weight: 500;
  margin-bottom: 8px;
}
.policy-number-display {
  display: inline-block;
  font-size: 32px;
  font-weight: 700;
  color: #BACF5E; 
  background-color: #f1f5e2;
  padding: 10px 20px;
  border-radius: 8px;
  margin-bottom: 30px;
}

#downloadSection {
  margin-top: 30px;
  border-top: 1px solid #e9ecef;
  padding-top: 20px;
}
.download-progress-bar {
  width: 100%;
  height: 10px;
  background-color: #e9ecef;
  border-radius: 5px;
  overflow: hidden;
  margin-top: 10px;
}
.progress-fill {
  height: 100%;
  width: 0%;
  background-color: #BACF5E;
  transition: width 0.3s ease;
}
.download-message {
  margin-top: 10px;
  font-weight: 600;
}
.download-status-label {
  color: #6c757d;
  font-size: 14px;
}

.status-error {
  color: #dc3545; /* Rojo */
}
.error-border {
  border: 2px solid #dc3545;
}

.br-4{
  border-radius: 4px !important;
}

.logo-final-circle {
  width: 90px; 
  height: 90px;
  border-radius: 50%; 
  overflow: hidden; 
  background-size: cover; 
  background-repeat: no-repeat;
  background-position: center; 
  margin: 0 auto 20px auto;
}

#Cotizador {
  padding: 20px;
}

