@font-face {
    font-display: optional;
    font-family: Centra No2;
    font-style: normal;
    font-weight: 300;
    src: url(https://a.travel-assets.com/egds/fonts/CentraNo2/CentraNo2-Light.woff2) format("woff2"), url(https://a.travel-assets.com/uds/fonts/centrano2/centrano2-light-webfont.woff) format("woff");
    unicode-range: U+0??
}

@font-face {
    font-display: optional;
    font-family: Centra No2;
    font-style: normal;
    font-weight: 400;
    src: url(https://a.travel-assets.com/egds/fonts/CentraNo2/CentraNo2-Book.woff2) format("woff2"), url(https://a.travel-assets.com/egds/fonts/CentraNo2/CentraNo2-Book.woff) format("woff");
    unicode-range: U+0??
}

@font-face {
    font-display: optional;
    font-family: Centra No2;
    font-style: normal;
    font-weight: 500;
    src: url(https://a.travel-assets.com/egds/fonts/CentraNo2/CentraNo2-Medium.woff2) format("woff2"), url(https://a.travel-assets.com/egds/fonts/CentraNo2/CentraNo2-Medium.woff) format("woff");
    unicode-range: U+0??
}

@font-face {
    font-display: optional;
    font-family: Centra No2;
    font-style: normal;
    font-weight: 700;
    src: url(https://a.travel-assets.com/egds/fonts/CentraNo2/CentraNo2-Bold.woff2) format("woff2"), url(https://a.travel-assets.com/egds/fonts/CentraNo2/CentraNo2-Bold.woff) format("woff");
    unicode-range: U+0??
}

/* Base style */
* {
    box-sizing: border-box;
}

html {
    color: #191E3B;
    font-family: Centra No2, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    font-synthesis: none;
    line-height: 20px;
    font-size: 16px;
    font-weight: 400;
}

input:focus-visible, textarea:focus-visible, button:focus-visible, select:focus-visible, .radio-group:focus-visible, .radio-group[data-is-click="False"]:focus-within, .checkbox-group[data-is-click="False"]:focus-within, .radio-button:focus-visible {
    outline: .125rem solid #1668e3;
}

input {
    margin-top: .75rem;
}

input, select, textarea, label {
    font-size: 0.8125rem; /* 13px */
    color: #191E3B; /* @colorSlateDark */
}

textarea {
    font-size: .875rem;
    color: #191E3B;
    padding: .75rem;
    resize: none;
}

textarea, input.email, input.itinerary_number {
    border: .0625rem solid #818494;
    border-radius: .5rem;
    width: 100%;
    padding: .8125rem .6875rem;
}

textarea::placeholder, input.email::placeholder, input.itinerary_number::placeholder {
    color: #676A7D;
}

::placeholder {
    color: #676A7D;
    font-family: Centra No2, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
}

h5.sub-header {
    font-size: 0.6875rem;
    letter-spacing: 0.04375rem;
}

h2, h5, h6, .question-header {
    font-weight: 600;
}

h6, .question-header {
    font-size: 0.8125rem;
}

#thank-you {
    display: none;
}

#thank-you img {
    margin-top: -.5rem;
    height: 1.75rem;
}

p[data-localization="thank-you-heading"] {
    margin-top: 1rem;
}

p {
    font-size: 0.875rem;
    padding-top: .75rem;
    padding-bottom: .75rem;
    margin: 0;
}

p.subheading {
    margin: 0;
    padding-top: 0;
}

#topic, #verbatim, #visit-reason, #visit-reason-other {
    display: block;
    width: 100%;
}

#email_address {
    padding-left: .5rem;
    margin-top: -0.50rem;
}

.question-group {
    border: none;
    margin: 0;
    padding: 0;
}

.verbatim {
    height: 10rem;
    background: #FFFFFF;
    border: .0625rem solid #818494;
    border-radius: .5rem;
}

