.page-gift-banner-top {
  padding-top: 0;
  position: relative;
  overflow: hidden;
  margin-bottom: 0; }
  .page-gift-banner-top .slider-item {
    position: relative; }
    .page-gift-banner-top .slider-item a {
      transition: 0s; }
      .page-gift-banner-top .slider-item a img {
        width: 100% !important; }
    .page-gift-banner-top .slider-item .owl-lazy {
      transition: opacity 0.3s ease; }
  .page-gift-banner-top .owl-carousel:not(.owl-loaded) {
    display: flex;
    display: -ms-flex;
    display: -webkit-flex;
    overflow: hidden; }
  .page-gift-banner-top .owl-carousel:not(.owl-loaded) .slider-item {
    -webkit-flex: 0 0 100%;
    flex: 0 0 100%; }
  .page-gift-banner-top .owl-carousel .owl-nav button {
    position: absolute;
    top: calc(50% - 20px);
    padding: 0;
    opacity: 0;
    height: 40px;
    width: 40px;
    border-radius: 50%;
    text-align: center;
    display: inline-block;
    text-align: center;
    color: #444444;
    background-color: #fff;
    border: 1px solid #e1e1e1;
    outline: none;
    -webkit-transform: scale(0.5);
    -ms-transform: scale(0.5);
    transform: scale(0.5);
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
    -ms-transition: all 0.4s;
    transition: all 0.4s;
    display: flex;
    align-items: center;
    justify-content: center; }
    .page-gift-banner-top .owl-carousel .owl-nav button.owl-prev {
      left: 30px; }
    .page-gift-banner-top .owl-carousel .owl-nav button.owl-next {
      right: 30px; }
    .page-gift-banner-top .owl-carousel .owl-nav button svg {
      width: 20px;
      height: 20px; }
  .page-gift-banner-top .owl-carousel .owl-dots {
    position: absolute;
    left: 50%;
    bottom: 15px;
    text-align: center;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%); }
    .page-gift-banner-top .owl-carousel .owl-dots .owl-dot {
      margin: 0 3px;
      outline: 0; }
    .page-gift-banner-top .owl-carousel .owl-dots .owl-dot span {
      display: flex;
      display: -ms-flex;
      display: -webkit-flex;
      width: 7px;
      height: 7px;
      margin: 5px;
      border-radius: 50%;
      background: #928c8c; }
    .page-gift-banner-top .owl-carousel .owl-dots .owl-dot.active {
      border-radius: 50%;
      border: 2px solid #000000; }
    .page-gift-banner-top .owl-carousel .owl-dots .owl-dot.active span {
      background: #000000; }
  .page-gift-banner-top:hover .owl-nav button {
    opacity: 1;
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1); }
  @media (max-width: 767px) {
    .page-gift-banner-top .owl-carousel .owl-dots {
      bottom: 5px; }
    .page-gift-banner-top .owl-carousel .owl-dots .owl-dot {
      margin: 0 2px; }
    .page-gift-banner-top .owl-carousel .owl-dots .owl-dot span {
      width: 4px;
      height: 4px;
      margin: 4px; }
    .page-gift-banner-top .owl-carousel .owl-dots .owl-dot.active {
      border: 1px solid #000000; } }

.page-gift-services {
  background: rgba(162, 198, 210, 0.3);
  padding: 80px 0; }
  .page-gift-services .service-item {
    justify-content: center;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    gap: 16px; }
    .page-gift-services .service-item .service-item-icon {
      width: 80px;
      height: 80px; }
    .page-gift-services .service-item .service-item-des {
      font-size: 16px; }
      @media (min-width: 767px) {
        .page-gift-services .service-item .service-item-des {
          min-height: 70px; } }
    .page-gift-services .service-item .service-item-line {
      border: 1px solid #173963;
      min-width: 200px; }
  @media (max-width: 991.98px) {
    .page-gift-services {
      padding: 30px 0; }
      .page-gift-services .service-item .service-item-icon {
        width: 50px;
        height: 50px; } }
  @media (max-width: 767.98px) {
    .page-gift-services .service-item {
      margin-bottom: 16px; } }
  @media (min-width: 991.98px) {
    .page-gift-services .service-item {
      padding: 0px 15px; } }

.page-gift-procedure {
  background: #F4F5F7;
  padding: 80px 0; }
  .page-gift-procedure h2 {
    text-align: center;
    font-size: 40px;
    color: #173963;
    margin-bottom: 40px; }
  .page-gift-procedure .procedure-lists {
    display: flex;
    flex-wrap: wrap;
    gap: 32px; }
    .page-gift-procedure .procedure-lists .procedure-item {
      flex: 1; }
  @media (max-width: 991.98px) {
    .page-gift-procedure {
      padding: 30px 0; }
      .page-gift-procedure h2 {
        font-size: 32px;
        margin-bottom: 30px; }
      .page-gift-procedure .procedure-lists {
        justify-content: center; }
        .page-gift-procedure .procedure-lists .procedure-item {
          flex: 0 0 calc(25% - 24px);
          max-width: calc(25% - 24px); } }
  @media (max-width: 767.98px) {
    .page-gift-procedure .procedure-lists {
      justify-content: center;
      gap: 16px; }
      .page-gift-procedure .procedure-lists .procedure-item {
        flex: 0 0 calc(50% - 8px);
        max-width: calc(50% - 8px); } }

.page-gift-event {
  background: #F4F5F7;
  padding: 80px 0; }
  .page-gift-event h2 {
    text-align: center;
    font-size: 40px;
    color: #173963;
    margin-bottom: 40px; }
  .page-gift-event .item-article .media-article img {
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: 10px;
    width: 100%; }
  .page-gift-event .item-article .info-article {
    padding: 0px; }
    .page-gift-event .item-article .info-article .date-article {
      padding: 20px 0px; }
      .page-gift-event .item-article .info-article .date-article time {
        font-weight: 400;
        font-size: 16px;
        line-height: 24px;
        color: #8F8F8F; }
    .page-gift-event .item-article .info-article .title-article h4 a {
      font-weight: bold;
      font-size: 18px;
      line-height: 24px;
      color: #173963; }
  .page-gift-event .event-viewmore {
    text-align: center; }
    .page-gift-event .event-viewmore a {
      color: #173963;
      border: 1px solid #173963;
      padding: 8px 12px;
      border-radius: 6px; }
  .page-gift-event .event-slider {
    position: relative; }
    .page-gift-event .event-slider .owl-nav button {
      position: absolute;
      top: 40%;
      transform: translateY(-50%);
      width: 40px;
      height: 40px;
      background-color: rgba(0, 0, 0, 0.3) !important;
      border-radius: 6px !important;
      display: flex !important;
      align-items: center;
      justify-content: center;
      color: #fff !important;
      z-index: 2;
      font-size: 18px !important;
      outline: none; }
      .page-gift-event .event-slider .owl-nav button:hover {
        background: #173963 !important; }
      .page-gift-event .event-slider .owl-nav button i {
        color: #fff;
        font-size: 18px; }
    .page-gift-event .event-slider .owl-nav .owl-prev {
      left: -20px; }
    .page-gift-event .event-slider .owl-nav .owl-next {
      right: -20px; }
    .page-gift-event .event-slider .owl-dots {
      margin-top: 24px;
      text-align: center; }
      .page-gift-event .event-slider .owl-dots .owl-dot span {
        width: 8px;
        height: 8px;
        margin: 0 4px;
        background: #D9D9D9;
        border-radius: 50%;
        transition: all 0.3s ease; }
      .page-gift-event .event-slider .owl-dots .owl-dot:hover span {
        background: #173963;
        transform: scale(1.5); }
      .page-gift-event .event-slider .owl-dots .owl-dot.active span {
        background: #173963;
        transform: scale(1.5); }
  @media (max-width: 991px) {
    .page-gift-event .event-slider .owl-nav button {
      width: 32px;
      height: 32px; }
      .page-gift-event .event-slider .owl-nav button i {
        font-size: 16px; } }
  @media (max-width: 767px) {
    .page-gift-event .event-slider .owl-nav button {
      width: 28px;
      height: 28px; }
      .page-gift-event .event-slider .owl-nav button i {
        font-size: 14px; }
    .page-gift-event .event-slider .owl-nav .owl-prev {
      left: 0px; }
    .page-gift-event .event-slider .owl-nav .owl-next {
      right: 0px; } }
  @media (max-width: 991.98px) {
    .page-gift-event {
      padding: 30px 0; }
      .page-gift-event h2 {
        font-size: 32px;
        margin-bottom: 30px; } }

.page-gift-partners {
  background-color: #A2C6D24D;
  padding: 60px 0; }
  .page-gift-partners h2 {
    text-align: center;
    font-size: 40px;
    color: #173963;
    margin-bottom: 40px; }
  .page-gift-partners .partner-logo {
    background: #fff;
    border-radius: 8px;
    padding: 20px;
    margin: 0 10px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease; }
  .page-gift-partners .partner-logo img {
    max-width: 100%;
    max-height: 80px;
    object-fit: contain; }
  .page-gift-partners .owl-nav {
    display: flex;
    justify-content: center;
    margin-top: 20px; }
  .page-gift-partners .owl-prev, .page-gift-partners .owl-next {
    width: 40px;
    height: 40px;
    background: #fff !important;
    border-radius: 50% !important;
    margin: 0 10px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    color: #333 !important;
    font-size: 24px !important; }
  .page-gift-partners .owl-prev:hover, .page-gift-partners .owl-next:hover {
    background: #f0f0f0 !important; }
  @media (max-width: 991.98px) {
    .page-gift-partners {
      padding: 30px 0; }
      .page-gift-partners h2 {
        font-size: 32px;
        margin-bottom: 30px; } }

.page-gift-bannercenter {
  padding: 80px 0;
  background: #fff; }
  .page-gift-bannercenter h2 {
    text-align: center;
    font-size: 40px;
    color: #173963;
    margin-bottom: 40px; }
  .page-gift-bannercenter .bannercenter-lists {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
    justify-content: center; }
    .page-gift-bannercenter .bannercenter-lists .bannercenter-item {
      flex: 0 0 calc(33.3333% - 21.3333334px);
      max-width: calc(33.3333% - 21.3333334px);
      cursor: pointer;
      transition: transform 0.3s ease; }
      .page-gift-bannercenter .bannercenter-lists .bannercenter-item:hover {
        transform: translateY(-5px); }
  .page-gift-bannercenter .bannercenter-image {
    border-radius: 8px; }
    .page-gift-bannercenter .bannercenter-image img {
      width: 100%; }
  .page-gift-bannercenter .bannercenter-content {
    margin-top: 16px; }
  .page-gift-bannercenter .bannercenter-heading {
    color: #173963;
    margin-bottom: 16px; }
    .page-gift-bannercenter .bannercenter-heading h3 {
      font-size: 24px;
      color: #173963;
      line-height: 32px;
      margin-bottom: 4px; }
    .page-gift-bannercenter .bannercenter-heading p {
      margin: 0;
      color: #173963;
      font-size: 16px;
      line-height: 24px; }
  .page-gift-bannercenter .bannercenter-pricing {
    background: #173963;
    color: #fff;
    padding: 8px 12px;
    text-align: center;
    font-size: 16px;
    margin-bottom: 16px;
    cursor: pointer;
    border-radius: 6px;
    border: 1px solid #173963;
    transition: all 0.3s ease; }
    .page-gift-bannercenter .bannercenter-pricing:hover {
      color: #173963;
      background: transparent; }
  .page-gift-bannercenter .bannercenter-des {
    font-size: 16px;
    line-height: 24px;
    color: #173963; }
    .page-gift-bannercenter .bannercenter-des .title {
      font-size: 18px;
      line-height: 24px;
      font-weight: 700;
      text-decoration: underline; }
    .page-gift-bannercenter .bannercenter-des p + p {
      overflow: hidden;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      display: -webkit-box; }
  .page-gift-bannercenter .bannercenter-des-eng {
    display: none; }

#modal-gift .modal-dialog {
  max-width: 886px !important;
  width: 96% !important; }
  #modal-gift .modal-dialog .modal-content {
    border-radius: 24px;
    overflow: hidden; }

#modal-gift .modal-body {
  padding: 24px;
  border-radius: 24px;
  position: relative; }
  #modal-gift .modal-body .close-modal-gift {
    position: absolute;
    right: 20px;
    top: 20px;
    z-index: 9999;
    background: #ffffff;
    opacity: 1;
    border-radius: 100%;
    border: 1px solid #000000; }

#modal-gift .modal-gift-image {
  flex: 0 0 40%;
  max-width: 40%;
  border-radius: 8px; }
  #modal-gift .modal-gift-image .owl-carousel {
    height: 394px; }
    #modal-gift .modal-gift-image .owl-carousel .item {
      height: 394px; }
      #modal-gift .modal-gift-image .owl-carousel .item img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
  #modal-gift .modal-gift-image .owl-dots {
    position: absolute;
    bottom: 10px;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    gap: 5px; }
    #modal-gift .modal-gift-image .owl-dots button {
      width: 8px;
      height: 8px;
      background: rgba(255, 255, 255, 0.5) !important;
      border-radius: 50%;
      margin: 0 2px; }
    #modal-gift .modal-gift-image .owl-dots button.active {
      background: #fff !important; }
  #modal-gift .modal-gift-image .owl-nav button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background-color: rgba(0, 0, 0, 0.3) !important;
    border-radius: 6px !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    color: #fff !important;
    z-index: 2;
    font-size: 18px !important;
    outline: none; }
    #modal-gift .modal-gift-image .owl-nav button:hover {
      background: #173963 !important; }
    #modal-gift .modal-gift-image .owl-nav button i {
      color: #fff;
      font-size: 18px; }
  #modal-gift .modal-gift-image .owl-nav .owl-prev {
    left: -20px; }
  #modal-gift .modal-gift-image .owl-nav .owl-next {
    right: -20px; }
  @media (max-width: 991px) {
    #modal-gift .modal-gift-image .owl-nav button {
      width: 32px;
      height: 32px; }
      #modal-gift .modal-gift-image .owl-nav button i {
        font-size: 16px; } }
  @media (max-width: 767px) {
    #modal-gift .modal-gift-image .owl-nav button {
      width: 28px;
      height: 28px; }
      #modal-gift .modal-gift-image .owl-nav button i {
        font-size: 14px; }
    #modal-gift .modal-gift-image .owl-nav .owl-prev {
      left: 0px; }
    #modal-gift .modal-gift-image .owl-nav .owl-next {
      right: 0px; } }

