.no-wrap {white-space: nowrap;}

.hidden {display:none;}
.warn_message {display:none; color:#ff0000;background:#fff;padding:5px;margin:5px;border:1px dotted #ff5d5d;}
.warn_message_show {display:block; color:#ff0000;}

.word_break {word-break: break-all;word-wrap: break-word;}
#message_from_bottom {color:#fff;}
.msg_hidden {color:#fff;visibility:hidden;position:absolute;top:-2000px;}

.inline{display:inline;}
.doted{border-bottom: 1px dotted #1ab1e8;border-top: 1px dotted #1ab1e8;border-right: 1px dotted #1ab1e8;border-left: 1px dotted #1ab1e8;}
.btn_hover{vertical-align:middle;display:inline;cursor:hand;cursor:pointer;}
.vmid, .vmid_fl{vertical-align:middle;display:inline;}
.vmid_fl{float:left;}

.vtop{vertical-align:top;display:inline;}

.cusor_hand{cursor:hand;cursor:pointer;}

.ha_center{text-align:center;}
.ha_left{text-align:left;}
.ha_right{text-align:right;}
.va_bottom{vertical-align:bottom;}
.va_middle{vertical-align:middle;}
.va_top{vertical-align:top;}

.rounded_corners {
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
border-radius: 10px; /* future proofing */
-khtml-border-radius: 10px; /* for old Konqueror browsers */
}

div.success_message, div.order_sample {background-color:#d8eee9; display:inline-block; padding:10px; border: 5px #53f34b dotted;}
span.availability_starts {font-size:110%; color:#ffcc99;}

.product_booking_extras, .product_booking_extras_b {
    padding:5px;
    margin:5px;
}
.product_booking_extras_b {
    background:#f5e4b4;
}

.breadcrumbs,
.breadcrumbs > a,
.breadcrumbs > div, 
.breadcrumbs > ul, 
.breadcrumbs > li, 
.breadcrumbs > h1, 
.breadcrumbs > h2, 
.breadcrumbs > h3 {
    background:#f051cb !important;
    padding-top: 25px !important;
    margin-bottom: 0px !important;
    color:#f4fc00e4 !important;
}

.page-header,
.page-header > a, 
.page-header > ul, 
.page-header > li, 
.page-header > h1, 
.page-header > h2, 
.page-header > h3 {
    margin: 0px !important;
    padding:0px !important;
    color:#f4fc00e4 !important;
}

.breadcrumb, 
.breadcrumb > li, 
.breadcrumb > li > a {
    color:#f4fc00e4 !important;
}
.breadcrumb > li::before {
    color:#ffffff !important;
}


.insurance-cards {
    max-width: 600px;
    margin: 40px auto; /* espaço seguro */
}

.section-title {
    font-weight: 700;
    margin: 0 0 25px 0;  /* garante espaço abaixo do título */
    padding: 20px;   /* evita sobreposição */
    text-align: center;
}

.insurance-card {
    cursor: pointer;
    padding: 0;
    margin-bottom: 20px;  /* distância entre os cards */
    display: block;
    position: relative;
}

.insurance-card input[type="radio"] {
    display: none;
}

/* corpo do card */
.insurance-card .card-body {
    background: #f8eac2;
    border-radius: 16px;
    padding: 22px 24px;
    border: 2px solid transparent;
    transition: all 0.25s ease;
}

/* título dentro do card */
.insurance-card .title {
    margin: 0;
    font-weight: 700;
    font-size: 20px;
    color: #c62828;
}

.insurance-card .price {
    font-size: 18px;
    margin-top: 6px;
    color: #222;
}

/* quando selecionado */
.insurance-card input[type="radio"]:checked + .card-body {
    border-color: #fe9c1d;
    background: #fffdf2;
    box-shadow: 0 0 10px rgba(0,0,0,0.12);
}

.insurance-card .card-body.selected {
    border-color: #fe9c1d;
    background: #fffdf2;
    box-shadow: 0 0 10px rgba(0,0,0,0.12);
}


.insurance-card {
    cursor: pointer;
    padding: 0;
    margin-bottom: 20px;
    display: block;
}

.insurance-card input[type="radio"] {
    display: none;
}

.insurance-card .title {
    margin: 0;
    font-weight: 700;
    font-size: 20px;
    color: #c62828;
}

.insurance-card .price {
    font-size: 18px;
    margin-top: 6px;
}


.cdw-header {
    margin-bottom: 2.5rem;  /* espaço entre texto e cards */
}

.cdw-warning {
    max-width: 720px;       /* deixa o texto mais estreito e elegante */
    margin: 0 auto;         /* centraliza o bloco */
    color: #555;
    line-height: 1.7;
    text-align: left;       /* título central, texto alinhado à esquerda */
}

.insurance-wrapper, .options-wrapper {
    background: #72befb;
    border-radius: 16px;
    padding: 32px 28px;
    max-width: 820px;
    margin: 0 auto;
    margin-bottom: 35px;
}

.insurance-header {
    margin-bottom: 32px;
    text-align: center;
}

.insurance-header .section-title {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 30px;
}

.cdw-warning {
    max-width: 680px;
    margin: 0 auto;
    color: #444;
    line-height: 1.7;
    text-align: left;
}

.insurance-cards .insurance-card {
    margin-top: 25px;
    margin-bottom: 16px;
}

.options-wrapper {
    background: #72befb;
}


/* CHECKBOX & RADIO */
input[type="checkbox"],
input[type="radio"] {
    transform: scale(1.5);
    cursor: pointer;
    margin-right: 8px;
}

/* SELECT FIELD */
select {
    font-size: 18px;
    padding: 12px 16px;
    border-radius: 8px;
}

/* OPTIONS */
select option {
    font-size: 18px;
    padding: 10px;
}

.card-agreement {
    color: #ffffff;
    background: #be3438;

    border-radius: 16px;
    padding: 22px 24px;
    border: 2px solid transparent;
    transition: all 0.25s ease;
}

.card-agreement a {
    color: #ffffff;
}
.card-agreement a:hover {
    color: #e9ff27;
}

.notices-header {
    margin-bottom: 32px;
    text-align: center;
}

.notices-header .section-title {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 30px;
}

.insurance-description, .notices-description {
    color: #000000;
    background: #c2eaf5;
    text-align:center;

    border-radius: 16px;
    padding: 22px 24px;
    border: 2px solid transparent;
    transition: all 0.25s ease;
}

/* Container geral da sessão */
.booking-section {
    padding: 20px 0;
}

/* Títulos */
.section-title {
    background: #6db7ff; /* mesmo azul do restante */
    color: #000;
    padding: 12px 15px;
    border-radius: 14px;
    margin-bottom: 20px;
    font-size: 20px;
    font-weight: 700;
}

/* Cartões de formulário */
.form-card {
    background: #ffffff;
    padding: 20px;
    border-radius: 14px;
    margin-bottom: 25px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}

/* Labels */
.form-card label {
    font-weight: 600;
    display: block;
    margin-bottom: 6px;
    margin-top: 12px;
}

/* Inputs */
.form-card input {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid #d8d8d8;
    border-radius: 10px;
    font-size: 16px;
    margin-bottom: 4px;
    outline: none;
}

.form-card input:focus {
    border-color: #7db8ff;
    box-shadow: 0 0 4px rgba(0, 131, 255, 0.4);
}

/* Margem extra */
.mt-4 {
    margin-top: 30px;
}

/* Ícones para inputs com data/hora (opcional) */
.date-input {
    background-image: url('data:image/svg+xml;utf8,<svg ...>');
}

.time-input {
    background-image: url('data:image/svg+xml;utf8,<svg ...>');
}


.car-big-card {
    align:center;
}.checkbox {
  padding-left: 20px;
}
.checkbox label {
  display: inline-block;
  vertical-align: middle;
  position: relative;
  padding-left: 5px;
}
.checkbox label::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 17px;
  height: 17px;
  left: 0;
  margin-left: -20px;
  border: 1px solid #cccccc;
  border-radius: 3px;
  background-color: #fff;
  -webkit-transition: border 0.15s ease-in-out, color 0.15s ease-in-out;
  -o-transition: border 0.15s ease-in-out, color 0.15s ease-in-out;
  transition: border 0.15s ease-in-out, color 0.15s ease-in-out;
}
.checkbox label::after {
  display: inline-block;
  position: absolute;
  width: 16px;
  height: 16px;
  left: 0;
  top: 0;
  margin-left: -20px;
  padding-left: 3px;
  padding-top: 1px;
  font-size: 11px;
  color: #555555;
}
.checkbox input[type="checkbox"] {
  opacity: 0;
  z-index: 1;
}
.checkbox input[type="checkbox"]:focus + label::before {
  outline: thin dotted;
  outline: 5px auto -webkit-focus-ring-color;
  outline-offset: -2px;
}
.checkbox input[type="checkbox"]:checked + label::after {
  font-family: 'FontAwesome';
  content: "\f00c";
}
.checkbox input[type="checkbox"]:disabled + label {
  opacity: 0.65;
}
.checkbox input[type="checkbox"]:disabled + label::before {
  background-color: #eeeeee;
  cursor: not-allowed;
}
.checkbox.checkbox-circle label::before {
  border-radius: 50%;
}
.checkbox.checkbox-inline {
  margin-top: 0;
}
.checkbox-primary input[type="checkbox"]:checked + label::before {
  background-color: #337ab7;
  border-color: #337ab7;
}
.checkbox-primary input[type="checkbox"]:checked + label::after {
  color: #fff;
}
.checkbox-danger input[type="checkbox"]:checked + label::before {
  background-color: #d9534f;
  border-color: #d9534f;
}
.checkbox-danger input[type="checkbox"]:checked + label::after {
  color: #fff;
}
.checkbox-info input[type="checkbox"]:checked + label::before {
  background-color: #5bc0de;
  border-color: #5bc0de;
}
.checkbox-info input[type="checkbox"]:checked + label::after {
  color: #fff;
}
.checkbox-warning input[type="checkbox"]:checked + label::before {
  background-color: #f0ad4e;
  border-color: #f0ad4e;
}
.checkbox-warning input[type="checkbox"]:checked + label::after {
  color: #fff;
}
.checkbox-success input[type="checkbox"]:checked + label::before {
  background-color: #5cb85c;
  border-color: #5cb85c;
}
.checkbox-success input[type="checkbox"]:checked + label::after {
  color: #fff;
}
.radio {
  padding-left: 20px;
}
.radio label {
  display: inline-block;
  vertical-align: middle;
  position: relative;
  padding-left: 5px;
}
.radio label::before {
  content: "";
  display: inline-block;
  position: absolute;
  width: 17px;
  height: 17px;
  left: 0;
  margin-left: -20px;
  border: 1px solid #cccccc;
  border-radius: 50%;
  background-color: #fff;
  -webkit-transition: border 0.15s ease-in-out;
  -o-transition: border 0.15s ease-in-out;
  transition: border 0.15s ease-in-out;
}
.radio label::after {
  display: inline-block;
  position: absolute;
  content: " ";
  width: 11px;
  height: 11px;
  left: 3px;
  top: 3px;
  margin-left: -20px;
  border-radius: 50%;
  background-color: #555555;
  -webkit-transform: scale(0, 0);
  -ms-transform: scale(0, 0);
  -o-transform: scale(0, 0);
  transform: scale(0, 0);
  -webkit-transition: -webkit-transform 0.1s cubic-bezier(0.8, -0.33, 0.2, 1.33);
  -moz-transition: -moz-transform 0.1s cubic-bezier(0.8, -0.33, 0.2, 1.33);
  -o-transition: -o-transform 0.1s cubic-bezier(0.8, -0.33, 0.2, 1.33);
  transition: transform 0.1s cubic-bezier(0.8, -0.33, 0.2, 1.33);
}
.radio input[type="radio"] {
  opacity: 0;
  z-index: 1;
}
.radio input[type="radio"]:focus + label::before {
  outline: thin dotted;
  outline: 5px auto -webkit-focus-ring-color;
  outline-offset: -2px;
}
.radio input[type="radio"]:checked + label::after {
  -webkit-transform: scale(1, 1);
  -ms-transform: scale(1, 1);
  -o-transform: scale(1, 1);
  transform: scale(1, 1);
}
.radio input[type="radio"]:disabled + label {
  opacity: 0.65;
}
.radio input[type="radio"]:disabled + label::before {
  cursor: not-allowed;
}
.radio.radio-inline {
  margin-top: 0;
}
.radio-primary input[type="radio"] + label::after {
  background-color: #337ab7;
}
.radio-primary input[type="radio"]:checked + label::before {
  border-color: #337ab7;
}
.radio-primary input[type="radio"]:checked + label::after {
  background-color: #337ab7;
}
.radio-danger input[type="radio"] + label::after {
  background-color: #d9534f;
}
.radio-danger input[type="radio"]:checked + label::before {
  border-color: #d9534f;
}
.radio-danger input[type="radio"]:checked + label::after {
  background-color: #d9534f;
}
.radio-info input[type="radio"] + label::after {
  background-color: #5bc0de;
}
.radio-info input[type="radio"]:checked + label::before {
  border-color: #5bc0de;
}
.radio-info input[type="radio"]:checked + label::after {
  background-color: #5bc0de;
}
.radio-warning input[type="radio"] + label::after {
  background-color: #f0ad4e;
}
.radio-warning input[type="radio"]:checked + label::before {
  border-color: #f0ad4e;
}
.radio-warning input[type="radio"]:checked + label::after {
  background-color: #f0ad4e;
}
.radio-success input[type="radio"] + label::after {
  background-color: #5cb85c;
}
.radio-success input[type="radio"]:checked + label::before {
  border-color: #5cb85c;
}
.radio-success input[type="radio"]:checked + label::after {
  background-color: #5cb85c;
}
input[type="checkbox"].styled:checked + label:after {
  font-family: 'FontAwesome';
  content: "\f00c";
}
input[type="checkbox"] .styled:checked + label::before {
  color: #fff;
}
input[type="checkbox"] .styled:checked + label::after {
  color: #fff;
}