#email_address, #itinerary_number {
    padding-left: .5rem;
}

.email, .itinerary_number {
    background: #FFFFFF;
    height: 2.875rem;
}

a {
    color: #1668e3;
    text-decoration: none;
}

a:hover {
    color: #1668e3;
    text-decoration: underline;
}

.submit {
    border: none;
    border-radius: 2rem;
    background: #1668e3;
    margin: auto;
    margin-top: 1.50rem;
    padding: .875rem 1rem;
    cursor: pointer;
    font-size: 1rem;
    line-height: 1.25rem;
    color: #FFFFFF;
}

.submit:hover {
    background: #0D4EAF;
    color: #FFFFFF;
}

.submit:active {
    background: #0e3672;
    color: #FFFFFF;
}

.center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.radio-button{
    background-color: #FFFFFF;
}

.radio-label:hover {
    background-color: #ecf4fd;
    color: #1668e3;
    border-radius: .5rem;
}

.radio-label:active {
    background-color: #c8dff9;
}

.radio-legend {
    display: flex;
    justify-content: space-between;
}

.radio-legend h5 {
    font-weight: 400;
    margin-bottom: 0;
}

.radio-group {
    display: flex;
    justify-content: flex-start;
    margin: 0;
    flex-wrap: wrap;
    padding-bottom: .75rem;
}

.item-hidden {
  min-width: 9rem;
  flex-grow: 1;
  flex-shrink: 1;
  border: 1px solid transparent;
}

.radio-button.nps {
    max-width: 5rem;
    margin-top: 1rem;
    margin-right: 0.25rem;
    margin-bottom: 0;
    margin-left: 0;
    border: .0625rem solid #CACCD2;
    border-radius: .5rem;
    flex-shrink: 1;
    flex-grow: 1;
}

.label {
    margin-top: 0.25rem; /* Space between the radio button and the label */
    display: block; /* Makes the label start on a new line */
}

.label-group {
    display: flex; /* Align labels horizontally */
    justify-content: space-between; /* Space them out */
    /*gap: 200px;*/
    width: 100%; /* Take full width for proper alignment */
    margin-top: -1rem; /* Use negative margin to move it up */
    color: #A9A9A9; /* Greyed out text color */
    font-size: 0.875rem; /* Optional: Adjust font size for subtlety */
}

.star-label-group {
    display: flex;
    gap: 190px;
    width: 100%;
    margin-top: -0.5rem;
    color: #A9A9A9; /* Greyed out text color */
    font-size: 0.875rem; /* Optional: Adjust font size for subtlety */
}

/*.radio-button.nps {*/
/*    flex-grow: 0;*/
/*    width: 2.4rem;*/
/*    margin-bottom: .25rem;*/
/*}*/

.radio-group.stars {
    display: flex;
    gap: 30px
    /*justify-content: flex-start; !* Spread out stars evenly *!*/
}

.radio-label {
    width: 100%;
    height: 100%;
    cursor: pointer;
    margin: 0;
    padding: 0.625rem 1rem;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-basis: 25%;
    color: #191e3b;
}

.radio-labels {
    display: flex;
    flex-direction: column; /* Stack elements vertically */
    align-items: center;    /* Center them horizontally */
    text-align: center;
}

input[type=radio]:checked ~ .radio-label {
    box-shadow: inset 0 0 0 2px;
    background-color: #c8dff9;
    color: #191E3B;
    border-radius: .5rem;
    pointer-events: auto;
}

input[type=radio] {
    height: 0;
    width: 0;
    opacity: 0;
    position: absolute;
}

.radio_label input {
    font-size: 1rem;
}

#footer {
    border-top: .0625rem solid #818494;
    margin-bottom: .3125rem;
    margin-top: .3125rem;
    background-color: #fff;
}

body {
    background: #FFFFFF;
    margin: 0;
}

#header {
    box-shadow: 0 1px 0 0 rgba(12,14,28,.12);
}