#modal-gift .modal-gift-content {
  flex: 0 0 calc(100% - 40%);
  max-width: calc(100% - 40%);
  padding-left: 32px;
  text-align: left; }
  #modal-gift .modal-gift-content h3 {
    font-size: 24px;
    color: #173963;
    margin-bottom: 0; }
  #modal-gift .modal-gift-content .subtitle {
    font-size: 16px;
    color: #A2C6D2;
    margin-bottom: 16px; }

#modal-gift .modal-gift-pricing {
  color: #173963;
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 16px; }

#modal-gift .modal-gift-des {
  color: #8F8F8F;
  font-size: 16px;
  line-height: 24px; }
  #modal-gift .modal-gift-des .title {
    font-weight: 600;
    font-size: 16px;
    color: #173963;
    margin-bottom: 8px; }
  #modal-gift .modal-gift-des .line {
    margin: 16px 0;
    width: 80px;
    border: 1px solid #173963; }

#modal-gift .modal-gift-contact {
  border-radius: 20px;
  padding: 8px 12px;
  color: #fff;
  text-align: center;
  background: #173963;
  margin-top: 16px;
  cursor: pointer;
  border: 1px solid #173963;
  width: 100%; }
  #modal-gift .modal-gift-contact:hover {
    background: transparent;
    color: #173963; }

