/* Contact page specific styles */
  /* img {
    max-width: 100%;
    display: block;
  } */
  
  /* Validation styles for Contact Form 7 */
  .wpcf7-not-valid-tip {
    position: absolute;
    bottom: -20px;
    left: 0;
    color: #ff1818;
    font-size: 14px;
    line-height: 1.4;
    display: none;
  }
  
  .wpcf7-form-control-wrap {
    position: relative;
    margin-bottom: 25px;
  }
  
  .wpcf7-response-output {
    padding: 12px 16px;
    margin: 16px 0;
    border-radius: 4px;
    font-weight: 500;
  }
  
  .wpcf7-form.invalid .wpcf7-response-output {
    background-color: #fdf2f2;
    border: 1px solid #e74c3c;
    color: #c0392b;
  }
  
  .location-info hr {
    height: 1px;
    border: 0;
    background: var(--global--color-light-blue);
    margin: 24px 0;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0;
  }
  .divider {
    height: 1px;
    border: 0;
    background: var(--global--color-light-blue);
    margin: 0 0;
  }
  .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
  }
  
  /* Layout */
  .container-contact {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0px 0px 0px 0px;
  }
  
  .block-contact .title {
    margin: 0 0 30px;
    text-transform: capitalize;
  }
  .location {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    margin-bottom: 100px;
  }


  /* .location-media {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;
    overflow: hidden;
  }
  .location-media img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  } */

  .location-media {
    position: relative;
  }
  .location-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .pill {
    position: absolute;
    right: -1px;
    bottom: -1px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--global--color-light-grey-bg);
    padding: 20px 24px;
    text-decoration: none;
    color: var(--global--color-cristal-blue);
  }
  .pill-form {
    position: absolute;
    right: 0px;
    bottom: 0px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--global--color-light-grey-bg);
    padding: 20px 24px;
    text-decoration: none;
    color: var(--global--color-cristal-blue);
  }
  
  .pill-dot {
    width: 21px;
    height: 21px;
    display: inline-block;
    vertical-align: top;
    border: 1px solid var(--global--color-drank-grey);
    border-radius: 100%;
    position: relative;
  }
  
  .pill-dot:before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    transform: scale(0.263);
    background-color: var(--global--color-drank-grey);
    border-radius: 100%;
    animation-duration: 0.8s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-out;
    will-change: transform;
  }
  
  .pill:hover .pill-dot:before {
    animation-name: rippleWith;
  }
  .pill-form:hover .pill-dot::before {
    animation-name: rippleWith;
  }
  
  .pill-dot:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    border-radius: 100%;
    opacity: 0;
    transform: scale(0.6);
    animation-duration: 0.8s;
    animation-delay: 0.4s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-out;
    will-change: transform, opacity;
    border: 4px solid var(--global--color-drank-grey);
  }
  
  .pill:hover .pill-dot:after {
    animation-name: ripple;
  }
  .pill-form:hover .pill-dot:after {
    animation-name: ripple;
  }
  
  .pill-dot-blue {
    width: 33px;
    height: 21px;
    display: inline-block;
    vertical-align: top;
    border: 1px solid var(--global--color-cristal-blue);
    border-radius: 100%;
    position: relative;
  }
  
  .pill-dot-blue:before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    transform: scale(0.263);
    background-color: var(--global--color-cristal-blue);
    border-radius: 100%;
    animation-duration: 0.8s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-out;
    will-change: transform;
  }
  
  .link-btn:hover .pill-dot-blue:before {
    animation-name: rippleWith;
  }
  
  .pill-dot-blue:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    transform: translate3d(-50%, -50%, 0);
    border: 3px solid var(--global--color-cristal-blue);
    border-radius: 100%;
    opacity: 0;
    animation-duration: 0.8s;
    animation-delay: 0.4s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-out;
    will-change: transform, opacity;
  }
  
  .link-btn:hover .pill-dot-blue:after {
    animation-name: ripple;
  }
  
  .location-info {
    display: flex;
    flex-direction: column;
    gap: 40px;
    position: relative;
    padding-bottom: 24px;
  }
  .info-title {
    font-size: var(--heading--font-size-h3);
    line-height: var(--heading--line-height-h3);
    font-weight: var(--heading--font-weight-page-title);
    margin: 0 0 12px;
  }
  .info-block p {
    margin: 0;
    font-size: var(--global--font-size-base);
    line-height: 21px;
    font-weight: 300;
  }

  .info-block a{
    margin: 0;
    font-size: var(--global--font-size-base);
    line-height: 21px;
    font-weight: 300;
    color: var(--global--font-primary);
  }
  
  /* 2 cols */
  .two-col {
    display: flex;
    gap: 60px;
    align-items: start;
  }
  .col {
    flex: 1;
    min-width: 0;
  }
  
  /* Form */
  .form {
    display: flex;
    flex-direction: column;
    gap: 30px;
    margin-top: 68px;
    max-width: 665px;
  }
  .row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .form .field,
  .form .row .field {
    display: flex;
    gap: 10px;
    border-bottom: 1px solid var(--global--color-light-blue);
    padding-bottom: 10px;
    margin: 0 0 25px 0;
  }

  .form .row .field .phone-number{
    margin-left: 0px !important;
  }

  .field > span {
    font-size: var(--heading--font-size-h6);
    line-height: var(--heading--line-height-h6);
    font-weight: 400;
    margin: 3px 0 0 0;
    white-space: nowrap;
    flex-shrink: 0;
  }
  .req {
    color: #ff1818;
    margin-left: 2px;
  }
  .field input,
  .field textarea {
    border: 0;
    outline: 0;
    background: transparent;
    padding: 0 0;
    color: var(--global--color-black);
    font-size: var(--heading--font-size-h6);
  }
  .inline {
    display: flex;
    align-items: center;
    gap: 12px;
  }
  .inline .divider {
    display: inline-block;
    width: 1px;
    height: 14px;
    background: var(--global--color-light-blue);
    margin: 0 4px;
  }
  /* Vertical separator after flag-container */
  .phone-position::before{
    content: "";
    display: inline-block;
    width: 1px;
    height: 14px;
    background: #C8D6D9;
    margin: 0 16px 0 0px;
  }
  
  .phone-position{
    display: inline-flex;
    align-items: center;
    margin-top: 0px !important;
  }
  .chev {
    margin-left: 2px;
  }
  .form-footer {
    display: flex;
    justify-content: space-between;
  }
  .check {
    display: flex;
    align-items: center;
    gap: 20px;
  }
  .check .box {
    width: 20px;
    height: 20px;
    border: 1px solid var(--global--color-light-blue);
    display: inline-block;
  }
  .check .box-accept {
    font-family: var(--global--font-primary);
    font-weight: var(--heading--font-weight-page-title);
    font-size: var(--heading--font-size-h6);
    line-height: var(--heading--line-height-h6);
    letter-spacing: var(--global--letter-spacing);
  }
  .link-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: transparent;
    border: 0;
    color: var(--global--color-cristal-blue);
    font-size: var(--global--font-size-base);
    cursor: pointer;
    margin-bottom: 10px;
  }
  
  .wpcf7-form-control-wrap {
    display: contents; /* bỏ span bọc */
    position: static;
  }
  .input-field,
  .wpcf7-form-control {
    border: 0;
    outline: 0;
    background: transparent;
    padding: 8px 0;
    color: var(--global--color-black);
    font-size: var(--global--font-size-base);
    width: 100%;
  }
  .wpcf7 form input[type="submit"] {
    padding: 0px !important;
    color: var(--global--color-cristal-blue) !important;
    border: none !important;
    font-family: var(--global--font-primary);
    font-weight: var(--heading--font-weight-page-title);
    font-size: var(--global--font-size-base);
    line-height: 21px;
    letter-spacing: var(--global--letter-spacing);
  }
  .wpcf7-spinner {
    display: none !important;
  }
  .wpcf7-response-output{
    margin: 2em 0.5em 1em;
    padding: 0.2em 1em;
  }

  /* Hide response output in init state */
  .wpcf7 form.init .wpcf7-response-output,
  .wpcf7 form.resetting .wpcf7-response-output,
  .wpcf7 form.submitting .wpcf7-response-output {
    display: none;
  }

  /* Success message - Green */
  .wpcf7 form.sent .wpcf7-response-output {
    display: block;
    border-color: #46b450 !important;
    background-color: #f0f8f0;
    color: #2d5a2d;
  }

  /* Error messages - Yellow */
  .wpcf7 form.invalid .wpcf7-response-output,
  .wpcf7 form.unaccepted .wpcf7-response-output {
    display: block;
    border-color: #ffb900 !important;
    background-color: #fffbf0;
    color: #8b6914;
  }

  /* Failed messages - Red */
  .wpcf7 form.failed .wpcf7-response-output,
  .wpcf7 form.aborted .wpcf7-response-output {
    display: block;
    border-color: #dc3232 !important;
    background-color: #fff5f5;
    color: #8b1515;
  }

  /* Spam messages - Orange */
  .wpcf7 form.spam .wpcf7-response-output {
    display: block;
    border-color: #f56e28 !important;
    background-color: #fff8f0;
    color: #8b4513;
  }
  
  /* Validation messages using pseudo-elements */
  .wpcf7-not-valid-tip {
    position: absolute;
    bottom: -20px;
    left: 0;
    color: #ff1818;
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
    margin: 0;
    padding: 0;
    display: block;
    white-space: nowrap;
    z-index: 1;
  }
  
  .field {
    position: relative;
    margin-bottom: 20px;
  }
  
  /* .wpcf7-not-valid {
    border-bottom-color: #ff1818 !important;
  } */
  
  .wpcf7-validation-errors {
    border: 1px solid #ff1818;
    background-color: #fff5f5;
    color: #ff1818;
    padding: 10px;
    margin-top: 15px;
    border-radius: 4px;
  }
  
  /* FAQ */
  .faq {
    display: flex;
    flex-direction: column;
    gap: 0;
    flex: 1;
    width: 100%;
    max-width: 550px;
  }
  .faq-media {
    background: url("../images/faq-back.png")
      center/cover no-repeat;
    height: 302px;
    width: 100%;
  }
  .faq-card {
    background: var(--global--color-cristal-blue);
    color: var(--global--color-white);
    padding: 30px;
    display: flex;
    flex-direction: column;
    gap: 40px;
    min-height: 260px;
    width: 100%;
    position: relative;
  }
  .faq-card h3 {
    margin: 0;
    font-size: var(--heading--font-size-h2);
    line-height: var(--heading--line-height-h2);
    font-weight: var(--heading--font-weight-page-title);
    text-transform: capitalize;
  }
  .text-view {
    font-family: var(--global--font-primary);
    font-weight: var(--heading--font-weight-page-title);
    font-size: var(--global--font-size-base);
    line-height: 21px;
    letter-spacing: var(--global--letter-spacing);
  }
  
  .intl-tel-input .selected-flag .iti-flag {display: none !important;}
  .intl-tel-input .country-list .flag-box{display: none !important;}
  .intl-tel-input .country-list .country-name{display: none !important;}
  .tel-input.separate-dial-code .selected-dial-code{font-family: Inter !important;
    font-weight: 400 !important;
    font-size: 14px !important;
    line-height: 19px !important;
    letter-spacing: 0 !important;
    }
  .selected-flag{background-color: transparent !important;}
  .selected-dial-code{padding: 0 !important; padding-top: 7px !important}
  /* Override arrow icon of intl-tel-input */
  .row .wpcf7-form-control-wrap,
  .intl-tel-input .iti-arrow{
    border: none !important;
    width: 12px !important;
    height: 8px !important;
    right: 26px !important;
    background: url(../images/phone-drop-down.svg) center/contain no-repeat !important;
    /* margin-top: -8px !important; */
  }
  .intl-tel-input .country-list .divider{
    display: none;
  }

  .intl-tel-input .selected-flag{
    padding: 0;
  }

  .intl-tel-input .phone-number { 
    padding-left: 0 !important;
  }

  .flag-container{
    margin-top: -16px;
    position: absolute;
    left: 0;
  }

  .phone{
    padding-left: 75px;
    position: relative;
  }

  .intl-tel-input {
    position: static;
  }

  /* Responsive */
  @media (max-width: 767.98px) {
    .container-contact {
      padding: 0px 20px 0px 20px;
    }
    .info-title{
      font-size: var(--heading--font-size-h4);
      line-height: var(--heading--line-height-h4);
    }
    .location-info{
      gap: 20px;
    }
    .pill{
      padding: 10px 17px;
    }
    .divider{
      margin: 10px 0;
    }
    .location{
      margin-bottom: 45px;
      gap: 30px;
    }
    .two-col{
      padding: 20px 0 0 0;
      display: flex;
      flex-direction: column;
      gap: 40px;
    }
    .form-footer{
      display: block;
    }
    .check{
      gap: 25px;
      margin-top: -10px;;
    }
    .form{
      margin-top: 37px;
    }
    .two-col .col .h2{
      margin-bottom: 20px;
    }
    .row{
      gap: 0;
    }
    .link-btn{
      margin: 16px 0;
      gap: 5px;
    }
    .pill-form{
      padding: 10px 16px;
    }
    .faq-card{
      padding: 40px;
    }
    .faq-card h3 {
      font-size: 25px;
      line-height: 32px;
      letter-spacing: 0;
      font-weight: 400;
    }
    .wpcf7-response-output{
      margin: 1em 0 10px 0 !important;
      padding: 0.5em 1em;
      font-size: 14px;
    }
    .two-col{
      gap: 45px;
    }
    .check .box{  
      width: 22.89px;
    }
  }

  @media(min-width: 768px) {
    .container-contact {
      padding: 0px 40px 0px 40px;
    }
    .location {
      grid-template-columns: 1fr 1fr;
      gap: 60px;
    }
    .two-col {
      gap: 35px;
    }
    .row {
      grid-template-columns: repeat(2, 1fr);
    }
    .faq-media {
      height: 302px;
    }
    .faq-card {
      padding: 35px;
      gap: 60px;
      min-height: 260px;
    }
  }

  @media(min-width: 992px) {
    .two-col {
      gap: 100px;
    }
    .faq-media {
      height: 302px;
    }
    .faq-card {
      padding: 40px;
      gap: 70px;
      min-height: 260px;
    }
  }

  @media(min-width: 1200px) {
    .two-col {
      gap: 120px;
    }
    .faq-media {
      height: 302px;
    }
    .faq-card {
      padding: 40px;
      gap: 80px;
      min-height: 260px;
    }
  }

  @media(min-width: 1440px) {
    .two-col {
      gap: 140px;
    }
  }