#banner {
    background-color: #fff;
    width: 100%;
    height: 4rem;
    margin: auto;
    margin-bottom: -2.5rem;
    box-shadow: 0 2px .75rem rgba(12,14,28,.08)
}

.logo {
    margin: 0 auto;
    margin-bottom: 1rem;
    margin-top: -7rem;
    height: 1.75rem;
}

.description-box {
    border: 1px solid #d3d3d3; /* Border color */
    border-radius: 20px; /* Rounded corners */
    padding: 16px; /* Inner padding */
    background-color: #ffffff; /* Background color */
    display: flex; /* Use flexbox for alignment */
    align-items: center; /* Center items vertically */
    margin-top: 16px; /* Margin above the box */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); /* Optional shadow for depth */
}

/*#required {*/
/*    display: flex;*/
/*    align-items: center; !* Vertically centers the icon and text *!*/
/*}*/

.icon-heading-container {
    background-color: #A7183C;
    color: #FFFFFF;
    padding: 1rem;
    border-radius: 1.2rem;
    display: inline-flex;
    align-items: center;
    width: 100%;
    box-sizing: border-box;
}

.info-icon {
    background-color: #f0f0f0; /* Icon background color */
    color: #4b4b4b; /* Icon text color */
    border-radius: 50%; /* Round shape */
    width: 20px; /* Width of the icon */
    height: 20px; /* Height of the icon */
    display: flex; /* Flexbox for centering */
    justify-content: center; /* Center horizontally */
    align-items: center; /* Center vertically */
    margin-right: 10px; /* Space between icon and text */
    font-weight: bold; /* Bold icon */
    font-size: 12px; /* Icon font size */
}

.description-box {
    display: flex;
    align-items: center; /* Centers icon and text vertically */
}

.description-box .info-icon {
    background-color: #f0f0f0;
    color: #4b4b4b;
    border: 2px solid black; /* Black border */
    border-radius: 50%; /* Make it a circle */
    width: 40px; /* Equal width and height for a circle */
    height: 20px;
    display: flex; /* Inline-flex to prevent extra space issues */
    justify-content: center; /* Center horizontally */
    align-items: center; /* Center vertically */
    font-size: 16px; /* Adjust font size if needed */
    font-weight: bold;
    margin-right: 10px; /* Space between icon and text */
    box-sizing: border-box; /* Ensures border is within the set width/height */
}

.description-box p[data-localization="survey-description"] {
    margin: 0; /* Remove default margin */
    padding-left: 30px; /* Space between icon and text */
    font-size: 16px; /* Font size */
    color: #333333; /* Text color */
}

.radio-button {
    position: relative;
    margin-right: 10px; /* Spacing between stars */
    cursor: pointer; /* Show pointer on hover */
}

/* Hide the actual radio input */
.radio-button input[type="radio"] {
    display: none; /* Hide the radio buttons */
}

.comment-option {
    margin-bottom: 5px; /* Space between options */
}

input[type="radio"] {
    margin-right: 3px; /* Space between the radio button and label */
    opacity: 1;
    position: static;
    width: auto;
    height: auto;
}

.textarea_container input[type="radio"]:checked + label {
    background-color: #c8dff9;
    border-radius: .5rem;
    color: #191E3B;
}

label.question-header {
    font-size: 16px; /* Font size for labels */
    cursor: pointer; /* Change cursor to pointer on hover */
}

.stars {
      display: flex;
      flex-direction: row-reverse;
      justify-content: flex-end;
        margin-top: 20px;
    gap: 0.5rem;
}


.stars label {
  cursor: pointer;
  font-size: 2rem;
  color: transparent;
    -webkit-text-stroke: 1px black; /* Black outline for stars */
}

.stars input[type="radio"] {
    display: none; /* Hide radio buttons */
}


.stars label:hover,
.stars label:hover ~ label {
  color: #007BFF;
    -webkit-text-stroke: 0 transparent;
}