@media (max-width: 991.98px) {
  .page-gift-bannercenter {
    padding: 30px 0; } }

@media (max-width: 767px) {
  .page-gift-bannercenter .bannercenter-lists .bannercenter-item {
    flex: 100%;
    max-width: 100%; }
  #modal-gift .modal-gift-image {
    flex: 0 0 100%;
    max-width: 100%;
    border-radius: 8px;
    overflow: hidden; }
  #modal-gift .modal-gift-content {
    padding-top: 15px;
    flex: 0 0 100%;
    max-width: 100%;
    padding-left: 0;
    text-align: left; }
  #modal-gift .modal-gift-pricing {
    font-size: 24px; } }

@media (min-width: 768px) {
  #modal-gift #modal-gift .modal-dialog {
    min-width: 950px; } }

.footer-newsletter .wrapbox-newsletter {
  max-width: 1112px;
  margin: 0 auto; }

#modal-contact .footer-newsletter {
  background: none;
  padding: 0; }
  #modal-contact .footer-newsletter .wrapbox-newsletter {
    background: #f4f5f7;
    padding: 32px;
    border-radius: 16px; }

#modal-contact .modal-dialog {
  max-width: 886px !important;
  width: 96% !important; }

#modal-contact .modal-content {
  border-radius: 24px;
  overflow: hidden; }

#modal-contact .modal-body {
  padding: 0;
  position: relative; }

#modal-contact .close-modal-contact {
  position: absolute;
  right: 20px;
  top: 20px;
  z-index: 10;
  background: none;
  border: none; }

#modal-contact .contact-popup-content {
  width: 100%; }

@media (max-width: 767px) {
  #modal-contact .footer-newsletter .wrapbox-newsletter {
    padding: 20px; }
  #modal-contact .modal-body {
    padding: 20px; } }

/* Alert Styles */
.alert {
  padding: 16px;
  border-radius: 8px;
  margin-bottom: 20px;
  border: 1px solid;
  animation: slideInDown 0.3s ease-out; }

.alert-content {
  display: flex;
  align-items: center;
  gap: 12px; }

.alert-content svg {
  flex-shrink: 0; }

.alert-success {
  background-color: #f0fdf4;
  border-color: #10b981;
  color: #065f46; }

.alert-error {
  background-color: #fef2f2;
  border-color: #ef4444;
  color: #991b1b; }

.alert-warning {
  background-color: #fffbeb;
  border-color: #f59e0b;
  color: #92400e; }

/* Button Loading State */
.btn-submit:disabled {
  opacity: 0.7;
  cursor: not-allowed; }

.btn-submit:disabled svg {
  animation: spin 1s linear infinite; }

/* Form Validation Styles */
.form-control.error {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1); }

.form-control.success {
  border-color: #10b981;
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1); }

/* Animations */
@keyframes slideInDown {
  from {
    opacity: 0;
    transform: translateY(-20px); }
  to {
    opacity: 1;
    transform: translateY(0); } }

@keyframes spin {
  from {
    transform: rotate(0deg); }
  to {
    transform: rotate(360deg); } }

/* Smooth transitions */
.form-control {
  transition: all 0.3s ease; }

.alert {
  transition: opacity 0.5s ease; }