.star {
    color: transparent;
    -webkit-text-stroke: 3px black; /* Black outline for unselected stars */
}

.stars input[type="radio"]:checked ~ label {
    color: #007BFF; /* Fill stars when selected */
    -webkit-text-stroke: 0 transparent;
}

#required-page-rating, #email_prompt_text, #email_heading_text, #required-verbatim, #email-validation {
    display: none;
    margin: 0;
    padding: 0;
}

#validation-header {
    display: none;
    max-width: 600px;
    margin: 0 auto;
}

#email-validation {
    color: #A7183C;
}

p[data-localization="survey-heading"] {
    font-weight: bold;    /* Bold font */
    font-size: 1.5rem;    /* Adjust font size */
    text-align: left;     /* Keeps the text left-aligned */
    margin-top: 0.5rem;   /* Space between logo and heading */
    margin-left: 0;       /* Optional: ensures no unintended left margin */
}

p[data-localization="mandatory-notice"] {
    color: #A9A9A9;;
}

p[data-localization="validation-heading"] {
    color: #FFFFFF;
    font-weight: 900;
    margin: 0;
}

p[data-localization="email-subtext"] {
    color: gray;  /* Sets the text color to gray */
    opacity: 0.6; /* Makes the text slightly transparent */
    margin-top: -0.75rem;
}

#required {
    color: #FFFFFF;
    margin-left:auto;
    margin-right:auto;
    max-width: 35rem;
}

#required p, #required .question-header {
    color:#fff;
}

.question-header {
    font-size: 1rem;
    color: #191E3B;
    font-weight: 500;
    padding-top: .75rem;
}

.red {
    color: #A7183C;
}

.light-mode-warning-default {
    color: #A7183C;
}

.light-mode-warning-muted {
    color: #FED5D8;
}

.light-mode-positive-default {
    color: #227950;
}

.light-mode-positive-muted {
    color: #E6F7E9;
}

.no-display {
    border: 0;
    height: .0625rem;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: .0625rem
}

#container {
    box-sizing: border-box;
    margin-right: auto;
    margin-left: auto;
    padding-left: .5rem;
    padding-right: .5rem;
    max-width: 33rem;
    padding-bottom: .3125rem;
}

#survey, #submit-button, #notification-banner {
    display: none;
}

#survey-header {
    margin: 1.5rem 0 0 0;
}

.notification_banner {
    text-align: left;
    background-color: #A7183C;
    border: .0625rem solid #818494;
    border-radius: .3125rem;
    font-size:1rem;
    color: #FFF;
    padding: .3125rem;
    display: block;
}

.textarea_container, select {
    margin-top: .75rem;
    margin-bottom: .75rem;
}

#verbatim {
    padding-left: .5rem;
    padding-top: .5rem;
    margin-top: 0.75rem;
    margin-bottom: .75rem;
    display: inline-block;
    width: 100%;
}

#topic {
    padding: .5rem;
    width: 100%;
}

#visit_reason, #topic, #email_address {
    display: inline-block;
    width: 100%;
}

#itinerary_number_section {
    display: none;
    width: 100%;
}

@keyframes fade-in {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes color-change {
    from {
        color: #A7183C;
    }
    to {
        color: #818494;
    }
}

@keyframes red-flash {
    from {
        color: #F50843FF;
    }
    to {
        color: #A7183C;
    }
}

button:disabled, button[disabled], button:disabled:hover{
    border: 1px solid #999999;
    background-color: #cccccc;
    color: #666666;
}

/* IE11 SPECIFIC RULES*/
@media all and (-ms-high-contrast:none)
{
    /* #required-box */
    /* .radio-group */
    /* .radio-button */
    /* .radio-label */
    /* .radio-legend */
    .radio-button {
        width: 5rem;
    }

    /* .question-group */
    /* .question-header */
    .question-header {
        width:100%;
    }
}