@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');

@font-face {
  font-family: "S FU Futura Bold";
  src: url("../fonts/SFUFuturaBold.TTF");
  font-style: normal;
  font-display: block;
}

@keyframes spin {
  to {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg)
  }
}

@-webkit-keyframes spin {
  to {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg)
  }
}

@keyframes blink {
  0% {
    opacity: 1
  }

  50% {
    opacity: 0
  }

  100% {
    opacity: 1
  }
}

@-webkit-keyframes blink {
  0% {
    opacity: 1
  }

  50% {
    opacity: 0
  }

  100% {
    opacity: 1
  }
}

@keyframes shake-anim {
  0% {
    -webkit-transform: rotate(0) scale(1) skew(1deg);
    transform: rotate(0) scale(1) skew(1deg)
  }

  10%,
  30% {
    -moz-transform: rotate(-25deg) scale(1) skew(1deg)
  }

  20%,
  40% {
    -moz-transform: rotate(25deg) scale(1) skew(1deg)
  }

  100%,
  50% {
    -moz-transform: rotate(0) scale(1) skew(1deg)
  }
}

@-webkit-keyframes shake-anim {

  0%,
  100%,
  50% {
    -webkit-transform: rotate(0) scale(1) skew(1deg)
  }

  10%,
  30% {
    -webkit-transform: rotate(-25deg) scale(1) skew(1deg)
  }

  20%,
  40% {
    -webkit-transform: rotate(25deg) scale(1) skew(1deg)
  }
}

input,
button,
select {
  appearance: none;
  box-shadow: none !important
}

body {
  font-size: 14px;
  font-family: 'Montserrat', sans-serif;
  background-color: #333333;
  color: #fff;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top
}

a,
XA input,
textarea {
  outline: none;
  padding: 0px
}

a {
  text-decoration: none !important
}

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0
}

#toc-content *,
.content-main * {
  max-width: 100%
}

#toc-content a,
.content-main a {
  color: #ff0000 !important;
}

img {
  max-width: 100% !important
}

.w-clear:after {
  display: block;
  content: "";
  clear: both
}

.hidden {
  display: none
}

.clear {
  clear: both
}

.none {
  display: none
}

.hidden-seoh {
  visibility: hidden;
  height: 0px;
  margin: 0px;
  overflow: hidden
}

.wap_1200 {
  max-width: 1200px;
  margin: auto;
  position: relative;
}

.wrap-main,
.wrap-content {
  max-width: 1200px;
  margin: 40px auto;
  padding: 0px
}

.wrap-home {
  max-width: 100%;
  padding: 0px;
  margin: 0;
}

.wrap-content {
  margin: auto
}

.title-main {
  margin-bottom: 1.5rem;
  text-align: center;
  padding-bottom: 30px;
  background: url(../images/line.png) no-repeat center bottom;
}

.title-main span {
  font-weight: 600;
  font-size: 40px;
  color: #ffffff;
}

.time-main {
  margin-bottom: 0.75rem;
  color: #999999
}

.time-main i {
  vertical-align: top;
  margin: 3px 7px 0px 0px
}

.time-main span {
  vertical-align: top;
  display: inline-block
}

.share {
  padding: 17px 15px 10px 15px;
  line-height: normal;
  background: rgba(128, 128, 128, 0.15);
  margin-top: 15px;
  border-radius: 5px
}

.share b {
  display: block;
  margin-bottom: 5px
}

.control-owl {
  position: absolute;
  width: 100%;
  z-index: 2;
  left: 0px;
  top: calc(50% - 45px / 2)
}

.control-owl button {
  opacity: 0.5;
  top: 0px;
  position: absolute;
  outline: none;
  border: 0px;
  padding: 0px;
  margin: 0px;
  display: block;
  cursor: pointer;
  color: #ffffff;
  width: 45px;
  height: 45px;
  text-align: center;
  font-size: 25px;
  margin: 0px;
  background-color: #000000;
  border-radius: 3px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.control-owl button:hover {
  opacity: 1
}

.control-owl button.owl-prev {
  left: 20px
}

.control-owl button.owl-next {
  right: 20px
}

.form-control,
.form-control-plaintext:not(textarea),
.custom-select {
  height: calc(1em + 1.25rem + 8px)
}

.custom-form-row {
  margin-right: -10px;
  margin-left: -10px
}

.custom-form-row>.col,
.custom-form-row>[class*="col-"] {
  padding-right: 10px;
  padding-left: 10px
}

.text-sm {
  font-size: 0.875rem !important
}

img.lazy {
  opacity: 0
}

img:not(.initial) {
  -webkit-transition: opacity 1s;
  transition: opacity 1s
}

img.initial,
img.loaded,
img.error {
  opacity: 1
}

img:not([src]) {
  visibility: hidden
}

.wrap-user {
  width: 100%;
  max-width: 550px;
  margin: auto;
  border: 1px solid #bce8f1;
  border-radius: 5px
}

.title-user {
  background-color: #cc0000;
  padding: 12px 15px;
  border-radius: 5px 5px 0px 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.title-user span {
  color: #ffffff;
}

.title-user a {
  color: #0056b3;
  font-size: 12px
}

.form-user {
  padding: 20px 15px;
  border: 1px solid #c00;
  border-top: none;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}

.input-user {
  margin-bottom: 0.75rem
}

.input-user input {
  font-size: 14px
}

.button-user {
  margin-bottom: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.button-user input {
  font-size: 14px
}

.checkbox-user,
.radio-user {
  cursor: pointer
}

.checkbox-user input {
  top: calc(50% - 1.25rem / 2);
  height: auto
}

.checkbox-user label {
  font-size: 14px;
  cursor: pointer
}

.checkbox-user label::before,
.checkbox-user label::after {
  top: calc(50% - 1rem / 2)
}

.radio-user {
  margin-right: 1rem
}

.radio-user:last-child {
  margin-right: 0px
}

.radio-user label::before,
.radio-user label::after {
  top: calc(50% - 1rem / 2)
}

.note-user {
  font-size: 14px;
  border-top: 1px solid #ddd;
  padding-top: 0.5rem
}

#popup-cart .modal-title {
  text-transform: uppercase
}

#popup-cart .modal-body .wrap-cart {
  padding: 0px;
  -webkit-box-shadow: none;
  box-shadow: none;
  border: 0px
}

#popup-cart .modal-footer {
  padding: 0.75rem 0 0 0;
  border-top: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.buymore-cart {
  color: var(--maincolor);
  cursor: pointer;
  margin: 0px
}

.buymore-cart i {
  margin-right: 2px;
  margin-top: 5px;
  vertical-align: top;
  font-size: 12px
}

.wrap-cart {
  padding: 20px 15px;
  background: #ffffff;
  border: 1px solid #d8d8d8;
  -webkit-box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.15)
}

.top-cart {
  border-right: 1px solid #eee
}

.procart {
  padding: 20px 10px;
  border: 1px solid #eee;
  border-top: 0px
}

.pic-procart {
  text-align: center
}

.pic-procart img {
  max-height: 100px;
  height: inherit
}

.pic-procart .del-procart {
  color: #999;
  font-size: 12px;
  display: block;
  margin-top: 5px;
  cursor: pointer
}

.pic-procart .del-procart:hover {
  color: var(--maincolor)
}

.name-procart a {
  font-size: 14px;
  color: #000;
  display: block
}

.name-procart a:hover {
  color: var(--maincolor)
}

.properties-procart {
  display: block
}

.properties-procart p {
  display: inline-block;
  margin-bottom: 0px
}

.properties-procart p:first-child {
  margin-right: 10px
}

.properties-procart p strong {
  font-weight: 600
}

.quantity-procart p {
  margin-bottom: 0px
}

.quantity-counter-procart {
  border: 1px solid #dfdfdf;
  width: 100%;
  height: 30px;
  line-height: normal;
  text-align: center;
  border-radius: 3px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.counter-procart {
  background-color: transparent;
  border: 0px;
  width: 30%;
  color: #333;
  outline: none;
  cursor: pointer;
  font-size: 23px
}

.counter-procart:hover,
.counter-procart:focus {
  color: var(--maincolor)
}

.counter-procart:disabled {
  color: #ccc;
  cursor: not-allowed
}

.counter-procart:disabled:hover {
  color: #ccc;
  cursor: not-allowed
}

.counter-procart-minus {
  line-height: 26px
}

.counter-procart-plus {
  line-height: 24px
}

.quantity-counter-procart .quantity-procart {
  width: 40%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 0px;
  border-right: 1px solid #dfdfdf;
  border-left: 1px solid #dfdfdf;
  outline: none;
  -webkit-box-shadow: none;
  box-shadow: none;
  padding: 0px;
  color: #333;
  text-align: center
}

.price-procart {
  width: 20%;
  text-align: right
}

.price-procart-rp {
  display: none;
  width: 100%;
  margin-bottom: 10px;
  font-size: 13.5px
}

.price-new-cart {
  color: var(--maincolor);
  margin-bottom: 0px;
  font-weight: bold
}

.price-old-cart {
  color: #999;
  text-decoration: line-through
}

.procart-label {
  border: 0px;
  background: #eee;
  padding: 10px;
  margin: 0px;
  text-transform: capitalize
}

.money-procart {
  margin-top: 15px
}

.total-procart {
  background: #eee;
  padding: 7px 10px;
  border: 1px solid #dddfe2;
  margin-bottom: -1px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.total-procart p {
  margin-bottom: 0px;
  font-size: 15px
}

.total-procart p:last-child {
  color: var(--maincolor);
  font-weight: bold
}

.section-cart {
  position: -webkit-sticky;
  position: sticky;
  top: 15px
}

.title-cart {
  font-size: 15px;
  text-transform: uppercase;
  color: var(--maincolor);
  border-bottom: 1px solid #eee;
  padding-bottom: 5px;
  margin-bottom: 15px;
  font-weight: bold
}

.information-cart {
  margin-bottom: 1.5rem
}

.input-cart {
  margin-bottom: 0.5rem;
  position: relative
}

.input-cart textarea {
  resize: none;
  height: 100px
}

.input-cart select {
  cursor: pointer
}

.payments-cart {
  text-align: left;
  margin-bottom: 5px;
  min-height: auto
}

.payments-cart:last-child {
  margin-bottom: 0px
}

.payments-cart input {
  top: calc(50% - 1.25rem / 2)
}

.payments-label {
  cursor: pointer;
  background: #eee;
  display: block;
  padding: 10px 15px;
  border-radius: 3px;
  margin-bottom: 0px;
  color: #313131 !important
}

.payments-label::before,
.payments-label::after {
  top: calc(50% - 1rem / 2)
}

.payments-label.active {
  background: var(--maincolor);
  color: #ffffff !important
}

.payments-info {
  opacity: 0;
  visibility: hidden;
  height: 0px;
  overflow: hidden;
  background: #f5efef;
  border-radius: 5px
}

.payments-info p {
  margin-bottom: 1em
}

.payments-info.active {
  padding: 10px 15px;
  margin-top: 5px;
  opacity: 1;
  visibility: visible;
  height: auto
}

.btn-cart {
  text-transform: capitalize
}

.empty-cart {
  padding: 25px 30px;
  display: block;
  text-align: center;
  color: #23527c !important;
  width: 100%;
  border: 1px solid #c00;
  border-top: 0;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}

.empty-cart i {
  color: red;
  font-size: 70px
}

.empty-cart p {
  margin: 15px 0px;
  color: #333;
  font-size: 18px
}

.comment-title {
  font-size: 18px
}

.comment-show {
  display: block !important
}

.comment-point {
  font-size: 47px;
  color: #cc0000
}

.comment-star {
  font-size: 0;
  position: relative;
  display: inline-block;
  vertical-align: top;
  margin-bottom: 0.5rem
}

.comment-star span {
  display: block;
  position: absolute;
  top: 0;
  left: 0px;
  bottom: 0;
  z-index: 1;
  overflow: hidden;
  text-align: left;
  white-space: nowrap
}

.comment-star i {
  display: inline-block;
  margin: 0.1rem;
  color: #b8b8b8;
  text-rendering: auto;
  font-size: 20px
}

.comment-star i:nth-child(1) {
  margin-left: 0
}

.comment-star span i {
  color: #ffc120
}

.comment-progress {
  width: 100%;
  margin-bottom: 0.375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.comment-progress:last-child {
  margin-bottom: 0px
}

.comment-progress .progress {
  height: 12px;
  margin-right: 10px;
  margin-left: 5px;
  width: calc(100% - 90px);
  border-radius: 10px
}

.comment-progress .progress-bar#has-rate {
  background-color: #cc0000
}

.comment-progress .progress-num {
  font-size: 15px;
  width: 25px;
  text-align: center;
  color: #787878
}

.comment-progress .progress-total {
  font-weight: 600;
  text-align: left;
  color: #787878;
  width: 50px
}

.comment-write {
  display: none
}

.review-rating-star {
  font-size: 0
}

.review-rating-star-icon .fa {
  font-weight: 400;
  font-style: normal;
  display: inline-block;
  margin: 0.1rem;
  font-size: 21px;
  cursor: pointer;
  color: #f0c808
}

.review-rating-star-icon .fa.star-empty {
  color: #dedddc
}

.review-rating-star-icon .fa.star-not-empty {
  color: #f0c808
}

.review-rating-star-icon .fa:nth-child(1) {
  margin-left: 0
}

.review-fileuploader {
  padding: 20px 15px;
  text-align: center;
  background-color: #ffffff;
  cursor: pointer;
  border: 2px dashed #c2cdda;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.review-fileuploader .review-fileuploader-text {
  color: #90a0bc
}

.review-file-uploader .fileuploader {
  padding: 0px;
  margin: 0px;
  background: transparent
}

.review-file-uploader .fileuploader-items .fileuploader-items-list {
  margin: 1rem -5px 0 -5px
}

.review-file-uploader .fileuploader-items .fileuploader-items-list:after {
  display: block;
  content: "";
  clear: both
}

.review-file-uploader .fileuploader-items .fileuploader-items-list .fileuploader-item {
  padding: 0px;
  width: calc(100% / 7 - 10px);
  float: left;
  margin: 0 5px 5px 5px;
  border-bottom: 0px
}

.review-file-uploader .fileuploader-items .fileuploader-items-list .fileuploader-item .columns {
  display: block
}

.review-file-uploader .fileuploader-items .fileuploader-items-list .fileuploader-item .column-thumbnail {
  width: auto;
  height: auto
}

.review-file-uploader .fileuploader-items .fileuploader-items-list .fileuploader-item .column-thumbnail .fileuploader-item-image {
  height: auto;
  padding: 50% 0
}

.review-file-uploader .fileuploader-items .fileuploader-items-list .fileuploader-item .column-thumbnail .fileuploader-item-image img {
  position: absolute;
  top: 0px;
  left: 0px;
  max-width: 100%;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -webkit-transform: none;
  transform: none
}

.review-file-uploader .fileuploader-items .fileuploader-items-list .fileuploader-item .column-title {
  padding: 0px;
  margin-top: 0.5rem;
  text-align: center;
  display: none
}

.review-file-uploader .fileuploader-items .fileuploader-items-list .fileuploader-item .column-actions {
  margin: 0px;
  position: absolute;
  top: 0px;
  right: -5px
}

.review-file-uploader .fileuploader-items .fileuploader-items-list .fileuploader-item .column-infos input {
  border: 1px solid #dddddd;
  border-radius: 0.25rem
}

.review-poster-video-avatar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start
}

.review-poster-video-avatar .avatar-detail {
  width: 95px;
  height: 95px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.review-poster-video-avatar .avatar-detail img {
  max-width: 95px;
  max-height: 95px
}

#review-content {
  height: 350px
}

.carousel-comment-media .carousel-control a {
  opacity: 1;
  width: 45px;
  height: 45px;
  top: calc(50% - 45px / 2);
  bottom: inherit
}

.carousel-comment-media .carousel-control a span {
  display: block;
  cursor: pointer;
  color: #222222;
  width: 45px;
  height: 45px;
  padding: 5px;
  text-align: center;
  background-color: #ffffff;
  -webkit-box-shadow: 0 1px 12px 0 rgba(0, 0, 0, 0.12);
  box-shadow: 0 1px 12px 0 rgba(0, 0, 0, 0.12);
  border-radius: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.carousel-comment-media .carousel-control a.carousel-control-prev {
  left: 20px
}

.carousel-comment-media .carousel-control a.carousel-control-prev span {
  padding-right: 9px
}

.carousel-comment-media .carousel-control a.carousel-control-next {
  right: 20px
}

.carousel-comment-media .carousel-control a.carousel-control-next span {
  padding-left: 8px
}

.carousel-comment-media .carousel-indicators {
  position: static;
  margin: 0px 0px 0.75rem 0px;
  text-align: left;
  display: block
}

.carousel-comment-media .carousel-indicators li {
  width: auto;
  max-width: 60px;
  height: auto;
  text-indent: inherit;
  -webkit-box-flex: 0;
  -ms-flex: none;
  flex: none;
  margin: 0px 0px 3px 0px;
  border: 2px solid transparent;
  opacity: 1;
  cursor: -webkit-zoom-in;
  cursor: zoom-in
}

.carousel-comment-media .carousel-indicators li.active {
  border-color: #ffc120;
  cursor: -webkit-zoom-out;
  cursor: zoom-out;
  -webkit-transform: scale(1.05);
  transform: scale(1.05)
}

.carousel-comment-media .carousel-inner {
  max-width: 550px;
  -webkit-box-shadow: 0 1px 12px 0 rgba(0, 0, 0, 0.12);
  box-shadow: 0 1px 12px 0 rgba(0, 0, 0, 0.12)
}

.carousel-comment-media .carousel-inner .carousel-lists .carousel-comment-media-item-video #file-video {
  max-width: 100%;
  width: 100%;
  height: 500px;
  vertical-align: top;
  display: inline-block;
  background-color: #000000
}

#form-reply {
  display: none
}

.comment-item {
  margin-bottom: 3rem
}

.comment-item-poster {
  width: 200px;
  margin-right: 30px;
  text-align: center
}

.comment-item-letter {
  border-radius: 50%;
  background-color: #d3d2d3;
  color: #919090;
  width: 65px;
  height: 65px;
  text-transform: uppercase;
  display: inline-block;
  vertical-align: top;
  line-height: 67px;
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 0.5rem
}

.comment-item-name {
  margin-bottom: 0.25rem;
  text-transform: capitalize
}

.comment-item-posttime {
  font-size: 12px;
  color: #999999
}

.comment-item-information {
  width: calc(100% - 230px)
}

.comment-item-star {
  float: left;
  margin-right: 10px
}

.comment-item-star i {
  font-size: 17px
}

.comment-item-title {
  font-size: 15px;
  font-weight: 500
}

.comment-replies {
  position: relative;
  background: #f8f9fa;
  border: 1px solid #dfdfdf;
  padding: 1.75rem 1.5rem
}

.comment-replies:after {
  content: "";
  position: absolute
}

.comment-replies:before {
  content: "";
  position: absolute;
  z-index: 1;
  top: -13px;
  left: 10px;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 13px solid #f8f9fa
}

.comment-replies:after {
  top: -14px;
  left: 9px;
  border-left: 11px solid transparent;
  border-right: 11px solid transparent;
  border-bottom: 14px solid #dfdfdf
}

.comment-replies-item {
  margin-bottom: 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start
}

.comment-replies-item:last-child {
  margin-bottom: 0px
}

.comment-replies-letter {
  width: 45px;
  height: 45px;
  margin-right: 10px;
  line-height: 45px;
  padding-left: 1px;
  font-size: 14px;
  border-radius: 50%;
  background-color: #e5e3e5;
  color: #919090;
  text-transform: uppercase;
  display: inline-block;
  vertical-align: top;
  font-weight: 500;
  text-align: center;
  margin-top: 0.125rem
}

.comment-replies-letter.admin {
  position: relative;
  background-color: #189eff;
  text-indent: 9999px;
  overflow: hidden
}

.comment-replies-letter.admin:before {
  content: "QTV";
  text-indent: 0px;
  color: #ffffff;
  font-weight: 500;
  text-transform: uppercase;
  font-size: 13px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}

.comment-replies-info {
  width: calc(100% - 55px)
}

.comment-replies-name {
  font-weight: 500;
  margin-bottom: 0.125rem
}

.comment-replies [class*="btn-load-more-"] {
  border: 0px;
  outline: none;
  padding: 0px;
  background: transparent
}

.comment-media-play {
  z-index: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%)
}

.comment-media-play svg {
  -webkit-box-shadow: 1px 1px 15px rgba(0, 0, 0, 0.3);
  box-shadow: 1px 1px 15px rgba(0, 0, 0, 0.3);
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.15)
}

.comment-media-play svg .comment-media-play-stroke-dotted {
  opacity: 0;
  stroke-dasharray: 4, 5;
  stroke-width: 1px;
  -webkit-transform-origin: 50% 50%;
  transform-origin: 50% 50%;
  -webkit-animation: spin 4s infinite linear;
  animation: spin 4s infinite linear;
  -webkit-transition: opacity 1s ease, stroke-width 1s ease;
  transition: opacity 1s ease, stroke-width 1s ease
}

.comment-media-play svg .comment-media-play-stroke-solid {
  stroke-dashoffset: 0;
  stroke-dasharray: 300;
  stroke-width: 4px;
  -webkit-transition: stroke-dashoffset 1s ease, opacity 1s ease;
  transition: stroke-dashoffset 1s ease, opacity 1s ease
}

.comment-media-play svg .comment-media-play-icon {
  -webkit-transform-origin: 50% 50%;
  transform-origin: 50% 50%;
  -webkit-transition: -webkit-transform 200ms ease-out;
  transition: -webkit-transform 200ms ease-out;
  transition: transform 200ms ease-out;
  transition: transform 200ms ease-out, -webkit-transform 200ms ease-out
}

.comment-media-play:hover svg .comment-media-play-stroke-dotted {
  stroke-width: 4px;
  opacity: 1
}

.comment-media-play:hover svg .comment-media-play-stroke-solid {
  opacity: 0;
  stroke-dashoffset: 300
}

.comment-media-play:hover svg .comment-media-play-icon {
  -webkit-transform: scale(1.05);
  transform: scale(1.05)
}

.menu {}

.menu ul {
  width: 100%;
  padding: 0px;
  margin: auto;
  list-style: none
}

.menu ul.menu-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 15px;
  margin-bottom: 40px;
}

.menu ul li {
  position: relative;
  z-index: 1
}

.menu ul li.li-home {}

.menu ul li.li-home a {
  padding-left: 0;
}

.menu ul li.li-tim {}

.menu ul li.li-tim a {}

.menu ul li.menu-line {
  width: 1px;
  height: 15px;
  background-color: rgba(0, 0, 0, 0.1)
}

.menu ul li ul li a {
  background-color: transparent !important;
}

.menu ul li a.active,
.menu ul li a:hover {
  border-radius: 21px;
  background-color: #ed1c24;
}

.menu ul li a {
  display: block;
  position: relative;
  font-size: 15px;
  color: #ffffff;
  padding: 11px 12px;
  text-transform: uppercase;
  text-decoration: none;
  font-weight: 600;
}

.menu ul li a.has-child {
  padding-right: 16px;
  margin-right: 8px
}

.menu ul li a.has-child:after {
  content: "";
  position: absolute;
  bottom: calc(50% - 4px / 2);
  right: 5px;
  width: 5px;
  height: 5px;
  border: 1px solid #fafafa;
  border-top: 0px;
  border-left: 0px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}

.menu ul li ul {
  position: absolute;
  min-width: 250px;
  margin-top: -5px;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  background-color: #fafafa;
  border-radius: 0.25rem;
  -webkit-box-shadow: 1px 1px 15px rgba(0, 0, 0, 0.15);
  box-shadow: 1px 1px 15px rgba(0, 0, 0, 0.15);
  -webkit-transform: perspective(600px) rotateX(-90deg);
  transform: perspective(600px) rotateX(-90deg);
  -webkit-transform-origin: 0 0 0;
  transform-origin: 0 0 0;
  opacity: 0;
  visibility: hidden
}

.menu ul li:hover>ul {
  -webkit-transform: perspective(600px) rotateX(0);
  transform: perspective(600px) rotateX(0);
  transform-origin: 0 0 0;
  -webkit-transform-origin: 0 0 0;
  opacity: 1;
  visibility: visible
}

.menu ul li ul li {
  padding-left: 0.75rem;
  padding-right: 0.75rem
}

.menu ul li ul li a {
  font-size: 14px;
  color: #313131;
  border-bottom: 1px solid #ececec;
  padding: 10px 0px 9px 0px;
  text-transform: capitalize
}

.menu ul li ul li a.has-child {
  margin-right: 0px
}

.menu ul li ul li a.has-child:after {
  border-color: #313131;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}

.menu ul li ul li a.active {
  color: #ec2d3f
}

.menu ul li ul li a.active.has-child:after {
  border-color: #ec2d3f
}

.menu ul li ul li:last-child>a {
  border-bottom: 0px
}

.menu ul li ul li:hover>a {
  color: var(--maincolor)
}

.menu ul li ul li:hover>a.has-child:after {
  border-color: var(--maincolor)
}

.menu ul li ul li ul {
  top: -0.75rem;
  left: 100%;
  margin-top: 0px
}

.search {
  width: 230px;
  background: #ffffff;
  position: relative
}

.search p {
  float: left;
  width: 35px;
  height: 35px;
  line-height: 35px;
  cursor: pointer;
  text-align: center;
  margin: 0px;
  color: #6c757d;
  font-size: 16px
}

.search input {
  width: calc(100% - 35px);
  height: 35px;
  float: left;
  outline: none;
  padding: 0px;
  border: 0px;
  background: transparent;
  text-indent: 10px;
  font-size: 12px
}

.search input::-webkit-input-placeholder {
  color: #313131
}

.search input:-moz-placeholder {
  color: #313131
}

.search input::-moz-placeholder {
  color: #313131
}

.search input:-ms-input-placeholder {
  color: #313131
}

.menu-res {
  height: 80px;
  z-index: 997;
  background: black position: sticky;
  display: none;
  position: -webkit-sticky;
  top: 0;
}

.menu-bar-res {
  height: 80px;
  padding: 0px 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

#menu {
  display: none
}

#hamburger {
  display: block;
  width: 45px;
  height: 23px;
  position: relative
}

#hamburger:before,
#hamburger:after,
#hamburger span {
  background: #ea0606;
  content: "";
  display: block;
  width: 100%;
  height: 3px;
  position: absolute;
  left: 0px
}

#hamburger:before {
  top: 0px
}

#hamburger span {
  top: 10px
}

#hamburger:after {
  top: 20px
}

#hamburger:before,
#hamburger:after,
#hamburger span {
  -webkit-transition: none 0.5s ease 0.5s;
  transition: none 0.5s ease 0.5s;
  -webkit-transition-property: transform, top, bottom, left, opacity;
  -webkit-transition-property: top, bottom, left, opacity, -webkit-transform;
  transition-property: top, bottom, left, opacity, -webkit-transform;
  transition-property: transform, top, bottom, left, opacity;
  transition-property: transform, top, bottom, left, opacity, -webkit-transform
}

.mm-wrapper_opening #hamburger:before,
.mm-wrapper_opening #hamburger:after {
  top: 10px
}

.mm-wrapper_opening #hamburger span {
  left: -50px;
  opacity: 0
}

.mm-wrapper_opening #hamburger:before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}

.mm-wrapper_opening #hamburger:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}

.mm-menu_opened {
  display: block !important
}

.mm-slideout {
  z-index: unset
}

.slideshow {
  position: relative;
  overflow: hidden
}

.slideshow-item {
  display: block;
  cursor: pointer
}

.slideshow:hover .control-slideshow {
  opacity: 1
}

.control-slideshow {
  opacity: 0
}

.wrap-partner {
  padding: 0px 15px
}

.wrap-partner .wrap-content {
  position: relative
}

.partner {
  display: block;
  border: 1px solid #eee;
  max-width: 175px;
  margin: 0px auto
}

.breadCrumbs {
  background-color: #eee
}

.breadCrumbs .wrap-content {
  padding: 0.75rem 0;
}

.breadCrumbs .wrap-content .breadcrumb {
  padding: 0;
  margin-bottom: 0;
  background-color: transparent;
  border-radius: 0
}

.breadCrumbs .wrap-content .breadcrumb-item a {
  color: #212529
}

.breadCrumbs .wrap-content .breadcrumb-item.active a {
  color: #6c757d
}

.hover_sang1 {
  position: relative;
  overflow: hidden;
}

.hover_sang1:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.5);
  content: '';
  z-index: 10;
  -webkit-transition: -webkit-transform 0.6s;
  transition: transform 0.6s;
  -webkit-transform: scale3d(2.2, 1.4, 1) rotate3d(0, 0, 1, 45deg) translate3d(0, -120%, 0);
  transform: scale3d(2.2, 1.4, 1) rotate3d(0, 0, 1, 45deg) translate3d(0, -120%, 0);
}

.hover_sang1:hover:before {
  -webkit-transform: scale3d(2.2, 1.4, 1) rotate3d(0, 0, 1, 45deg) translate3d(0, 120%, 0);
  transform: scale3d(2.2, 1.4, 1) rotate3d(0, 0, 1, 45deg) translate3d(0, 120%, 0);
}

.hover_sang2 {
  position: relative;
  overflow: hidden;
}

.hover_sang2:before {
  position: absolute;
  top: 0;
  left: -85%;
  z-index: 10;
  display: block;
  content: '';
  width: 50%;
  height: 100%;
  background: -webkit-linear-gradient(left, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .3) 100%);
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .3) 100%);
  -webkit-transform: skewX(-25deg);
  transform: skewX(-25deg);
}

.hover_sang2:hover:before {
  transition: 1s;
  left: 100%;
}

.wrap-intro {
  background-color: #eeeadd
}

.news-intro:before {
  content: "";
  position: absolute;
  width: 1px;
  height: calc(100% - 50px);
  top: 10px;
  left: 90px;
  background-color: #cacaca
}

.news-scroll:before,
.news-scroll:after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  left: 85px;
  border-radius: 100%;
  background-color: #cacaca
}

.news-scroll:before {
  top: 10px
}

.news-scroll:after {
  bottom: 40px
}

.news-control {
  left: 85px;
  font-size: 13px;
  opacity: 0.5;
  z-index: 1;
  cursor: pointer
}

.news-control:hover {
  opacity: 1;
  color: #ec2d3f
}

.news-control#up {
  top: -10px
}

.news-control#down {
  bottom: 20px
}

.news-shadow {
  padding-bottom: 30px;
}

.news-shadow .news-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  position: relative;
}

.news-shadow .news-shadow-time {
  font-size: 13px;
  width: 75px;
  margin-right: 45px;
}

.news-shadow .news-shadow-time:after {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  top: calc(50% - 20px / 2);
  right: -26px;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url(../images/pattern-news.png)
}

.news-shadow .news-shadow-article {
  width: calc(100% - 120px);
  padding: 14px 15px;
  border-radius: 10px;
  background-color: #ffffff;
  border: 1px solid #cecabb;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.news-shadow .news-shadow-article:before {
  content: "";
  position: absolute;
  top: calc(50% - 26px / 2);
  left: -13px;
  z-index: 0;
  border-top: 13px solid transparent;
  border-right: 13px solid #cecabb;
  border-bottom: 13px solid transparent
}

.news-shadow .news-shadow-article:after {
  content: "";
  position: absolute;
  top: calc(50% - 24px / 2);
  left: -11px;
  z-index: 1;
  border-top: 12px solid transparent;
  border-right: 11px solid #ffffff;
  border-bottom: 12px solid transparent
}

.news-shadow .news-shadow-article .news-shadow-image {
  margin-right: 10px;
  width: 90px
}

.news-shadow .news-shadow-article .news-shadow-info {
  width: calc(100% - 100px)
}

.news-shadow .news-shadow-article .news-shadow-info .news-shadow-name {
  height: 36px;
  font-size: 15px;
  font-weight: 700
}

.news-shadow .news-shadow-article .news-shadow-info .news-shadow-name a {
  color: #222222
}

.news-shadow .news-shadow-article .news-shadow-info .news-shadow-name a:hover {
  color: #ec2d3f
}

.news-shadow .news-shadow-article .news-shadow-info .news-shadow-name a .text-split {
  -webkit-line-clamp: 2
}

.news-shadow .news-shadow-article .news-shadow-info .news-shadow-desc {
  height: 38px;
  font-size: 13px
}

.news-shadow .news-shadow-article .news-shadow-info .news-shadow-desc.text-split {
  -webkit-line-clamp: 2
}

/* Album */
.album {
  cursor: pointer;
  width: calc(50% - 20px);
  margin: 10px 10px;
  text-align: center;
  cursor: pointer;
}

.album-image {
  margin-bottom: 0.75rem;
}

.pic-album {
  position: relative;
}

.pic-album img {
  width: 100%;
}

.name-album {
  font-size: 16px;
  color: #000;
  margin-bottom: 0px;
}

.album-name {
  margin-bottom: 0px;
  text-align: center;
}

.album-name a {
  display: block;
  font-size: 16px;
  color: #212529;
  margin-bottom: 0px;
}

/* Album */
.wrap-brand {
  margin-bottom: 50px;
  padding: 0px 15px
}

.wrap-brand .wrap-content {
  position: relative
}

.brand {
  display: block;
  border: 1px solid #eee;
  max-width: 160px;
  margin: 0px auto
}

.wrap-product {
  padding: 30px 0;
}

.product {
  width: calc(25% - 20px);
  margin: 10px 10px;
  position: relative;
}

.box-product {
  position: relative;
  display: block;
}


.name-product {
  color: #ffffff;
  font-weight: 500;
  font-size: 14px;
}

.name-product:hover {
  color: var(--maincolor);
}

.info_product {
  padding: 15px 10px;
  background-color: #ff0000;
  text-align: center;
}

.info_product p {
  color: #ffffff;
}

.info_product p .sdt {
  font-weight: bold;
  color: #fafafa;
  font-size: 15px;
}

.name-product.text-split {
  -webkit-line-clamp: 1
}

.price-product {
  margin-bottom: 0px
}

.price-product span {
  font-weight: 700
}

.price-new {
  font-size: 15px;
  font-weight: 500;
  color: #f00
}

.price-old {
  padding-left: 10px;
  font-size: 12px;
  color: #6c757d
}

.price-per {
  position: absolute;
  top: 15px;
  right: 15px;
  color: #ffffff;
  background: var(--maincolor);
  font-size: 11px;
  border-radius: 2px;
  width: 45px;
  height: 25px;
  text-align: center;
  line-height: 25px
}

.cart-product {
  margin-bottom: 0px;
  margin-top: 5px;
}

.cart-product span {
  cursor: pointer;
  color: #ffffff;
  text-transform: capitalize;
  text-align: center;
  background: #000;
  border-color: #000;
}

.cart-product span:hover {
  background: none !important;
  color: #000 !important;
  border-color: #000 !important;
}

.cart-product span:nth-child(2) {
  background: #f00;
  border-color: #f00;
}

.grid-pro-detail {
  margin-bottom: 3rem
}

.left-pro-detail {
  position: relative;
  text-align: center
}

.left-pro-detail .MagicZoom {
  border: 1px solid #eee;
  padding: 7px;
  border-radius: 5px;
  background-color: #ffffff
}

.gallery-thumb-pro {
  position: relative;
  margin-top: 10px
}

.owl-pro-detail {
  padding: 0px 30px
}

.control-pro-detail button {
  background-color: transparent;
  color: #222222;
  opacity: 1;
  width: 25px;
  font-size: 23px
}

.control-pro-detail button:hover {
  opacity: 0.7
}

.control-pro-detail button.owl-prev {
  left: 0px
}

.control-pro-detail button.owl-next {
  right: 0px
}

.thumb-pro-detail {
  display: block !important;
  border: 1px solid #eee;
  padding: 5px;
  border-radius: 3px;
  cursor: pointer;
  background-color: #ffffff
}

.thumb-pro-detail.mz-thumb.mz-thumb-selected {
  border-color: #cecfd2
}

.thumb-pro-detail img {
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  -webkit-filter: brightness(100%) !important;
  filter: brightness(100%) !important;
  border-bottom: 0px !important;
  padding-bottom: 0px !important
}

.title-pro-detail {
  text-transform: capitalize;
  font-size: 20px;
  display: block;
  font-weight: 700
}

.comment-pro-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start
}

.social-plugin-pro-detail {
  margin-bottom: 1rem;
  margin-top: 0px !important
}

.desc-pro-detail {
  margin-bottom: 1rem
}

.attr-pro-detail {
  list-style: none;
  padding: 0px
}

.attr-pro-detail li {
  margin-bottom: 0.5rem
}

.attr-label-pro-detail {
  margin: 0px 5px 0px 0px
}

.attr-label-pro-detail.d-block {
  display: block;
  margin: 0px 0px 5px 0px
}

.attr-content-pro-detail {
  display: inline-block;
  margin-bottom: 0px
}

.price-new-pro-detail {
  font-weight: 700;
  font-size: 20px;
  color: #ffffff;
}

.price-old-pro-detail {
  font-weight: 500;
  color: #6c757d;
  text-decoration: line-through;
  padding-left: 10px
}

.color-pro-detail {
  cursor: pointer;
  display: inline-block;
  vertical-align: top;
  position: relative;
  width: 35px;
  height: 30px;
  margin: 0px 0px 3px 0px;
  border: 1px solid transparent;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center
}

.size-pro-detail {
  cursor: pointer;
  border: 1px solid #ccc;
  padding: 3px 10px 4px 10px;
  display: inline-block;
  position: relative
}

.size-pro-detail.active {
  border-color: #e5101d;
  color: #e5101d
}

.color-pro-detail.active {
  border-color: #e5101d;
  color: #e5101d
}

.size-pro-detail.active:after {
  content: "";
  position: absolute;
  bottom: 0px;
  right: 0px;
  width: 13px;
  height: 13px;
  background-repeat: no-repeat;
  background-image: url(../images/check-cart.png)
}

.color-pro-detail.active:after {
  content: "";
  position: absolute;
  bottom: 0px;
  right: 0px;
  width: 13px;
  height: 13px;
  background-repeat: no-repeat;
  background-image: url(../images/check-cart.png)
}

.color-pro-detail input[type="radio"] {
  display: none
}

.size-pro-detail input[type="radio"] {
  display: none
}

.quantity-pro-detail {
  width: 100%;
  max-width: 110px;
  line-height: normal;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.quantity-pro-detail span {
  line-height: 25px;
  padding: 0px;
  width: 30px;
  height: 30px;
  color: #5f5f5f;
  cursor: pointer;
  font-size: 22px;
  border: 1px solid #cccccc
}

.quantity-pro-detail span.quantity-plus-pro-detail {
  border-left: 0px
}

.quantity-pro-detail span.quantity-minus-pro-detail {
  border-right: 0px
}

.quantity-pro-detail input {
  height: 30px;
  border: 1px solid #cccccc;
  width: calc(100% - 60px);
  text-align: center;
  font-size: 14px;
  padding: 5px
}

.cart-pro-detail {
  margin-bottom: 1rem
}

.cart-pro-detail a {
  font-size: 14px;
  color: #ffffff !important;
  text-transform: uppercase
}

.tags-pro-detail a {
  float: left;
  font-size: 13px;
  padding-bottom: 0.375rem;
  margin: 0px 5px 5px 0px
}

.tags-pro-detail a i {
  font-size: 11px;
  margin: 5px 5px 0px 0px
}

.tabs-pro-detail {
  margin-top: 2rem
}

.tabs-pro-detail .nav-tabs .nav-link {
  border-top-width: 3px;
  font-size: 13px
}

.tabs-pro-detail .nav-tabs .nav-link.active {
  border-top-color: #ff0000;
}

.tabs-pro-detail .nav-tabs .nav-item.show .nav-link {
  border-top-color: #555555
}

.othernews b {
  margin-bottom: 10px
}

.list-news-other {
  padding-left: 17px;
  list-style: square
}

.list-news-other li {
  margin-bottom: 2px
}

.list-news-other li a {
  text-transform: none;
  color: #333333
}

.list-news-other li a:hover {
  color: var(--maincolor)
}

.contact-article {
  margin-bottom: 3rem
}

.contact-input {
  position: relative;
  margin-bottom: 15px
}

.contact-input textarea {
  resize: none;
  height: 150px
}

.contact-input .custom-file-label::after {
  content: attr(title)
}

.contact-map {
  position: relative;
  height: 500px
}

.contact-map iframe {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100% !important;
  height: 100% !important
}

.newsletter-slogan {
  margin-bottom: 0.5rem;
  color: #6c757d
}

.newsletter-input {
  position: relative
}


.footer-article {
  background-color: #ffffff;
}

.footer-article .wrap-content {
  padding: 55px 0px;
}

.footer-title {
  text-transform: uppercase;
  font-size: 14px;
  margin-bottom: 1rem;
  font-weight: 500
}

.footer-ul {
  list-style: none;
  padding: 0px;
  margin: 0px
}

.footer-ul li {
  margin-bottom: 10px
}

.footer-ul li:last-child {
  margin-bottom: 0px
}

.footer-ul li a {
  color: #212529
}

.footer-ul li a:hover {
  text-decoration: none;
  color: var(--maincolor)
}

.footer-tags {
  background: #eee
}

.footer-tags .wrap-content {
  padding: 30px 15px
}

.footer-tags-lists {
  list-style: none;
  padding: 0px;
  margin: 0px
}

.footer-tags-lists li {
  float: left
}

.footer-tags-lists li a {
  padding-bottom: 0.375rem
}

.footer-powered {
  color: #ffffff;
  background-color: var(--maincolor)
}

.footer-powered .wrap-content {
  padding-top: 15px;
  padding-bottom: 15px
}

.footer-statistic {
  text-align: right
}

.footer-statistic span {
  padding-right: 10px
}

.footer-statistic span:last-child {
  padding-right: 0px
}

#footer-map {
  position: relative;
  height: 500px
}

#footer-map iframe {
  position: absolute !important;
  width: 100% !important;
  height: 100% !important;
  top: 0px !important;
  left: 0px !important
}

.social-plugin {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start
}

.social-plugin .at-share-btn {
  margin-bottom: 0px !important
}

.social-plugin .zalo-share-button {
  margin-left: 3px
}

.pagination-home .pagination .page-item .page-link {
  color: #555555;
  font-size: 0.875rem
}

.pagination-home .pagination .page-item.active .page-link {
  color: #ffffff;
  background-color: #555555;
  border-color: #555555
}

.pagination-ajax {
  text-align: center
}

.pagination-ajax a {
  display: inline-block;
  vertical-align: top;
  margin: 0px 3px 3px 3px;
  width: 35px;
  height: 35px;
  line-height: 33px;
  color: #666 !important;
  border: 1px solid #e6e6e6;
  font-size: 13px;
  cursor: pointer;
  text-decoration: none !important;
  background-color: #ffffff
}

.pagination-ajax a.current,
.pagination-ajax a:hover {
  color: #ffffff !important;
  border-color: #ec2d3f;
  background-color: #ec2d3f
}

.pagination-ajax a.first,
.pagination-ajax a.last,
.pagination-ajax a.prev,
.pagination-ajax a.next {
  text-indent: -9999px;
  position: relative;
  background-color: #ffffff !important
}

.pagination-ajax a.first:before,
.pagination-ajax a.last:before,
.pagination-ajax a.prev:before,
.pagination-ajax a.next:before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  z-index: 2;
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: center
}

.pagination-ajax a.first:before {
  background-image: url(../images/page-first.png)
}

.pagination-ajax a.last:before {
  background-image: url(../images/page-last.png)
}

.pagination-ajax a.prev:before {
  background-image: url(../images/page-prev.png)
}

.pagination-ajax a.next:before {
  background-image: url(../images/page-next.png)
}

#popup .modal-body {
  padding: 0px
}

#popup-map iframe {
  width: 100%
}

#popup button.close,
#popup-map button.close,
#popup-baogia button.close {
  width: 40px;
  height: 40px;
  display: block;
  position: absolute;
  right: 10px;
  top: 10px;
  z-index: 5;
  text-align: center;
  line-height: 40px;
  border-radius: 50%;
  box-shadow: 0 0 10px #000 !important;
  background: #f00;
  opacity: 1;
  color: #fff;
}

.grecaptcha-badge {
  display: none !important;
  width: 0px !important;
  height: 0px !important;
  visibility: hidden !important;
  overflow: hidden
}

coccocgrammar {
  display: none
}

.scrollToTop {
  width: 41px;
  height: 41px;
  text-align: center;
  font-weight: bold;
  color: #444;
  text-decoration: none;
  position: fixed;
  bottom: 65px;
  right: 25px;
  display: none;
  z-index: 10;
  cursor: pointer
}

.text-split {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  -webkit-line-clamp: 3
}

.transition,
.control-owl button,
.carousel-comment-media .carousel-control a span,
.menu ul li a.has-child:after,
.menu ul li ul,
.menu ul li:hover>ul,
.scale-img img,
.scale-img:hover>img,
.btn-frame .kenit-alo-circle-fill,
.support-online .kenit-alo-circle-fill {
  -webkit-transition: 0.3s all;
  transition: 0.3s all
}

.scale-img {
  overflow: hidden;
  display: block
}

.scale-img img {
  -webkit-transform: scale(1, 1);
  transform: scale(1, 1)
}

.scale-img:hover>img {
  -webkit-transform: scale(1.1, 1.1);
  transform: scale(1.1, 1.1)
}

.blink {
  -webkit-animation-name: blink;
  -webkit-animation-duration: 1s;
  -webkit-animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  -moz-animation-name: blink;
  -moz-animation-duration: 1s;
  -moz-animation-timing-function: linear;
  -moz-animation-iteration-count: infinite;
  animation-name: blink;
  animation-duration: 1s;
  animation-timing-function: linear;
  animation-iteration-count: infinite
}

.btn-frame {
  display: block;
  width: 50px;
  height: 50px;
  position: fixed;
  right: 20px;
  z-index: 997;
  cursor: pointer
}

.btn-frame i {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #030302;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.btn-frame i img {
  vertical-align: middle;
  width: 70%
}

.btn-frame .animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite
}

.btn-frame .kenit-alo-circle {
  width: 60px;
  height: 60px;
  top: -5px;
  right: -5px;
  position: absolute;
  background-color: transparent;
  border-radius: 100%;
  border: 2px solid rgba(7, 41, 103, 0.8);
  opacity: 0.1;
  border-color: var(--maincolor);
  opacity: 0.5
}

.btn-frame .zoomIn {
  -webkit-animation-name: zoomIn;
  animation-name: zoomIn
}

.btn-frame .animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both
}

.btn-frame .kenit-alo-circle-fill {
  width: 70px;
  height: 70px;
  top: -10px;
  right: -10px;
  position: absolute;
  border-radius: 100%;
  border: 2px solid transparent;
  background-color: rgba(7, 41, 103, 0.35);
  opacity: 0.4
}

.btn-frame .pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse
}

.btn-zalo {
  bottom: 315px
}

.btn-phone {
  bottom: 230px
}

.js-facebook-messenger-container.closed {
  display: none !important
}

.js-facebook-messenger-tooltip {
  bottom: 97px;
  right: 97px;
  color: #404040;
  background: #fff
}

.js-facebook-messenger-tooltip.closed {
  display: none !important
}

.js-facebook-messenger-box,
.js-facebook-messenger-button {
  z-index: 999
}

.js-facebook-messenger-tooltip {
  z-index: 999;
  display: none;
  position: fixed;
  text-align: center;
  border-radius: 10px;
  overflow: hidden;
  font-size: 12px;
  line-height: 1;
  padding: 10px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  -webkit-box-shadow: rgba(0, 0, 0, 0.15) 0 2pt 10pt;
  box-shadow: rgba(0, 0, 0, 0.15) 0 2pt 10pt;
  z-index: 1000000000000000019884624838656
}

.js-facebook-messenger-close-tooltip {
  width: 10px;
  height: 10px;
  display: inline-block;
  cursor: pointer;
  margin-left: 10px
}

.js-facebook-messenger-box {
  z-index: 999
}

.js-facebook-messenger-box.rubberBand {
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand
}

.js-facebook-messenger-box.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both
}

.js-facebook-messenger-button,
.js-facebook-messenger-tooltip {
  z-index: 999
}

.js-facebook-messenger-box {
  display: block;
  position: fixed;
  cursor: pointer;
  bottom: 150px;
  right: 17px;
  width: 56px;
  height: 56px;
  text-align: center;
  background: #050504;
  border-radius: 100%;
  overflow: hidden;
  z-index: 99;
  -webkit-box-shadow: 1px 1px 4px 0 rgba(0, 0, 0, 0.3);
  box-shadow: 1px 1px 4px 0 rgba(0, 0, 0, 0.3)
}

.js-facebook-messenger-box.rotate svg#fb-msng-icon {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg)
}

.js-facebook-messenger-box svg#fb-msng-icon {
  width: 32px;
  height: 33px;
  position: absolute;
  top: 13px;
  left: 12px;
  opacity: 1;
  overflow: hidden;
  -webkit-transition: opacity 160ms ease-in-out, transform 160ms ease-in-out;
  -webkit-transition: opacity 160ms ease-in-out, -webkit-transform 160ms ease-in-out;
  transition: opacity 160ms ease-in-out, -webkit-transform 160ms ease-in-out;
  transition: opacity 160ms ease-in-out, transform 160ms ease-in-out;
  transition: opacity 160ms ease-in-out, transform 160ms ease-in-out, -webkit-transform 160ms ease-in-out
}

.js-facebook-messenger-box.rotate svg#close-icon {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}

.js-facebook-messenger-box svg#close-icon {
  opacity: 0;
  width: 19px;
  height: 20px;
  position: absolute;
  top: 19px;
  left: 19px;
  -webkit-transition: opacity 160ms ease-in-out, transform 160ms ease-in-out;
  -webkit-transition: opacity 160ms ease-in-out, -webkit-transform 160ms ease-in-out;
  transition: opacity 160ms ease-in-out, -webkit-transform 160ms ease-in-out;
  transition: opacity 160ms ease-in-out, transform 160ms ease-in-out;
  transition: opacity 160ms ease-in-out, transform 160ms ease-in-out, -webkit-transform 160ms ease-in-out
}

.js-facebook-messenger-container,
.js-facebook-messenger-container-button {
  z-index: 1000
}

.js-facebook-messenger-container {
  position: fixed;
  opacity: 0;
  -webkit-transform: translateY(50px);
  transform: translateY(50px);
  bottom: 110px;
  right: 90px;
  border-radius: 10px;
  pointer-events: none;
  -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.06), 0 2px 32px rgba(0, 0, 0, 0.16);
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.06), 0 2px 32px rgba(0, 0, 0, 0.16);
  -webkit-transition: transform 160ms ease-in-out, opacity 160ms ease-in-out;
  -webkit-transition: opacity 160ms ease-in-out, -webkit-transform 160ms ease-in-out;
  transition: opacity 160ms ease-in-out, -webkit-transform 160ms ease-in-out;
  transition: transform 160ms ease-in-out, opacity 160ms ease-in-out;
  transition: transform 160ms ease-in-out, opacity 160ms ease-in-out, -webkit-transform 160ms ease-in-out
}

.js-facebook-messenger-top-header {
  width: 220px;
  color: #ffffff;
  display: block;
  position: relative;
  width: 220px;
  background: var(--maincolor);
  color: #ffffff;
  text-align: center;
  line-height: 1;
  padding: 10px;
  font-size: 14px;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px
}

.js-facebook-messenger-container iframe,
.js-facebook-messenger-container-button iframe {
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px
}

.js-facebook-messenger-box,
.js-facebook-messenger-button,
.js-facebook-messenger-tooltip {
  z-index: 999
}

.js-facebook-messenger-container,
.js-facebook-messenger-container-button {
  z-index: 1000
}

.js-facebook-messenger-top-header {
  color: #ffffff;
  background: var(--maincolor);
  width: 220px
}

.js-facebook-messenger-tooltip {
  color: #404040;
  background: #fff
}

.js-facebook-messenger-container.open {
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
  opacity: 1;
  pointer-events: all
}

.js-facebook-messenger-tooltip {
  bottom: 97px;
  right: 97px
}

.js-facebook-messenger-box.open svg#fb-msng-icon {
  opacity: 0
}

.js-facebook-messenger-box.rotate.open svg#close-icon {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg)
}

.js-facebook-messenger-box.open svg#close-icon {
  opacity: 1
}

.cart-fixed {
  position: fixed;
  right: 20px;
  bottom: 390px;
  z-index: 997;
  background: #4b4f56;
  width: 50px;
  height: 50px;
  text-align: center;
  color: #fff !important;
  border-radius: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.cart-fixed i {
  font-size: 20px
}

.cart-fixed span {
  position: absolute;
  top: 0px;
  right: -5px;
  color: #ffffff;
  width: 25px;
  height: 25px;
  background: var(--maincolor);
  text-align: center;
  line-height: 25px;
  font-size: 11px;
  border-radius: 100%
}

.toolbar {
  background: #fff6e4;
  width: 100%;
  padding: 2px;
  bottom: 0px;
  position: fixed;
  z-index: 500;
  height: auto;
  left: 0px
}

.toolbar ul {
  list-style: none;
  padding: 0px;
  margin: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.toolbar ul li:nth-child(1) {
  background-color: #0d0c0a;
}

.toolbar ul li:nth-child(2) {
  background-color: #820505;
}

.toolbar ul li {
  text-align: center;
  width: 50%;
  padding: 10px 5px;
}

.toolbar ul li a img {
  animation: flash 2s infinite;
}

.toolbar ul li a {
  display: block;
  width: 100%;
  cursor: pointer;
  color: #fff;
  font-size: 16px;
}

.toolbar ul li a img {
  height: 6vw;
  width: auto
}

.toolbar ul li a span {
  font-weight: 400;
  color: #ffffff;
  font-size: 3.5vw;
  display: none
}

.fixbar {
  bottom: 0;
  display: block;
  background: #f0eff4;
  border-top: 1px solid #ddd;
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: fixed;
  margin: 0;
  z-index: 500;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  height: 50px
}

.fixbar ul {
  margin: 0px;
  padding: 0px;
  list-style: none
}

.fixbar ul li {
  margin: 0 auto 10px;
  text-align: center;
  width: 25%;
  float: left
}

.fixbar .icon-cart-mobile,
.fixbar .icon-cart-new,
.fixbar .icon-home-new,
.fixbar .icon-hotdeal-new {
  width: 20px;
  height: 20px;
  display: block;
  margin: 8px auto 0
}

.fixbar .icon-cart-mobile {
  background: url(../images/cart-mobile.png) no-repeat
}

.cart-total-header-mobile {
  font-size: 10px;
  position: absolute;
  background: red;
  color: #fff !important;
  border-radius: 50%;
  height: 15px;
  width: 15px;
  line-height: 15px;
  top: 5px;
  margin-left: 5px
}

.fixbar ul li a {
  font-size: 11px;
  text-decoration: none;
  color: #333
}

.fixbar ul li a i {
  font-size: 20px
}

.plugbar {
  position: fixed;
  bottom: 0;
  left: 0;
  border-top: 1px solid #eae6e6;
  width: 100%;
  right: 0;
  max-width: 767px;
  margin: 0 auto;
  background: #ffffff;
  padding: 9px 10px 10px 7px;
  z-index: 10
}

.plugbar ul {
  list-style: none;
  padding: 0;
  margin: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.plugbar ul li {
  width: 20%;
  float: left
}

.plugbar ul li a {
  display: block;
  color: #696969;
  font-size: 12px;
  text-align: center;
  position: relative
}

.plugbar ul li a i {
  font-size: 20px;
  color: #696969
}

.plugbar ul li a span {
  position: absolute;
  width: 50px;
  height: 50px;
  top: -40px;
  left: calc(50% - 50px / 2);
  font-size: 14px;
  display: block;
  border: 1px solid rgba(234, 230, 230, 0.5);
  border-radius: 100%
}

.support-online {
  position: fixed;
  z-index: 999;
  left: 10px;
  bottom: 0px
}

.support-online a {
  position: relative;
  margin: 20px 10px;
  text-align: left;
  width: 40px;
  height: 40px
}

.support-online i {
  width: 40px;
  height: 40px;
  background: #43a1f3;
  color: #ffffff;
  border-radius: 100%;
  font-size: 20px;
  text-align: center;
  line-height: 1.9;
  position: relative;
  z-index: 999
}

.support-online a {
  display: block
}

.support-online a span {
  border-radius: 2px;
  text-align: center;
  background: #67b634;
  padding: 9px;
  display: none;
  width: 180px;
  margin-left: 10px;
  position: absolute;
  color: #ffffff;
  z-index: 999;
  top: 0px;
  left: 40px;
  -webkit-transition: all 0.2s ease-in-out 0s;
  transition: all 0.2s ease-in-out 0s;
  -webkit-animation: headerAnimation 0.7s 1;
  animation: headerAnimation 0.7s 1
}

.support-online a:hover span {
  display: block
}

.support-online a span:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 10px 10px 0;
  border-color: transparent #67b634 transparent transparent;
  position: absolute;
  left: -10px;
  top: 10px
}

.support-online .kenit-alo-circle-fill {
  width: 60px;
  height: 60px;
  top: -10px;
  position: absolute;
  border-radius: 100%;
  border: 2px solid transparent;
  background-color: rgba(0, 175, 242, 0.5);
  opacity: 0.75;
  right: -10px
}

.support-online .kenit-alo-circle {
  width: 50px;
  height: 50px;
  top: -5px;
  right: -5px;
  position: absolute;
  background-color: transparent;
  border-radius: 100%;
  border: 2px solid rgba(30, 30, 30, 0.4);
  opacity: 0.1;
  border-color: #0089b9;
  opacity: 0.5
}

.support-online .support-online .btn-support {
  cursor: pointer
}

.support-online .mes i {
  background: orange
}

.support-online .sms i {
  background: red
}

.support-online .call-now i {
  background: green
}

.widget-mobile {
  position: fixed;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  bottom: 10px;
  z-index: 9999999
}

#my-phone-circle {
  position: relative;
  width: 50px !important;
  height: 50px !important
}

.wcircle-open .wcircle-icon i:before {
  content: "\f00d"
}

.wcircle-icon {
  background: #1282fc;
  border-radius: 50%;
  position: relative !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.wcircle-icon:before {
  position: absolute;
  content: "";
  width: 60px;
  height: 60px;
  background: rgba(18, 130, 252, 0.5);
  border: 1px solid #ffffff;
  border-radius: 50%;
  left: -5px;
  top: -5px;
  -webkit-animation: pulse 1s infinite ease-in-out;
  animation: pulse 1s infinite ease-in-out
}

.wcircle-icon:after {
  position: absolute;
  content: "";
  width: 80px;
  height: 80px;
  background: rgba(18, 130, 252, 0.5);
  border-radius: 50%;
  left: -15px;
  top: -15px;
  -webkit-animation: zoomIn 2s infinite ease-in-out;
  animation: zoomIn 2s infinite ease-in-out
}

.wcircle-menu {
  position: absolute !important;
  left: 0;
  top: 0;
  display: none
}

.wcircle-menu-item {
  width: 50px;
  height: 50px;
  background: #1282fc;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.wcircle-menu-item img {
  width: 50px;
  height: 50px;
  display: block;
  border-radius: 50%
}

.wcircle-menu-item i {
  font-size: 25px;
  color: #ffffff;
  position: relative;
  z-index: 9999
}

.wcircle-icon i {
  font-size: 25px;
  color: #ffffff;
  position: relative;
  z-index: 9999
}

.shake-anim {
  -webkit-animation: shake-anim 1s infinite ease-in-out;
  animation: shake-anim 1s infinite ease-in-out;
  -webkit-transform-origin: 50% 50%;
  transform-origin: 50% 50%
}

.page-link.active,
.page-link.bg-primary {
  background: var(--maincolor) !important
}

.page-link.active:hover,
.page-link.bg-primary:hover {
  background: var(--maincolor) !important
}

.page-link {
  cursor: pointer
}

.boxProduct {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-bottom: 35px;
}

.boxProduct>.product {
  margin: 0 !important;
  width: 100%;
  min-width: 100%
}

.keyword-autocomplete {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  background: #fff;
  border: 1px solid var(--maincolor);
  font-size: 13px;
  max-height: calc(80px * 4);
  overflow-x: hidden;
  overflow-y: auto
}

.autocomplete_item {
  display: block
}

.autocomplete_item a {
  padding: 0.2rem !important;
  display: flex !important;
  align-items: center;
  gap: 0.5rem
}

.autocomplete_item a picture {
  min-width: 30%;
  max-width: 30%
}

.autocomplete_item a section {
  flex-grow: 1;
  position: relative
}

.autocomplete_item a h3 {
  font-size: 12px;
  color: #222;
  margin: 0
}

.autocomplete_item a p {
  float: none;
  width: 100%;
  text-align: left;
  line-height: unset;
  height: unset
}

.autocomplete_item a p span {
  font-size: 12px
}

.autocomplete_item a p span.price-per {
  top: 0;
  right: 0;
  z-index: 2;
  width: auto;
  height: auto;
  padding: 2.5px 5px;
  font-size: 10px;
  line-height: unset
}

.filter_block {
  display: block;
  border: 1px solid #ebebeb;
  border-radius: 5px;
  padding: 1rem;
  margin-bottom: 1rem
}

.filter_title {
  font-weight: bold;
  font-size: 14px;
  display: flex;
  align-items: center
}

.filter_block ul {
  list-style: none;
  display: block
}

.filter_block ul li {
  margin: 0.5rem 0 0;
  display: block
}

.filter_block ul li a {
  color: #777;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer
}

.filter_block ul li a span {
  border: 1px solid #ddd;
  border-radius: 3px;
  width: 1rem;
  height: 1rem;
  display: block;
  position: relative
}

.filter_block ul li a.checked span:after {
  content: '\2713';
  filter: brightness(0);
  font-size: 15px;
  position: absolute;
  top: -7px;
  right: -1px;
  z-index: 2
}

.filter_block ul li a i {
  width: 1rem;
  height: 1rem;
  border-radius: 3px
}

.cart-pro-detail .btn-success {
  background: var(--maincolor) !important;
  border-color: var(--maincolor) !important
}

.btn-load-more-comment-parent {
  background: var(--maincolor) !important;
  border-color: var(--maincolor) !important
}

.filter_title:after {
  content: '\f0d7';
  font-family: 'FontAwesome';
  margin-left: auto
}

.line-clamp-1 {
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical
}

.line-clamp-2 {
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 2;
  display: -webkit-box;
  -webkit-box-orient: vertical
}

.line-clamp-3 {
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
  display: -webkit-box;
  -webkit-box-orient: vertical
}

.line-clamp-4 {
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 4;
  display: -webkit-box;
  -webkit-box-orient: vertical
}

.line-clamp-5 {
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 5;
  display: -webkit-box;
  -webkit-box-orient: vertical
}

.line-clamp-6 {
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 6;
  display: -webkit-box;
  -webkit-box-orient: vertical
}

.line-clamp-7 {
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 7;
  display: -webkit-box;
  -webkit-box-orient: vertical
}

.line-clamp-8 {
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 8;
  display: -webkit-box;
  -webkit-box-orient: vertical
}

.contact-form .btn-primary {
  background: #ee1d24 !important;
  border-color: #ffffff !important;
}

.save-listing,
.save-listing-already {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  font-size: 1rem;
  background: var(--maincolor);
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff !important;
  /* display: none; */
}

.save-listing:hover i:before,
.save-listing-already i:before {
  font-weight: bold
}

.liked-fixed {
  bottom: 455px;
  display: none;
}

div.box-sanpham-tc {
  padding: 30px 0;
}

div.css_flex_baiviet {
  display: flex;
  flex-wrap: wrap;
  margin: 10px 0;
}

div.css_flex_video {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px;
}

div.css_flex_album {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px;
}

div.css_flex_product {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px;
  padding: 0;
}

div.css_flex_ajax .pro-in {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px;
  padding: 0;
}

div.css_baiviet_ngang .news {
  width: calc(25% - 20px);
}

div.css_baiviet_ngang .pic-news {
  width: 100%;
  margin-right: 0;
  margin-bottom: 10px;
}

div.css_baiviet_ngang .info-news {
  width: 100%
}

div.wap-tin-video {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.left-intro {
  width: 56%;
}

.right-intro {
  width: 42%;
}

div.wap_footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

/* bai viet */
.news {
  width: calc(50% - 20px);
  margin: 0 10px;
  margin-bottom: 25px;
  display: block;
}

.pic-news {
  float: left;
  margin-right: 4%;
  width: 36%;
  margin-bottom: 0;
}

.pic-news img {
  width: 100%;
}

.info-news {
  float: left;
  width: 60%;
}

.name-news {
  color: #fff;
  font-size: 16px;
  display: block;
  line-height: normal;
  margin-bottom: 5px;
}

.name-news:hover {
  color: #f00;
}

.time-news {
  color: #666;
  margin-bottom: 0.25rem;
}

.desc-news {
  color: #fff;
  margin-top: 5px;
  line-height: 22px;
}

.view-news {
  color: #c00;
  display: block;
  margin-top: 5px;
}

/* bai viet */
/* Video */
.video {
  width: calc(25% - 20px);
  text-align: center;
  cursor: pointer;
  margin: 10px 10px;
}

.pic-video {
  position: relative;
}

.pic-video:before {
  content: "";
  position: absolute;
  width: 50px;
  height: 35px;
  top: calc(50% - 50px/2);
  left: calc(50% - 35px/2);
  z-index: 1;
  background-repeat: no-repeat;
  background-image: url(../images/play.png);
}

.pic-video img {
  width: 100%;
}

.name-video {
  font-size: 16px;
  color: #000;
  margin-bottom: 0px;
}

.load-video-tc .h-r-v {
  width: 48%;
  position: absolute;
  right: 20px;
  bottom: 26px;
}

.load-video-tc .h-l-v iframe {
  height: 540px;
}

.load-video-tc div.item-duoi {
  margin: 0 5px;
  border: 1px solid #fff;
  position: relative;
}

.load-video-tc div.item-duoi:before {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: url(../images/icon-video.png) no-repeat center;
  background-size: 30px;
  cursor: pointer;
}

.load-video-tc div.item-duoi iframe {
  width: 100%;
  height: 100%;
}

.load-video-tc div.item-duoi span {
  display: block;
  text-align: left;
}

.load-video-tc div.item-duoi span.ten {
  font-size: 14px;
}

.load-video-tc div.item-duoi span.ngay {
  font-size: 14px;
}

.load-video-tc div.item-video {
  position: relative
}

.load-video-tc div.item-video a {
  position: relative;
  display: block;
  line-height: 0;
  cursor: pointer;
}

.load-video-tc div.item-video a img {
  object-fit: cover;
  height: 419px;
}

.load-video-tc div.item-video a:before {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: url(../images/icon-video.png) no-repeat center;
}

.load-video-tc {
  position: relative;
}

/* Video */
div.wap_copy {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

div.wap_copy .copyright,
div.wap_copy .statistic {
  margin-bottom: 0;
}

.statistic span {
  margin-left: 8px;
}

div#main_footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

div#main_footer ul li {
  margin: 9px 0;
  font-size: 14px;
}

div#main_footer ul li i {
  width: 30px;
  height: 30px;
  border: 1px solid #f9f9f9;
  text-align: center;
  border-radius: 3px;
  line-height: 30px;
  margin-right: 8px;
  font-size: 18px;
  color: #525252;
}

.footer-news:nth-child(1) {
  width: 25%;
}

.footer-news:nth-child(2) {
  width: 25%;
}

.footer-news:nth-child(3) {
  width: 15%;
}

.footer-news:nth-child(4) {
  width: 25%;
}

.footer-title {
  color: #ed1c24;
  font-weight: 700;
  font-size: 18px;
}

.footer-ul {
  list-style: none;
  padding: 0px;
  margin: 0px;
}

.footer-ul li {
  margin-bottom: 10px;
}

.footer-ul li:last-child {
  margin-bottom: 0px;
}

.footer-ul li a {
  color: #000000;
}

.footer-ul li a:hover {
  text-decoration: none;
  color: var(--maincolor);
}

.social-header li {
  width: 30px;
}

.social {
  margin-bottom: 0;
  padding: 0;
}

.social ul {
  padding: 0;
  list-style: none
}

.social li {
  display: inline-block;
}

.social li:hover {
  transform: rotateY(360deg);
  transition: all 0.5s linear;
}

.list_monnb {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.list_monnb a {
  font-size: 14px;
  color: #999999;
  cursor: pointer;
  padding: 8px 20px;
}

.list_monnb a:hover,
.list_monnb a.active {
  color: #fff !important;
  background-color: #810505 !important;
}

/*tin tuc trang chu*/
.title-intro {
  border-bottom: 1px solid #cc0000;
  margin-bottom: 1.5rem;
}

.title-intro span {
  display: inline-block;
  text-transform: uppercase;
  position: relative;
  padding-bottom: 10px;
  font-size: 20px;
  color: #cc0000;
}

.title-intro span:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 4px;
  bottom: 0px;
  left: 0px;
  /* background-color:#f00; */
}

div.box-tintuc-video {
  padding: 50px 0;
}

.newshome-best {
  width: 43%;
  display: block;
  float: left;
  margin-right: 1.5%;
}

.newshome-best .pic-newshome-best img {
  width: 100%;
}

.name-newshome {
  color: #fff;
  font-size: 14px;
  line-height: 18px;
  margin-bottom: 0.25rem;
}

.name-newshome:hover {
  color: #f00;
}

.name-newshome.text-split {
  -webkit-line-clamp: 2;
}

.time-newshome {
  color: #666;
  margin-bottom: 0.25rem;
  display: none;
}

.desc-newshome {
  color: #fff;
  margin-bottom: 0px;
  -webkit-line-clamp: 2;
}

.view-newshome {
  display: inline-block;
  border: 1px solid #000;
  padding: 8px 15px;
  color: #000;
  text-transform: capitalize;
  margin-top: 1rem;
}

.view-newshome:hover {
  background-color: #000;
  color: #fff;
}

.newshome-scroll {
  width: calc(100% - 44.5%);
  overflow: hidden;
}

.newshome-scroll ul li {
  margin-bottom: 15px !important;
}

.newshome-normal {
  display: block;
  margin-bottom: 10px;
}

.pic-newshome-normal {
  float: left;
  width: 34%;
  margin-right: 3%;
  margin-bottom: 0px;
}

.pic-newshome-normal img {
  width: 100%;
}

.info-newshome-normal {
  float: left;
  width: calc(100% - 37%);
}

#video-select iframe {
  height: 281px;
}

#video-select .listvideos {
  width: 100%;
  height: 40px;
  padding: 0 10px;
}

/*tin tuc trang chu*/
.proprice_item_color span {
  width: 50px;
  height: 25px;
  border-radius: 6px;
}

.prod_details_color {
  display: flex;
  justify-content: start;
  flex-flow: wrap;
  margin: 0 -5px;
  margin-bottom: 10px;
}

.prod_details_color .align-items-center {
  margin: 0 5px;
}

.proprice_item_color.active>span {
  border: 1px solid #000;
  border-radius: 6px;
  transition: 0.5s;
}

.proprice_item_size a {
  display: flex;
  width: 50px;
  height: 25px;
  align-items: center;
  justify-content: center;
  background: #ddd;
  border-radius: 6px;
}

.proprice_group {
  display: flex;
  align-items: center;
  justify-content: start;
  margin: 0 -5px;
  margin-bottom: 10px;
}

.proprice_item_size {
  margin: 0 5px;
}

.proprice_item_size.active>a {
  border: 1px solid #000;
  border-radius: 6px;
}

.proprice_item_label {
  margin-bottom: 5px !important;
}

div.run-slick .slick-prev:before,
div.run-slick .slick-next:before {
  font-size: 0;
}

div.run-slick .slick-prev,
div.run-slick .slick-next {
  width: 32px;
  height: 45px;
  top: 46%;
}

div.run-slick .slick-prev {
  background: url(../images/sl-1.png) no-repeat center;
  left: 20px;
}

div.run-slick .slick-next {
  background: url(../images/sl-2.png) no-repeat center;
  right: 20px;
}

div.box-hethong {
  padding: 0 0;
  position: relative;
}

div.box-hethong .ht-left {
  width: calc(100% - 10px);
  position: absolute;
  top: 19px;
  right: 10px;
  z-index: 4;
  text-align: right;
}

div.box-hethong .ht-right {
  width: 100%;
}

div.box-hethong .ht-left .item-ht {
  margin-bottom: 8px;
  font-size: 14px;
  cursor: pointer;
  background: rgb(0 0 0 / 70%);
  padding: 10px 20px;
  color: #fff;
  display: inline-block;
}

div.box-hethong .ht-left .item-ht .ten {
  display: block;
}

div.box-hethong .ht-left .act-item {
  background: rgb(235 32 9);
}

div.box-hethong .ht-right iframe {
  width: 100%;
}

div.box-hethong .ht-left .item-ht p {
  margin-bottom: 2px;
}

div.box-hethong .ht-left .item-ht p span {
  color: #fffc00;
}

div.box-lienhe {
  padding: 50px 0;
  background-size: cover;
  background: #478b7b;
}

div.box-lienhe .td-tc1,
div.box-lienhe .td-tc2 {
  color: #fff;
  text-align: center;
}

div.box-lienhe .td-tc1 {
  text-transform: uppercase;
  font-size: 27px;
}

div.css_lienhe .baogia-form {
  max-width: 750px;
  width: 100%;
  margin: auto;
  text-align: center;
  margin-top: 16px;
}

div.css_lienhe .baogia-input input {
  background: none;
  border: 0;
  border-bottom: 1px solid #000;
  border-radius: 0;
  color: #000;
}

div.css_lienhe .baogia-input textarea.form-control {
  background: none;
  border: 0;
  border-bottom: 1px solid #000;
  border-radius: 0;
  color: #000;
  height: 46px;
}

div.css_lienhe .btn-primary {
  margin-top: 14px;
  background: #000;
  border-color: #000;
  text-transform: uppercase;
}

div.css_lienhe ::-webkit-input-placeholder {
  color: #000;
}

div.css_lienhe :-moz-placeholder {
  color: #000;
}

div.css_lienhe ::-moz-placeholder {
  color: #000;
}

div.css_lienhe :-ms-input-placeholder {
  color: #000;
}

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

.left_info {
  width: 270px;
}

.right_info {
  width: calc(100% - 280px);
}

.list_mananger {
  padding: 0;
  margin: 0;
  list-style: none;
  border: 1px solid #c00;
  border-top: none;
  border-bottom-left-radius: 7px;
  border-bottom-right-radius: 7px;
}

.sty_list1,
.sty_list {
  padding: 10px 0;
  margin-left: 10px;
  color: #000;
  cursor: pointer;
}

.list_mananger li {
  border-bottom: 1px solid #d3d3d3;
}

.left_info .title-user {
  background: #c00;
}

.left_info .title-user span {
  color: #fff;
}

.dong {
  position: relative;
  left: 0;
  top: 0;
  opacity: 0;
  width: 100%;
  display: none;
}

.mo {
  position: relative;
  left: 0;
  top: 0;
  opacity: 1;
  width: 100%;
  display: block;
}

.sty_btn_info span,
.button-user .sty_btn_info {
  padding: 5px 15px;
  border: 1px solid #c00;
  background: #c00;
  color: #fff;
  border-radius: 5px;
}

div#danhmuc {
  border-bottom: none;
}

div#danhmuc ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

div#danhmuc ul li {
  position: relative;
}

div#danhmuc ul li:last-child {
  border: none;
}

div#danhmuc ul li a {
  color: #454545;
  text-decoration: none;
  font-size: 16px;
  transition: 0.4s;
  display: block;
  border-bottom: 1px solid #DDD;
  padding: 6px 5px 6px 0px;
}

div#danhmuc ul li a h2 {
  font-size: 15px;
}

div#danhmuc ul li span {
  position: absolute;
  right: 6px;
  top: 0;
  display: block;
  width: 14px;
  height: 100%;
  background: url(../images/muiten-menu.png) no-repeat center;
  cursor: pointer;
  max-height: 44px;
  transition: 0.3s;
}

div#danhmuc ul li span.active {
  background: url(../images/muiten-menu-act.png) no-repeat center;
}

div#danhmuc ul li a:hover,
div#danhmuc ul li a.active {
  color: red;
  transition: 0.4s;
  text-decoration: underline;
}

div#danhmuc ul li ul li a {
  padding: 9px 5px 9px 26px;
  font-family: inherit;
}

div#danhmuc ul li ul li span {
  background: url(../images/muiten-menu.png) no-repeat;
}

div#danhmuc ul li ul li ul li span {}

div#danhmuc ul li ul {
  display: none;
}

div#danhmuc ul li ul.show-ul-c2 {
  display: block
}

div#danhmuc ul li ul li ul li {}

div#danhmuc ul li ul li ul li a {
  padding-left: 26px;
  color: #0193de;
}

div#danhmuc ul li ul li ul li ul li {}

div#danhmuc ul li ul li ul li ul li a {
  padding-left: 40px;
  color: #000;
}

div#danhmuc ul li ul li ul li ul li ul li {}

div#danhmuc ul li ul li ul li ul li ul li a {
  color: #0193de;
}

/* Toc */
.box-readmore {
  padding: 8px 15px;
  border: 1px solid #dedede;
  margin-bottom: 2rem;
  border-radius: 5px;
  background-color: #eeeeee;
}

.box-readmore li ul>li {
  margin: 0;
  margin-bottom: 8px
}

.box-readmore li ul>li:before {
  content: counters(item, ".") " "
}

.box-readmore ul {
  list-style-type: none;
  counter-reset: item;
  margin-bottom: 0px;
  padding-left: 0px !important;
  margin-top: 8px;
}

.box-readmore ul li {
  display: table;
  counter-increment: item;
  margin-bottom: 5px
}

.box-readmore ul li:before {
  content: counters(item, ".") ". ";
  display: table-cell;
  padding-right: 5px
}

.box-readmore ul li a {
  color: #333333;
  cursor: pointer;
  font-weight: 600;
}

.box-readmore ul li a:hover {
  color: #767676;
}



.search-res {
  position: relative;
  float: right;
  width: 40px;
}

.search-res .icon-search {
  width: 40px;
  height: 40px;
  cursor: pointer;
  text-align: center;
  line-height: 42px;
  color: #fff;
  font-size: 17px;
  margin: 0px;
  margin-top: 0px;
}

.search-res .icon-search.active {
  background: #fff;
  border-radius: 100%;
  color: #810505;
}

.search-res .search-grid {
  position: absolute;
  top: 55px;
  right: 0px;
  width: 0px;
  height: 40px;
  overflow: hidden;
  background: #fff;
  border: 1px solid #810505;
  z-index: 2;
  opacity: 0;
  border-radius: 25px;
  line-height: normal;
}

.search-res .search-grid p {
  float: left;
  width: 35px;
  height: 38px;
  cursor: pointer;
  outline: none;
  border: none;
  margin: 0px;
  font-size: 17px;
  display: block;
  color: #810505;
  line-height: 40px;
  text-align: center;
}

.search-res .search-grid input {
  width: calc(100% - 35px);
  float: right;
  line-height: 38px;
  outline: none;
  border: none;
  color: #666363;
  font-size: 13px;
}

.search-res .search-grid input::-webkit-input-placeholder {
  color: #ccc;
}

.search-res .search-grid input:-moz-placeholder {
  color: #ccc;
}

.search-res .search-grid input::-moz-placeholder {
  color: #ccc;
}

.search-res .search-grid input:-ms-input-placeholder {
  color: #ccc;
}

.catchuoi1 {
  -webkit-line-clamp: 1;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.catchuoi2 {
  -webkit-line-clamp: 2;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.catchuoi3 {
  -webkit-line-clamp: 3;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.catchuoi4 {
  -webkit-line-clamp: 4;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.catchuoi5 {
  -webkit-line-clamp: 5;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.catchuoi6 {
  -webkit-line-clamp: 6;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.catchuoi7 {
  -webkit-line-clamp: 7;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.catchuoi8 {
  -webkit-line-clamp: 8;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.header.header-fix {
  height: auto;
  padding: 10px;
  background-color: rgb(50 49 49);
  position: fixed;
  animation: slideInDown 0.5s;
}

.header.header-fix .menu ul.menu-main {
  margin-bottom: 10px;
}

.header.header-fix .logo_header {
  max-width: 70px;
}

.wap_duan {
  padding: 60px 10px;
}

.header {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 999;
  padding: 20px 0px;
  height: 300px;
  background-image: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, #000000 100%);
}

.search-res img {
  vertical-align: inherit;
}

.icon-search i.fa-sharp img {
  display: none;
}

.text-slide {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #ffffff;
  z-index: 2;
  padding: 20px 30px;
}

.text-slide::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 225px;
  height: 90px;
  border-top: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
}

.text-slide::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 225px;
  height: 90px;
  border-bottom: 1px solid #ffffff;
  border-left: 1px solid #ffffff;
}

.text-slide span {
  font-size: 23px;
  letter-spacing: 8px;
}

.text-slide p {
  font-family: "S FU Futura Bold";
  font-size: 57px;
  text-transform: uppercase;
  line-height: 1;
  letter-spacing: -1px;
  text-shadow: 0px 3px 5px rgba(0, 0, 0, 0.5);
}

.img_gioithieu {
  width: 49%;
}

.info_gioithieu {
  width: 48.333%;
}

.wap_gioithieu {
  padding: 55px 10px;
  background: #333333 url(../images/bg-gioithieu.jpg) no-repeat center;
}

.title-gioithieu {
  text-align: center;
  background: url(../images/dot.png) no-repeat bottom center;
  margin-bottom: 0.5rem;
}

.title-gioithieu img {
  margin: 0 auto 0.5rem;
}

.title-gioithieu span {
  color: #888888;
  text-transform: uppercase;
  font-weight: 600;
  font-size: 45px;
}

.info_gioithieu p {
  font-size: 14px;
  text-align: center;
  line-height: 30px;
  color: #999999;
}

.xemthem {
  text-transform: uppercase;
  margin: auto;
  color: #fdfdfd;
  font-size: 15px;
  width: 144px;
  height: 42px;
  line-height: 42px;
  display: block;
  text-align: center;
  position: relative;
}

.xemthem::after {
  content: "";
  width: calc(100% + 7px);
  height: calc(100% + 7px);
  position: absolute;
  border-top: 1px solid #f8fdff;
  border-right: 1px solid #d2d1d0;
  right: 0;
  top: 0;
  transition: all 0.5s;
}

.xemthem::before {
  content: "";
  width: calc(100% + 7px);
  height: calc(100% + 7px);
  position: absolute;
  border-bottom: 1px solid #f9f9f9;
  border-left: 1px solid #ffffff;
  left: 0;
  bottom: 0;
  transition: all 0.5s;
}

/* .info_gioithieu a:hover::after,.info_gioithieu a:hover::before{width: calc(100% + 7px);height: calc(100% + 7px);transition: all 0.5s;} */
.xemthem:hover {
  background-color: #ffffff;
}

.wap_thietke {
  padding: 10px 10px 60px;
  background: #333333 url(../images/bg_all.png) no-repeat left top
}

.wap_sanpham {
  padding: 50px 10px;
  position: relative;
}

.wap_sanpham .wap_1200 {
  z-index: 2;
}

.info_thietke {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background-image: linear-gradient(0deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
  text-align: center;
  padding: 10px 15px;
}

.info_thietke h3 {
  font-size: 20px;
  color: #fff;
  text-transform: uppercase;
  text-align: center;
  font-weight: 600;
}

.info_thietke h3:hover {
  color: var(--maincolor);
}

.thietke_content {
  padding: 2px 5px;
}

.scale_a {
  overflow: hidden;
}

.scale_a img {
  transition: all 5s linear;
}

.scale_a:hover img {
  transform: scale(1.5);
  transition: all 5s linear
}

.list_monnb {}

.slick_banner {
  max-width: 1000px;
  margin: auto;
  margin-bottom: 20px;
}

.bg1 {
  overflow: hidden;
  position: relative;
  background-color: #2B2B2B;
}

.bg3 {
  overflow: hidden;
  position: relative;
}

.bg1 .wap_sanpham::after,
.bg3::after {
  content: "";
  height: 1369px;
  width: 684px;
  position: absolute;
  right: 0;
  top: 0;
  background: url(../images/bg_all.png) no-repeat right top;
  transform: scaleX(-1);
}

.bg3::after {
  z-index: -1;
}

.grid_duan {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  grid-template-rows: auto 70px auto;
}

.duan_content img {
  height: 100%;
  object-fit: cover;
}

.duan_content:nth-child(1) {
  grid-area: 1 / 3 / 3 / 5;
}

.duan_content:nth-child(2) {
  grid-area: 2 / 1 / 4 / 3;
}

.info_duan {
  width: 100%;
  height: 100%;
  position: absolute;
  background-color: #000000bb;
  top: 0;
  left: -100%;
  transition: all 0.5s;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 10px 25px;
}

.info_duan h3 {
  color: #ffffff;
  text-transform: uppercase;
  font-weight: 700;
  font-size: 16px;
}

.info_duan h3:hover {
  color: var(--maincolor);
}

.info_duan h3::after {
  content: "";
  width: 40px;
  height: 3px;
  background-color: #810505;
  display: block;
  margin: 10px auto;
}

.info_duan p {
  font-size: 14px;
  line-height: 25px;
  color: #ffffff;
}

.duan_content {
  overflow: hidden;
}

.duan_content:hover .info_duan {
  left: 0;
  transition: all 0.5s;
}

.bg2 {
  background: url(../images/bg_all.png) no-repeat left top;
}

.wap_quytrinh {
  padding: 50px 10px;
  background-image: url(../images/bg-quytrinh.jpg);
}

.wap_form {
  padding: 40px 10px;
  background-image: url(../images/bg-form.jpg);
  background-size: cover;
}

.footer-copyright {
  color: #ff0000;
}

.footer-copyright span {
  color: #ed1c24;
}

.bando p {
  color: #ed1c24;
  margin-bottom: 0.25rem;
  font-weight: 600;
  font-size: 16px;
  line-height: 40px;
}

.bando:hover p {
  color: #ffffff;
}

.bando {
  margin-top: -26px;
}

.footer-article hr {
  background-color: rgba(255, 255, 255, 0.16);
}

.title-form {
  width: 370px;
}

.title-form h2 {
  color: #ed1c24;
  font-weight: 600;
  font-size: 30px;
}

.title-form p {
  line-height: 28px;
  color: #fffefe;
  font-weight: 400;
}

.wap_form form {
  width: 780px;
  display: flex;
  gap: 16px;
}

.newsletter-button input[type="submit"] {
  width: 48px;
  height: 110px;
  background: url(../images/btn.png) no-repeat center;
  border: 0px;
}

.form_baogia {
  flex-grow: 1;
}

.form_baogia .form-control {
  background-color: transparent;
  border: 1px solid #7f7f7f;
  border-radius: 0px;
  color: #fff;
  margin-bottom: 16px;
}

.form_baogia .form-control::placeholder {
  color: #ffffff;
}

.form_baogia textarea {
  height: 110px;
}

.form_baogia input {
  height: 47px;
}

.img_parner {
  margin: 0 5px;
  background-color: #404040;
}

.img_parner .d-flex {
  width: 228px;
  height: 140px;
  max-width: 100%;
}

.img_parner img {
  max-width: 190px;
}

.wap_doitac {
  margin-bottom: 60px;
}

.tintuc_1 {
  width: 590px;
}

.tintuc_2 {
  width: 570px;
}

.tintuc1 {
  padding: 20px;
  background-color: #262626;
}

.info_tintuc p {
  font-size: 14px;
  min-height: 75px;
  line-height: 25px;
  color: #999999;
}

.info_tintuc a {
  color: #810505;
}

.info_tintuc a:hover {
  color: #fff;
}

.info_newsnb {
  background-image: linear-gradient(0deg, #000000b0 0%, rgba(0, 0, 0, 0));
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  padding: 20px 30px;
}

.info_newsnb .info span {
  font-size: 13px;
  line-height: 30px;
  color: #ebd8a2;
}

.info_newsnb .info h3:hover {
  color: var(--maincolor);
}

.info_newsnb .info h3 {
  font-size: 18px;
  margin: 0;
  line-height: 25px;
  text-transform: uppercase;
  color: #ffffff;
  font-weight: 600;
}

.info_newsnb .info {
  flex-grow: 1;
}

.info_newsnb .btn-a {
  display: flex;
  align-items: center;
  gap: 15px;
}

.arrow-slick {
  width: 46px;
  height: 46px;
  background-image: url(../images/arrow.png);
  display: block;
}

.arrow-left {
  transform: scaleX(-1);
}

.info_tintuc2 {
  width: calc(100% - 250px);
}

.info_tintuc2 span {
  color: #810505;
}

.info_tintuc2 span:hover {
  color: #fff;
}

.info_tintuc2 p {
  font-size: 13px;
  margin: 0;
  line-height: 22px;
  color: #999999;
}

.info_tintuc2 h3 {
  color: #ffffff;
  font-size: 14px;
  margin: 0.5rem 0;
  font-weight: 600;
  text-transform: uppercase;
}

.info_tintuc2 h3:hover {
  color: var(--maincolor);
}

.tintuc2_content {
  margin-bottom: 20px;
}

.tintuc2 {
  padding: 10px;
  background-color: #262626;
}

.slick_tintuc2 {
  margin-bottom: -20px;
}

.wap_tintuc {
  margin-bottom: 60px;
}

.wap_1366 {
  max-width: 1366px;
  margin: auto;
}

.pics-video {
  position: relative;
  cursor: pointer;
}

.pics-video::after {
  content: "";
  width: 110px;
  height: 110px;
  background-image: url(../images/play.png);
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.wap_videoclip {
  padding: 50px 0 20px;
}


.number_quytrinh {
  font-size: 45px;
  border-radius: 100%;
  color: #ffffff;
  margin-top: -45px;
}


.flex_quytrinh {
  display: flex;
}

.quytrinh_content {
  flex-grow: 1;
  margin-top: 45px;
}

.quytrinh_content h3 {
  font-size: 16px;
  text-align: center;
  padding: 10px 10px 0;
  color: #ffffff;
  font-weight: 600;
}

.quytrinh_content p {
  font-size: 13px;
  padding: 0 25px 0;
  line-height: 22px;
  color: #ffffff;
  text-align: center;
}

.number_quytrinh::after,
.number_quytrinh::before {
  content: "";
  flex-grow: 1;
  height: 1px;
  background-color: #595959;
  display: block;
}

.number_quytrinh {
  display: flex;
  align-items: center;
}

.number_quytrinh span {
  display: block;
  height: 90px;
  width: 90px;
  line-height: 90px;
  text-align: center;
  position: relative;
}

.number_quytrinh .border_quytrinh {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border: 4px solid #820505;
  border-top: 4px solid #595959;
  border-radius: 100%;
  transform: rotate(45deg);
}

.quytrinh_content.active {}

.quytrinh_content {
  position: relative;
}

.quytrinh_content.active .desc_quytrinh {
  opacity: 1;
  transition: all 1s;
  transition-delay: 1s;
}

.quytrinh_content.active h3 {
  color: var(--maincolor);
}

.desc_quytrinh {
  opacity: 0;
}

.quytrinh_content.active::after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  border: 1px solid #595959;
  border-top: 0;
  animation: slideInLeft 1s;
}

.quytrinh_content.active .border_quytrinh {
  transform: rotate(405deg);
  transition: all 3s;
}

.right_baiviet {
  width: calc(100% - 280px);
  padding: 0 10px;
}

.left_baiviet {
  width: calc(280px);
  padding: 0 10px;
}

.baiviet_ot:hover h3 {
  color: var(--maincolor);
}

.info_baivietkhac h3 {
  color: #ff0000;
  font-size: 16px;
  line-height: normal;
}

.info_baivietkhac p {
  line-height: 22px;
  font-size: 12px;
  color: #000000;
}

.title-baiviet {
  text-align: center;
  background-color: #ee1d24;
  padding: 10px 10px;
}

.title-baiviet span {
  font-size: 20px;
  font-weight: bold;
  text-transform: uppercase;
}

.flex-baivietkhac {
  display: flex;
  gap: 10px;
  align-items: center;
}

.flex-baivietkhac img {
  max-width: 40% !important;
}

.baiviet_ot {
  margin: 5px 0;
}

.criteria {
  text-align: center;
}

.criteria-image {
  margin-bottom: 1rem;
  display: inline-block;
}

.criteria-name a {
  font-size: 18px;
  color: #333333;
  text-transform: uppercase;
  -webkit-line-clamp: 1;
}

.criteria-desc {
  font-size: 15px;
  color: #4c4c4c;
  line-height: 1.8;
}

.criteria:hover img {
  transform: rotateY(360deg);
  transition: all 0.6s linear;
}

.bor-criteria {
  border: solid 1px #eee;
  padding: 20px 10px;
  background-color: #fff;
}

.font15 {
  font-size: 15px !important;
}

.font13 {
  font-size: 13px !important;
}

.flex-lienhe {
  display: flex;
  gap: 10px;
}

.flex-lienhe a {
  text-align: center;
  width: calc(50% - 5px);
  font-size: 12px;
}

.tag_linkcap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin: 10px 0;
  flex-wrap: wrap;
}

.tag_linkcap a {
  padding: 10px;
  border-radius: 5px;
  color: #fff;
  background: #ed1c24;
  display: block;
}

.hidden_pc {
  display: none;
}

.left_baiviet {
  position: relative;
}

.baivietkhac {
  position: sticky;
  top: 95px;
}

/* ================= THIEN AN FOOD HOME REDESIGN 2026 ================= */
:root {
  --taf-red: #ed1c24;
  --taf-red-dark: #c80f16;
  --taf-yellow: #f9b000;
  --taf-text: #222;
  --taf-muted: #666;
  --taf-soft: #fff7ed;
  --taf-border: #ffe1b4;
  --taf-shadow: 0 18px 45px rgba(196, 40, 25, .12)
}

body {
  background: #fff;
  color: #000000;
}

.wap_1200 {
  max-width: 1200px;
  margin: auto;
  padding-left: 15px;
  padding-right: 15px
}

.wap_1366 {
  max-width: 1366px;
  margin: auto
}

.header {
  position: sticky;
  top: 0;
  z-index: 99;
  background: rgba(255, 255, 255, .96);
  backdrop-filter: blur(14px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, .06);
  padding: 8px 0
}

.logo_header img {
  max-height: 54px;
  width: auto
}

.menu-main {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none
}

.menu-main>li>a {
  display: flex;
  align-items: center;
  min-height: 42px;
  padding: 0 15px;
  border-radius: 30px;
  color: #222;
  font-weight: 700;
  text-decoration: none
}

.menu-main>li>a.active,
.menu-main>li:hover>a {
  color: var(--taf-red);
  background: #fff1f1
}

.taf-header-quote {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  background: var(--taf-red) !important;
  color: #fff !important;
  border-radius: 8px !important;
  box-shadow: 0 10px 24px rgba(237, 28, 36, .24)
}

.taf-header-quote:hover {
  background: var(--taf-red-dark) !important;
  color: #fff !important
}

.search-res {
  display: none !important
}

.slideshow {
  position: relative;
  background: linear-gradient(120deg, #fff 0%, #fffaf3 54%, #ffe7b4 100%);
  overflow: hidden
}

.slideshow:before {
  content: "";
  position: absolute;
  inset: auto -80px -180px auto;
  width: 480px;
  height: 480px;
  border-radius: 50%;
  background: rgba(249, 176, 0, .24);
  z-index: 1
}

.slideshow-item {
  position: relative
}

.slideshow-image {
  display: block;
  position: relative;
  text-decoration: none;
  min-height: 610px
}

.slideshow-image>img {
  height: 610px;
  object-fit: cover;
  object-position: center right;
  filter: saturate(1.08)
}

.slideshow-image:after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, .98) 0%, rgba(255, 255, 255, .92) 33%, rgba(255, 255, 255, .12) 63%, rgba(255, 255, 255, 0) 100%);
  z-index: 1
}

.text-slide {
  position: absolute;
  left: calc((100% - 1200px)/2 + 15px);
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: min(540px, calc(100% - 30px));
  color: #1f1f1f
}

.taf-hero-brand {
  display: block;
  font-family: cursive;
  font-size: 38px;
  color: var(--taf-red);
  font-weight: 500;
  margin-bottom: 6px
}

.taf-type-target,
.text-slide h1 {
  font-size: 48px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -1px;
  margin: 0 0 16px
}

.taf-typed {
  border-right: 3px solid var(--taf-red);
  white-space: pre-line
}

.text-slide p,
.desc_slide {
  font-size: 16px;
  line-height: 1.6;
  color: #444
}

.taf-hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px
}

.taf-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 9px;
  padding: 13px 24px;
  font-weight: 800;
  text-decoration: none;
  transition: .25s
}

.taf-btn-primary {
  background: var(--taf-red);
  color: #fff !important;
  box-shadow: 0 12px 25px rgba(237, 28, 36, .25)
}

.taf-btn-primary:hover {
  background: var(--taf-red-dark);
  transform: translateY(-2px)
}

.taf-btn-light {
  background: #fff;
  color: #111 !important;
  border: 1px solid #ffd0d0
}

.taf-hero-contact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 22px
}

.taf-hero-contact span {
  display: flex;
  align-items: center;
  gap: 9px;
  background: #fff;
  border: 1px solid #ffe0d4;
  border-radius: 12px;
  padding: 12px 14px;
  font-size: 13px;
  color: #333;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .05)
}

.taf-hero-contact i {
  color: var(--taf-red)
}

.taf-stats {
  position: relative;
  z-index: 3;
  margin: -45px auto 20px;
  max-width: 1200px;
  background: #fff;
  border: 1px solid #ffe1c2;
  border-radius: 18px;
  box-shadow: var(--taf-shadow);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  overflow: hidden
}

.taf-stat {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 22px 28px;
  border-right: 1px solid #ffe4c6
}

.taf-stat:last-child {
  border-right: 0
}

.taf-stat i {
  font-size: 30px;
  color: var(--taf-red)
}

.taf-stat strong {
  display: block;
  font-size: 24px;
  color: var(--taf-red)
}

.taf-stat span {
  font-size: 13px;
  color: #555;
  font-weight: 700
}

.control-slideshow {
  position: absolute;
  right: 30px;
  bottom: 26px;
  z-index: 4
}

.owl-theme .owl-dots .owl-dot span {
  background: #ffd1d1
}

.owl-theme .owl-dots .owl-dot.active span {
  background: var(--taf-red)
}

.taf-section {
  padding: 44px 0
}

.taf-title {
  text-align: center;
  margin-bottom: 24px
}

.taf-title span,
.taf-kicker {
  display: block;
  color: var(--taf-red);
  font-weight: 900;
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: .4px
}

.taf-title h2,
.taf-intro-copy h2 {
  font-size: 30px;
  font-weight: 900;
  line-height: 1.2;
  margin: 4px 0 0
}

.taf-title h2 {
  display: inline-block
}

.taf-title h2:after {
  content: "";
  display: block;
  width: 70%;
  height: 4px;
  background: linear-gradient(90deg, var(--taf-red), var(--taf-yellow));
  border-radius: 4px;
  margin: 10px auto 0
}

.taf-title-left {
  text-align: left
}

.taf-title-left h2:after {
  margin-left: 0
}

.taf-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1.08fr;
  gap: 34px;
  align-items: center
}

.taf-richtext {
  line-height: 1.7;
  color: #444
}

.taf-checklist {
  margin: 18px 0 24px;
  padding: 0;
  list-style: none
}

.taf-checklist li {
  margin: 8px 0;
  color: #333
}

.taf-checklist li:before {
  content: "✓";
  display: inline-flex;
  width: 20px;
  height: 20px;
  align-items: center;
  justify-content: center;
  background: #fff1f1;
  color: var(--taf-red);
  border-radius: 50%;
  margin-right: 8px;
  font-weight: 900
}

.taf-intro-media {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 160px;
  gap: 16px
}

.taf-video-card {
  position: relative;
  grid-row: span 2;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--taf-shadow)
}

.taf-video-card img {
  width: 100%;
  height: 360px;
  object-fit: cover
}

.taf-play {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #fff !important;
  text-decoration: none;
  background: linear-gradient(0deg, rgba(0, 0, 0, .45), rgba(0, 0, 0, .05))
}

.taf-play i {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 76px;
  height: 76px;
  background: var(--taf-red);
  border: 4px solid #fff;
  border-radius: 50%;
  font-size: 28px;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .28)
}

.taf-play span {
  margin-top: 10px;
  font-weight: 800
}

.taf-year-card {
  border-radius: 14px;
  background: linear-gradient(135deg, var(--taf-yellow), #ffcf47);
  color: #fff;
  padding: 22px;
  text-align: center;
  box-shadow: var(--taf-shadow)
}

.taf-year-card strong {
  display: block;
  font-size: 34px
}

.taf-mini-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px
}

.taf-mini-gallery img {
  width: 100%;
  height: 120px;
  object-fit: cover;
  border-radius: 12px
}

.taf-why {
  background: #fffdf9
}

.taf-why-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px
}

.taf-why-card {
  background: #fff;
  border: 1px solid #fff0dc;
  border-radius: 14px;
  padding: 18px;
  text-align: center;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .04);
  transition: .25s
}

.taf-why-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--taf-shadow)
}

.taf-icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: #fff5dc;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px;
  color: var(--taf-red)
}

.taf-icon img {
  max-width: 28px;
  max-height: 28px
}

.taf-why-card h3 {
  font-size: 15px;
  font-weight: 900;
  margin-bottom: 8px
}

.taf-why-card p {
  font-size: 13px;
  color: #666;
  margin: 0
}

.taf-services {
  background: #fff
}

.taf-service-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px
}

.taf-service-card {
  border: 1px solid #ffe6d3;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .05);
  transition: .25s
}

.taf-service-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--taf-shadow)
}

.taf-service-img img {
  width: 100%;
  height: 145px;
  object-fit: cover
}

.taf-service-body {
  padding: 16px;
  position: relative
}

.taf-service-icon {
  position: absolute;
  right: 16px;
  top: -24px;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: var(--taf-red);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  box-shadow: 0 10px 18px rgba(237, 28, 36, .22)
}

.taf-service-card h3 {
  font-size: 18px;
  font-weight: 900;
  margin: 0 0 10px
}

.taf-service-card a {
  color: #222;
  text-decoration: none
}

.taf-service-card h3 a:hover,
.taf-service-card li a:hover {
  color: var(--taf-red)
}

.taf-service-card ul {
  padding-left: 16px;
  margin: 0
}

.taf-service-card li {
  margin: 5px 0;
  color: var(--taf-red)
}

.taf-service-card p {
  font-size: 13px;
  color: #666;
  margin: 0
}

.taf-process {
  background: linear-gradient(180deg, #fff 0%, #fff8ef 100%)
}

.taf-process-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
  counter-reset: step
}

.taf-process-item {
  position: relative;
  background: #fff;
  border: 1px solid #ffe3c0;
  border-radius: 16px;
  padding: 18px 14px;
  text-align: center;
  box-shadow: 0 10px 20px rgba(0, 0, 0, .04)
}

.taf-process-number {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  margin: -36px auto 10px;
  background: var(--taf-red);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  border: 5px solid #fff;
  box-shadow: 0 8px 18px rgba(237, 28, 36, .24)
}

.taf-process-item h3 {
  font-size: 15px;
  font-weight: 900;
  margin-bottom: 7px
}

.taf-process-item p {
  font-size: 13px;
  color: #666;
  margin: 0
}

.taf-combo-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px
}

.taf-combo-card {
  display: block;
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid #ffe7d2;
  text-decoration: none;
  color: #222;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .05);
  transition: .25s
}

.taf-combo-card:hover {
  transform: translateY(-5px);
  color: var(--taf-red)
}

.taf-combo-card img {
  width: 100%;
  height: 118px;
  object-fit: cover
}

.taf-combo-card strong {
  display: block;
  padding: 12px 12px 4px;
  font-weight: 900;
  font-size: 14px;
  text-transform: uppercase
}

.taf-combo-card span {
  display: block;
  padding: 0 12px 14px;
  font-size: 13px;
  color: #666
}

.taf-projects {
  background: #fffdf9
}

.taf-project-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px
}

.taf-project-card {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid #ffe7d2;
  text-decoration: none;
  color: #222;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .05);
  transition: .25s
}

.taf-project-card:hover {
  transform: translateY(-5px);
  color: var(--taf-red)
}

.taf-project-card img {
  width: 100%;
  height: 140px;
  object-fit: cover
}

.taf-project-card h3 {
  font-size: 14px;
  font-weight: 900;
  margin: 12px 12px 4px
}

.taf-project-card p {
  font-size: 12px;
  color: #666;
  margin: 0 12px 14px
}

.taf-center {
  text-align: center;
  margin-top: 22px
}

.taf-feedback-grid {
  display: grid;
  grid-template-columns: 1.1fr 1.4fr;
  gap: 24px
}

.taf-testimonial,
.taf-partners {
  background: #fff;
  border: 1px solid #ffe7d2;
  border-radius: 18px;
  padding: 24px;
  box-shadow: 0 10px 26px rgba(0, 0, 0, .05)
}

.taf-quote {
  position: relative;
  background: #fffaf4;
  border-radius: 14px;
  padding: 18px;
  margin-bottom: 12px
}

.taf-quote i {
  color: var(--taf-yellow);
  font-size: 28px
}

.taf-quote p {
  color: #555;
  line-height: 1.6
}

.taf-quote strong {
  color: var(--taf-red)
}

.taf-partner-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px
}

.taf-partner-grid div {
  height: 78px;
  border-radius: 12px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #f1f1f1
}

.taf-partner-grid img {
  max-width: 82%;
  max-height: 56px
}

.taf-news-faq {
  background: #fff
}

.taf-news-faq-grid {
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: 24px
}

.taf-news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px
}

.taf-news-card {
  border: 1px solid #ffe7d2;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .04)
}

.taf-news-card img {
  width: 100%;
  height: 130px;
  object-fit: cover
}

.taf-news-card div {
  padding: 12px
}

.taf-news-card time {
  font-size: 12px;
  color: var(--taf-red)
}

.taf-news-card h3 {
  font-size: 14px;
  font-weight: 900;
  line-height: 1.35;
  margin: 4px 0 0
}

.taf-news-card a {
  text-decoration: none;
  color: #222
}

.taf-news-card a:hover {
  color: var(--taf-red)
}

.taf-faq-list details {
  border: 1px solid #eee;
  border-radius: 10px;
  background: #fff;
  margin-bottom: 10px;
  overflow: hidden
}

.taf-faq-list summary {
  cursor: pointer;
  list-style: none;
  padding: 14px 16px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: space-between
}

.taf-faq-list details[open] summary {
  color: var(--taf-red);
  background: #fff7f2
}

.taf-faq-list p {
  padding: 0 16px 15px;
  color: #555;
  margin: 0;
  line-height: 1.55
}

.taf-contact-home {
  background: linear-gradient(90deg, #fff 0%, #fff7ed 100%);
  padding-bottom: 0
}

.taf-contact-grid {
  display: grid;
  grid-template-columns: 1.3fr .7fr;
  gap: 24px;
  align-items: stretch
}

.taf-quote-form {
  background: linear-gradient(135deg, var(--taf-red), #ff2e35);
  color: #fff;
  border-radius: 18px 18px 0 0;
  padding: 28px;
  box-shadow: var(--taf-shadow)
}

.taf-quote-form h2 {
  font-size: 26px;
  font-weight: 900
}

.taf-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px
}

.taf-quote-form input,
.taf-quote-form textarea {
  width: 100%;
  border: 0;
  border-radius: 7px;
  padding: 12px 14px;
  margin-bottom: 10px
}

.taf-quote-form textarea {
  min-height: 70px
}

.taf-quote-form button {
  border: 0;
  background: var(--taf-yellow);
  color: #111;
  font-weight: 900;
  border-radius: 8px;
  padding: 13px 28px;
  cursor: pointer
}

.taf-contact-info {
  background: #fff;
  border-radius: 18px 18px 0 0;
  border: 1px solid #ffe7d2;
  padding: 28px
}

.taf-contact-info h3 {
  font-size: 18px;
  font-weight: 900;
  margin: 0 0 14px
}

.taf-contact-info p {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: #555
}

.taf-contact-info i {
  color: var(--taf-red);
  min-width: 18px;
  margin-top: 4px
}

.taf-contact-info ul {
  list-style: none;
  padding: 0;
  margin: 0
}

.taf-contact-info li {
  margin: 8px 0
}

.taf-contact-info li:before {
  content: "\f3c5";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  color: var(--taf-red);
  margin-right: 8px
}

[data-taf-reveal] {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity .7s ease, transform .7s ease
}

[data-taf-reveal].taf-visible {
  opacity: 1;
  transform: none
}

.taf-service-card,
.taf-why-card,
.taf-project-card,
.taf-combo-card,
.taf-news-card {
  will-change: transform
}

@media(max-width:1199px) {
  .text-slide {
    left: 15px
  }

  .taf-why-grid {
    grid-template-columns: repeat(3, 1fr)
  }

  .taf-service-grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .taf-process-row {
    grid-template-columns: repeat(3, 1fr);
    row-gap: 34px
  }

  .taf-project-grid,
  .taf-combo-grid {
    grid-template-columns: repeat(3, 1fr)
  }
}

@media(max-width:800px) {
  .menu-main {
    display: none
  }

  .slideshow-image,
  .slideshow-image>img {
    min-height: 560px;
    height: 560px
  }

  .slideshow-image:after {
    background: rgba(255, 255, 255, .86)
  }

  .text-slide {
    top: 52%;
  }

  .taf-type-target,
  .text-slide h1 {
    font-size: 34px
  }

  .taf-hero-brand {
    font-size: 28px
  }

  .taf-hero-contact,
  .taf-stats,
  .taf-intro-grid,
  .taf-feedback-grid,
  .taf-news-faq-grid,
  .taf-contact-grid {
    grid-template-columns: 1fr
  }

  .taf-stats {
    margin: 15px
  }

  .taf-stat {
    border-right: 0;
    border-bottom: 1px solid #ffe4c6
  }

  .taf-intro-media {
    grid-template-columns: 1fr
  }

  .taf-why-grid,
  .taf-service-grid,
  .taf-process-row,
  .taf-project-grid,
  .taf-combo-grid,
  .taf-news-grid,
  .taf-partner-grid {
    grid-template-columns: 1fr 1fr
  }

  .taf-form-grid {
    grid-template-columns: 1fr
  }
}

@media(max-width:520px) {
  .taf-section {
    padding: 30px 0
  }

  .taf-why-grid,
  .taf-service-grid,
  .taf-process-row,
  .taf-project-grid,
  .taf-combo-grid,
  .taf-news-grid,
  .taf-partner-grid {
    grid-template-columns: 1fr
  }

  .taf-title h2,
  .taf-intro-copy h2 {
    font-size: 25px
  }

  .taf-type-target,
  .text-slide h1 {
    font-size: 30px
  }

  .slideshow-image,
  .slideshow-image>img {
    min-height: 520px;
    height: 520px
  }
}

/* TAF fixes: visible header, inner pages and product/category colors */
:root {
  --taf-red: #ed1c24;
  --taf-red-dark: #bb1419;
  --taf-yellow: #f9b000;
  --taf-orange: #ff8a00;
  --taf-ink: #1f1f1f;
  --taf-soft: #fff7ec;
  --taf-line: #ffe2c2;
  --taf-shadow: 0 15px 40px rgba(237, 28, 36, .12)
}

.taf-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(255, 255, 255, .98) !important;
  border-bottom: 1px solid #ffe4d4;
  box-shadow: 0 10px 32px rgba(0, 0, 0, .08);
  padding: 8px 0 !important
}

.taf-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  min-height: 66px
}

.taf-logo {
  display: flex !important;
  align-items: center;
  gap: 12px;
  text-decoration: none !important;
  min-width: 210px
}

.taf-logo img {
  display: block;
  max-height: 52px !important;
  width: auto !important;
  object-fit: contain;
  background: #fff;
  border-radius: 6px
}

.taf-logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1.05
}

.taf-logo-text strong {
  font-size: 20px;
  font-weight: 900;
  color: var(--taf-red);
  letter-spacing: .2px
}

.taf-logo-text small {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  color: #777;
  letter-spacing: .8px
}

.menu {
  width: auto !important;
  background: transparent !important
}

.menu .wrap-content {
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important
}

.menu-main {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none
}

.menu-main>li {
  position: relative;
  list-style: none
}

.menu-main>li>a {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 14px !important;
  border-radius: 999px;
  color: #202020 !important;
  font-weight: 800;
  text-transform: none;
  text-decoration: none !important;
  background: transparent;
  line-height: 1;
  white-space: nowrap
}

.menu-main>li>a.active,
.menu-main>li:hover>a {
  background: #fff1f1 !important;
  color: var(--taf-red) !important
}

.menu-main .taf-header-quote {
  background: var(--taf-red) !important;
  color: #fff !important;
  border-radius: 9px !important;
  padding: 0 20px !important;
  box-shadow: 0 12px 28px rgba(237, 28, 36, .26)
}

.menu-main .taf-header-quote:hover {
  background: var(--taf-red-dark) !important;
  color: #fff !important;
  transform: translateY(-1px)
}

.menu-main ul {
  background: #fff;
  border: 1px solid #ffe0d2;
  border-radius: 14px;
  box-shadow: 0 18px 40px rgba(0, 0, 0, .12);
  overflow: hidden
}

.menu-main ul li a {
  color: #222 !important
}

.menu-main ul li:hover>a {
  color: var(--taf-red) !important;
  background: #fff6f2 !important
}

.taf-top-area {
  background: #fff
}

.taf-inner-hero {
  position: relative;
  min-height: 230px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: radial-gradient(circle at 90% 10%, rgba(249, 176, 0, .34), transparent 26%), linear-gradient(115deg, #fff 0%, #fff5e7 48%, #ffe1a3 100%);
  border-bottom: 1px solid #ffe1c2
}

.taf-inner-hero:before {
  content: "";
  position: absolute;
  left: -90px;
  top: -120px;
  width: 330px;
  height: 330px;
  border-radius: 50%;
  background: rgba(249, 176, 0, .16)
}

.taf-inner-hero:after {
  content: "";
  position: absolute;
  right: 70px;
  bottom: -75px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(237, 28, 36, .11)
}

.taf-inner-hero-copy {
  position: relative;
  z-index: 2;
  max-width: 680px;
  padding: 35px 0
}

.taf-inner-hero-copy span {
  display: inline-flex;
  align-items: center;
  background: #fff;
  border: 1px solid #ffd4c4;
  border-radius: 999px;
  padding: 8px 16px;
  color: var(--taf-red);
  font-weight: 900;
  text-transform: uppercase;
  box-shadow: 0 10px 25px rgba(237, 28, 36, .08)
}

.taf-inner-hero-copy h1 {
  font-size: 46px;
  line-height: 1.1;
  font-weight: 900;
  color: #ff0000;
  margin: 14px 0 10px
}

.taf-inner-hero-copy p {
  font-size: 18px;
  color: #555;
  margin: 0;
  font-weight: 700
}

.breadCrumbs {
  background: #fff !important;
  border-bottom: 1px solid #f1f1f1
}

.breadCrumbs .wrap-content {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 12px 15px !important
}

.wrap-main:not(.wrap-home) {
  max-width: 1200px !important;
  margin: 34px auto !important;
  padding-left: 15px !important;
  padding-right: 15px !important;
  background: #fff
}

.title-main {
  margin: 0 0 24px !important;
  padding: 0 0 14px !important;
  background: none !important;
  text-align: center;
  position: relative
}

.title-main:after {
  content: "";
  display: block;
  width: 86px;
  height: 4px;
  border-radius: 999px;
  margin: 12px auto 0;
  background: linear-gradient(90deg, var(--taf-red), var(--taf-yellow))
}

.title-main span {
  color: #ff0000 !important;
  font-weight: 900 !important;
  font-size: 34px !important;
  line-height: 1.2;
  text-transform: uppercase
}

.tag_linkcap {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-bottom: 22px
}

.tag_linkcap a {
  display: inline-flex;
  padding: 9px 16px;
  background: #fff7ef;
  color: #ff0000;
  border: 1px solid #ffe1c2;
  border-radius: 999px;
  font-weight: 800
}

.tag_linkcap a:hover {
  background: var(--taf-red);
  color: #fff !important
}

.filter_block {
  border: 1px solid #ffe0cc !important;
  border-radius: 16px !important;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .04);
  margin-bottom: 16px !important
}

.filter_title {
  background: linear-gradient(90deg, var(--taf-red), #ff4a28) !important;
  color: #fff !important;
  font-weight: 900 !important;
  text-transform: uppercase;
  padding: 13px 16px !important
}

.content-main .alert-warning {
  border: 1px solid #ffe0bd;
  background: #fff9ef;
  color: #bd6b00;
  border-radius: 14px;
  padding: 18px
}

.boxProduct,
.product,
.item-product {
  background: #fff;
  border-radius: 14px
}

.slideshow {
  background: linear-gradient(120deg, #fff 0%, #fff7ec 52%, #ffd98a 100%) !important
}

.text-slide {
  background: rgba(255, 255, 255, .74);
  border: 1px solid rgba(255, 225, 194, .8);
  border-radius: 20px;
  padding: 25px;
  box-shadow: 0 18px 45px rgba(196, 40, 25, .10);
  backdrop-filter: blur(5px)
}

.taf-hero-brand {
  font-family: Arial, sans-serif !important;
  font-style: italic;
  color: var(--taf-red) !important;
  font-weight: 800 !important
}

.taf-type-target,
.text-slide h1 {
  color: #202020 !important
}

.desc_slide {
  color: #464646 !important;
  font-weight: 600
}

.taf-stats {
  border: 1px solid #ffd9b1 !important;
  box-shadow: 0 16px 45px rgba(237, 28, 36, .14) !important
}

.taf-stat strong,
.taf-stat i {
  color: var(--taf-red) !important
}

@media(max-width:1100px) {
  .taf-header-inner {
    gap: 10px
  }

  .taf-logo {
    min-width: 180px
  }

  .taf-logo-text strong {
    font-size: 17px
  }

  .menu-main>li>a {
    padding: 0 10px !important;
    font-size: 13px
  }

  .menu-main .taf-header-quote {
    padding: 0 14px !important
  }
}

@media(max-width:800px) {
  .taf-header-inner {
    min-height: 58px
  }

  .taf-logo img {
    max-height: 44px !important
  }

  .taf-logo-text strong {
    font-size: 16px
  }

  .taf-inner-hero {
    min-height: 190px
  }

  .taf-inner-hero-copy h1 {
    font-size: 32px
  }

  .taf-inner-hero-copy p {
    font-size: 15px
  }

  .title-main span {
    font-size: 26px !important
  }

  .text-slide {
    padding: 18px
  }

  .menu-main {
    display: none !important
  }
}

/* TAF v3 requested fixes */
.taf-top-area,
.taf-top-home {
  margin: 0 !important;
  padding: 0 !important;
  background: #fff !important
}

.taf-header {
  height: auto !important;
  min-height: 0 !important
}

.taf-header .wap_1200 {
  display: block !important
}

.taf-header-inner {
  height: 72px !important;
  min-height: 72px !important
}

.taf-top-home .taf-header {
  margin-bottom: 0 !important
}

.taf-home-hero,
.taf-home-hero .owl-carousel,
.taf-home-hero .owl-stage-outer,
.taf-home-hero .owl-stage,
.taf-home-hero .owl-item,
.taf-home-hero .slideshow-item,
.taf-home-hero .slideshow-image {
  height: 610px !important;
  min-height: 610px !important;
  margin: 0 !important;
  padding: 0 !important
}

.taf-home-hero {
  clear: both;
  display: block !important;
  overflow: hidden !important
}

.taf-home-hero .slideshow-image>img {
  display: block !important;
  width: 100% !important;
  height: 610px !important;
  min-height: 610px !important;
  object-fit: cover !important;
  object-position: center right !important;
  margin: 0 !important;
  padding: 0 !important
}

.taf-home-hero .text-slide {
  top: 50% !important;
  margin: 0 !important
}

.taf-logo img[src$="/"] {
  display: none !important
}

.taf-logo-text {
  display: flex !important
}

.header.header-fix {
  background: #fff !important;
  padding: 6px 0 !important
}

.header.header-fix .logo_header {
  max-width: none !important
}

.header.header-fix .menu ul.menu-main {
  margin-bottom: 0 !important
}

.taf-process-item {
  position: relative
}

.taf-process-icon {
  width: 54px;
  height: 54px;
  border-radius: 16px;
  background: #fff4dc;
  border: 1px solid #ffe0aa;
  margin: 0 auto 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--taf-red);
  font-size: 24px;
  box-shadow: 0 10px 22px rgba(237, 28, 36, .08)
}

.taf-process-icon img {
  max-width: 34px;
  max-height: 34px;
  object-fit: contain
}

.taf-process-number {
  margin-top: 0 !important
}

.taf-contact-info p:empty {
  display: none !important
}

.taf-projects .taf-title span:before {
  content: none !important
}

@media(max-width:800px) {
  .taf-header-inner {
    height: 62px !important;
    min-height: 62px !important
  }

  .taf-home-hero,
  .taf-home-hero .owl-carousel,
  .taf-home-hero .owl-stage-outer,
  .taf-home-hero .owl-stage,
  .taf-home-hero .owl-item,
  .taf-home-hero .slideshow-item,
  .taf-home-hero .slideshow-image,
  .taf-home-hero .slideshow-image>img {
    height: 560px !important;
    min-height: 560px !important
  }
}

/* TAF v4 fixes */
.footer .wap_form {
  display: none !important
}

.footer-article {
  margin-top: 0 !important
}

.taf-contact-info a {
  color: #333;
  text-decoration: none
}

.taf-contact-info a:hover {
  color: var(--taf-red)
}

.taf-admin-contact {
  margin: 10px 0 18px;
  color: #555;
  line-height: 1.7
}

.taf-admin-contact p {
  margin: 0 0 8px;
  display: block
}

.taf-admin-contact i,
.taf-admin-contact svg {
  color: var(--taf-red)
}

.taf-gallery-page {
  padding: 36px 0 55px
}

.taf-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  max-width: 1200px;
  margin: 0 auto
}

.taf-gallery-card {
  background: #fff;
  border: 1px solid #ffe4c9;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 30px rgba(0, 0, 0, .06);
  transition: .25s
}

.taf-gallery-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 38px rgba(237, 28, 36, .12)
}

.taf-gallery-card a {
  display: block;
  color: #222;
  text-decoration: none
}

.taf-gallery-img {
  display: block;
  position: relative;
  overflow: hidden
}

.taf-gallery-img img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  transition: .35s
}

.taf-gallery-card:hover img {
  transform: scale(1.06)
}

.taf-gallery-info {
  display: block;
  padding: 15px 16px 18px
}

.taf-gallery-info strong {
  display: block;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.35;
  margin-bottom: 8px
}

.taf-gallery-info em {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-style: normal;
  color: #666;
  font-size: 14px;
  line-height: 1.55
}

.taf-gallery-card:hover strong {
  color: var(--taf-red)
}

.taf-quote-modal .modal-content {
  border: 0;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 28px 80px rgba(0, 0, 0, .28)
}

.taf-quote-modal .modal-body {
  padding: 0
}

.taf-modal-close {
  position: absolute;
  right: 16px;
  top: 12px;
  z-index: 5;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #fff !important;
  opacity: 1;
  color: var(--taf-red) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .18)
}

.taf-popup-quote {
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  min-height: 460px
}

.taf-popup-copy {
  padding: 42px 34px;
  background: linear-gradient(135deg, var(--taf-red), #ff3d27);
  color: #fff
}

.taf-popup-copy span {
  font-family: cursive;
  font-size: 28px;
  letter-spacing: 2px
}

.taf-popup-copy h2 {
  font-size: 36px;
  font-weight: 900;
  line-height: 1.1;
  margin: 12px 0
}

.taf-popup-copy p {
  font-size: 16px;
  line-height: 1.7
}

.taf-popup-copy ul {
  padding: 0;
  margin: 22px 0 0;
  list-style: none
}

.taf-popup-copy li {
  margin: 11px 0
}

.taf-popup-copy li:before {
  content: '✓';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fff;
  color: var(--taf-red);
  font-weight: 900;
  margin-right: 8px
}

.taf-popup-form {
  padding: 42px 34px;
  background: #fff
}

.taf-popup-form input,
.taf-popup-form textarea {
  width: 100%;
  height: 52px;
  border: 1px solid #ffe0c7;
  border-radius: 12px;
  margin-bottom: 12px;
  padding: 0 16px;
  font-size: 15px;
  background: #fffaf6
}

.taf-popup-form textarea {
  height: 100px;
  padding-top: 14px
}

.taf-popup-form button {
  border: 0;
  border-radius: 12px;
  background: var(--taf-yellow);
  color: #111;
  font-weight: 900;
  padding: 14px 24px;
  box-shadow: 0 10px 24px rgba(255, 184, 0, .25);
  cursor: pointer
}

.taf-popup-form button:hover {
  filter: brightness(.96)
}

@media(max-width:991px) {
  .taf-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    padding: 0 15px
  }

  .taf-popup-quote {
    grid-template-columns: 1fr
  }

  .taf-popup-copy {
    padding: 32px 24px
  }

  .taf-popup-form {
    padding: 30px 24px
  }
}

@media(max-width:560px) {
  .taf-gallery-grid {
    grid-template-columns: 1fr
  }

  .taf-gallery-img img {
    height: 220px
  }

  .taf-popup-copy h2 {
    font-size: 28px
  }
}

/* TAF v5: fix hero text, featured gallery, and scroll/hover effects */
.taf-home-hero .slideshow-item {
  position: relative !important;
  overflow: hidden !important
}

.taf-home-hero .slideshow-image {
  display: block !important;
  position: relative !important;
  z-index: 1 !important
}

.taf-home-hero .slideshow-image:after {
  pointer-events: none !important
}

.taf-home-hero .text-slide,
.taf-home-hero .taf-hero-copybox {
  position: absolute !important;
  left: calc((100% - 1200px)/2 + 15px) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 5 !important;
  width: min(520px, calc(100% - 30px)) !important;
  min-height: 0 !important;
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  background: rgba(255, 255, 255, .88) !important;
  border: 1px solid rgba(255, 215, 175, .95) !important;
  border-radius: 22px !important;
  padding: 34px 38px !important;
  color: #202020 !important;
  text-align: left !important;
  box-shadow: 0 22px 55px rgba(0, 0, 0, .10), 0 8px 24px rgba(237, 28, 36, .08) !important;
  backdrop-filter: blur(8px) !important;
}

.taf-home-hero .text-slide:before,
.taf-home-hero .text-slide:after {
  display: none !important;
  content: none !important
}

.taf-home-hero .taf-hero-brand {
  display: block !important;
  font-size: 30px !important;
  line-height: 1.15 !important;
  letter-spacing: 7px !important;
  color: var(--taf-red) !important;
  margin: 0 0 12px !important;
  text-align: center !important;
  font-weight: 800 !important;
  font-family: Arial, sans-serif !important;
  font-style: italic !important
}

.taf-home-hero .taf-type-target,
.taf-home-hero .text-slide h1 {
  display: block !important;
  font-size: 48px !important;
  line-height: 1.08 !important;
  font-weight: 900 !important;
  letter-spacing: -1px !important;
  margin: 0 0 16px !important;
  color: #202020 !important;
  text-align: center !important;
  min-height: 156px !important;
  white-space: normal !important;
  overflow: visible !important;
  text-shadow: none !important
}

.taf-home-hero .desc_slide {
  display: block !important;
  color: #444 !important;
  font-size: 16px !important;
  line-height: 1.55 !important;
  font-weight: 600 !important;
  text-align: left !important;
  margin-top: 5px !important
}

.taf-home-hero .taf-hero-actions {
  position: relative !important;
  z-index: 7 !important
}

.taf-home-hero .taf-btn {
  pointer-events: auto !important
}

.taf-home-hero .taf-typed {
  border-right: 3px solid var(--taf-red) !important
}

.taf-projects .taf-project-grid {
  align-items: stretch !important
}

.taf-projects .taf-project-card {
  position: relative !important;
  min-height: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  background: #fff !important;
  box-shadow: 0 14px 34px rgba(0, 0, 0, .07) !important
}

.taf-projects .taf-project-card:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, .62) 100%);
  z-index: 2;
  opacity: .72;
  transition: .35s;
  pointer-events: none
}

.taf-projects .taf-project-card img {
  display: block !important;
  width: 100% !important;
  height: 190px !important;
  object-fit: cover !important;
  transition: transform .55s ease, filter .55s ease !important
}

.taf-projects .taf-project-card h3 {
  position: absolute !important;
  left: 14px !important;
  right: 14px !important;
  bottom: 14px !important;
  z-index: 3 !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: 15px !important;
  line-height: 1.35 !important;
  font-weight: 900 !important;
  text-shadow: 0 2px 10px rgba(0, 0, 0, .35) !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden
}

.taf-projects .taf-project-card p {
  display: none !important
}

.taf-projects .taf-project-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 22px 46px rgba(237, 28, 36, .18) !important;
  color: #fff !important
}

.taf-projects .taf-project-card:hover img {
  transform: scale(1.09) !important;
  filter: saturate(1.12) contrast(1.04) !important
}

.taf-projects .taf-project-card:hover:before {
  opacity: .92;
  background: linear-gradient(180deg, rgba(237, 28, 36, .05) 0%, rgba(237, 28, 36, .85) 100%)
}

[data-taf-reveal] {
  opacity: 0 !important;
  transform: translateY(44px) scale(.985) !important;
  transition: opacity .75s ease, transform .75s cubic-bezier(.2, .8, .2, 1) !important
}

[data-taf-reveal].taf-visible {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important
}

.taf-visible .taf-why-card,
.taf-visible .taf-service-card,
.taf-visible .taf-process-item,
.taf-visible .taf-combo-card,
.taf-visible .taf-project-card,
.taf-visible .taf-news-card,
.taf-visible .taf-gallery-card {
  animation: tafFadeUp .75s both;
}

.taf-visible .taf-why-card:nth-child(2),
.taf-visible .taf-service-card:nth-child(2),
.taf-visible .taf-process-item:nth-child(2),
.taf-visible .taf-combo-card:nth-child(2),
.taf-visible .taf-project-card:nth-child(2),
.taf-visible .taf-news-card:nth-child(2),
.taf-visible .taf-gallery-card:nth-child(2) {
  animation-delay: .08s
}

.taf-visible .taf-why-card:nth-child(3),
.taf-visible .taf-service-card:nth-child(3),
.taf-visible .taf-process-item:nth-child(3),
.taf-visible .taf-combo-card:nth-child(3),
.taf-visible .taf-project-card:nth-child(3),
.taf-visible .taf-news-card:nth-child(3),
.taf-visible .taf-gallery-card:nth-child(3) {
  animation-delay: .16s
}

.taf-visible .taf-why-card:nth-child(4),
.taf-visible .taf-service-card:nth-child(4),
.taf-visible .taf-process-item:nth-child(4),
.taf-visible .taf-combo-card:nth-child(4),
.taf-visible .taf-project-card:nth-child(4),
.taf-visible .taf-news-card:nth-child(4),
.taf-visible .taf-gallery-card:nth-child(4) {
  animation-delay: .24s
}

.taf-visible .taf-why-card:nth-child(5),
.taf-visible .taf-service-card:nth-child(5),
.taf-visible .taf-process-item:nth-child(5),
.taf-visible .taf-combo-card:nth-child(5),
.taf-visible .taf-project-card:nth-child(5),
.taf-visible .taf-news-card:nth-child(5),
.taf-visible .taf-gallery-card:nth-child(5) {
  animation-delay: .32s
}

@keyframes tafFadeUp {
  from {
    opacity: 0;
    transform: translateY(28px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.taf-intro-media img,
.taf-service-img img,
.taf-combo-card img,
.taf-news-card img,
.taf-gallery-img img {
  transition: transform .55s ease, filter .55s ease !important
}

.taf-intro-media img:hover,
.taf-service-card:hover .taf-service-img img,
.taf-combo-card:hover img,
.taf-news-card:hover img,
.taf-gallery-card:hover .taf-gallery-img img {
  transform: scale(1.06) !important;
  filter: saturate(1.12) !important
}

@media(max-width:1199px) {

  .taf-home-hero .text-slide,
  .taf-home-hero .taf-hero-copybox {
    left: 15px !important
  }
}

@media(max-width:800px) {

  .taf-home-hero .text-slide,
  .taf-home-hero .taf-hero-copybox {
    padding: 24px 20px !important;
    top: 52% !important
  }

  .taf-home-hero .taf-type-target,
  .taf-home-hero .text-slide h1 {
    font-size: 33px !important;
    min-height: 110px !important
  }

  .taf-home-hero .taf-hero-brand {
    font-size: 22px !important;
    letter-spacing: 4px !important
  }

  .taf-projects .taf-project-card img {
    height: 210px !important
  }
}


/* TAF v6: banner alignment, menu page, red contact buttons, mobile header */
:root {
  --maincolor: #ed1c24 !important;
  --taf-red: #ed1c24 !important;
  --taf-red-dark: #c80f16 !important
}

.taf-home-hero .slideshow-image {
  pointer-events: none !important
}

.taf-home-hero .slideshow-image img {
  pointer-events: none !important
}

.taf-home-hero .taf-hero-food-copy {
  width: min(470px, calc(100% - 30px)) !important;
  padding: 30px 30px !important;
  z-index: 30 !important;
  pointer-events: auto !important
}

.taf-home-hero .taf-hero-food-copy .taf-hero-brand {
  text-align: left !important;
  font-size: 25px !important;
  letter-spacing: 6px !important;
  margin-left: 8px !important
}

.taf-home-hero .taf-hero-food-copy h1,
.taf-home-hero .taf-hero-food-copy .taf-type-target {
  text-align: left !important;
  font-size: 40px !important;
  line-height: 1.08 !important;
  letter-spacing: -.8px !important;
  min-height: 130px !important;
  margin-bottom: 14px !important
}

.taf-home-hero .taf-hero-food-copy .desc_slide {
  font-size: 15px !important;
  line-height: 1.5 !important;
  max-width: 390px !important
}

.taf-home-hero .taf-hero-food-copy .taf-hero-actions {
  margin-top: 24px !important;
  display: flex !important;
  gap: 12px !important;
  align-items: center !important;
  position: relative !important;
  z-index: 40 !important;
  pointer-events: auto !important
}

.taf-home-hero .taf-hero-food-copy .taf-btn {
  min-height: 48px !important;
  padding: 0 22px !important;
  position: relative !important;
  z-index: 45 !important;
  pointer-events: auto !important
}

.taf-btn-primary,
.menu-main .taf-header-quote,
.taf-service-icon,
.taf-process-number,
.taf-play i {
  background: #ed1c24 !important
}

.taf-btn-primary:hover,
.menu-main .taf-header-quote:hover {
  background: #c80f16 !important
}

.btn-frame i,
.js-facebook-messenger-box {
  background: #ed1c24 !important
}

.btn-frame .kenit-alo-circle {
  border-color: #ed1c24 !important
}

.btn-frame .kenit-alo-circle-fill {
  background-color: rgba(237, 28, 36, .25) !important
}

.toolbar ul li:nth-child(1),
.toolbar ul li:nth-child(2) {
  background-color: #ed1c24 !important
}

.taf-menu-page {
  max-width: 1200px;
  margin: 0 auto;
  padding: 36px 0 58px
}

.taf-menu-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px
}

.taf-menu-card {
  display: block;
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  border: 1px solid #ffe3cf;
  box-shadow: 0 14px 34px rgba(0, 0, 0, .07);
  text-decoration: none;
  color: #202020;
  transition: .32s
}

.taf-menu-card:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 45%, rgba(0, 0, 0, .65));
  z-index: 1;
  opacity: .7;
  transition: .32s;
  pointer-events: none
}

.taf-menu-card img {
  width: 100%;
  height: 360px;
  object-fit: cover;
  display: block;
  transition: .5s
}

.taf-menu-card h3 {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 2;
  color: #fff;
  font-size: 20px;
  font-weight: 900;
  margin: 0;
  text-shadow: 0 2px 12px rgba(0, 0, 0, .35)
}

.taf-menu-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 54px rgba(237, 28, 36, .18)
}

.taf-menu-card:hover img {
  transform: scale(1.08);
  filter: saturate(1.12)
}

.taf-menu-card:hover:before {
  opacity: .95;
  background: linear-gradient(180deg, rgba(237, 28, 36, .05) 0%, rgba(237, 28, 36, .82) 100%)
}

.taf-admin-login {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  align-items: center;
  gap: 40px;
  padding: 60px;
  position: relative;
  background: radial-gradient(circle at 20% 20%, rgba(255, 214, 150, .45), transparent 28%), linear-gradient(135deg, #fff 0%, #fff6ee 52%, #ffe2ba 100%);
  overflow: hidden
}

.taf-admin-login:after {
  content: "";
  position: absolute;
  right: -150px;
  bottom: -180px;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  background: rgba(237, 28, 36, .09)
}

.taf-admin-brand,
.taf-admin-card {
  position: relative;
  z-index: 2
}

.taf-admin-logo {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 34px
}

.taf-admin-logo img {
  max-width: 90px;
  max-height: 80px
}

.taf-admin-logo strong {
  display: block;
  color: #ed1c24;
  font-weight: 900;
  font-size: 28px;
  line-height: 1
}

.taf-admin-logo small {
  text-transform: uppercase;
  color: #555;
  font-weight: 800;
  letter-spacing: 1px
}

.taf-admin-brand h1 {
  font-size: 52px;
  line-height: 1.02;
  font-weight: 900;
  color: #1f1f1f;
  margin: 0 0 18px
}

.taf-admin-brand p {
  font-size: 18px;
  line-height: 1.7;
  color: #555;
  max-width: 560px
}

.taf-admin-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px
}

.taf-admin-pills span {
  display: inline-flex;
  border: 1px solid #ffd4c4;
  background: #fff;
  border-radius: 999px;
  padding: 10px 16px;
  font-weight: 800;
  color: #333
}

.taf-admin-card {
  background: #fff;
  border-radius: 24px;
  padding: 42px 36px;
  box-shadow: 0 28px 80px rgba(0, 0, 0, .14);
  border: 1px solid #ffe1d3
}

.taf-admin-card .login-box-msg {
  font-size: 32px !important;
  font-weight: 900 !important;
  color: #ed1c24 !important;
  text-align: left !important;
  padding: 0 !important;
  margin: 0 0 8px !important
}

.taf-admin-card .login-sub {
  color: #666;
  margin-bottom: 24px
}

.taf-admin-card .input-group {
  height: 54px;
  border: 1px solid #ffe0d0;
  border-radius: 14px;
  overflow: hidden;
  background: #fffaf6
}

.taf-admin-card .input-group-text {
  height: 54px;
  border: 0 !important;
  background: #fff3ec !important;
  color: #ed1c24 !important;
  width: 54px;
  justify-content: center
}

.taf-admin-card .form-control {
  border: 0 !important;
  background: transparent !important;
  height: 54px;
  font-size: 15px !important
}

.taf-admin-card .btn-login {
  height: 54px;
  border: 0 !important;
  border-radius: 14px !important;
  background: linear-gradient(90deg, #ed1c24, #ff7a00) !important;
  font-weight: 900 !important;
  font-size: 16px !important;
  box-shadow: 0 14px 30px rgba(237, 28, 36, .28)
}

.taf-admin-extra {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 10px 0 20px;
  color: #666
}

.taf-admin-extra label {
  margin: 0
}

.taf-admin-extra a {
  color: #ed1c24;
  font-weight: 800
}

.login-view-website {
  background: #ed1c24 !important
}

.login-copyright a {
  color: #ed1c24 !important
}

@media(max-width:991px) {
  .taf-menu-grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .taf-admin-login {
    grid-template-columns: 1fr;
    padding: 40px 20px
  }

  .taf-admin-brand h1 {
    font-size: 38px
  }

  .taf-header-inner {
    justify-content: center !important;
    position: relative
  }

  .taf-logo {
    margin: 0 auto !important;
    justify-content: center !important;
    text-align: center
  }

  .taf-logo img {
    margin: 0 auto !important
  }

  .taf-header .menu {
    display: none !important
  }
}

@media(max-width:800px) {
  .taf-home-hero .taf-hero-food-copy {
    left: 18px !important;
    right: 18px !important;
    width: auto !important;
    padding: 24px 22px !important
  }

  .taf-home-hero .taf-hero-food-copy h1,
  .taf-home-hero .taf-hero-food-copy .taf-type-target {
    font-size: 31px !important;
    min-height: 105px !important
  }

  .taf-home-hero .taf-hero-food-copy .taf-hero-brand {
    font-size: 20px !important;
    letter-spacing: 4px !important
  }

  .taf-menu-grid {
    grid-template-columns: 1fr
  }

  .taf-menu-card img {
    height: 330px
  }
}


/* TAF v7: banner copy, CTA click layer and mobile logo alignment */
.taf-home-hero .taf-hero-food-copy {
  left: calc((100% - 1200px)/2 + 15px) !important;
  width: min(430px, calc(100% - 30px)) !important;
  padding: 28px 32px !important;
  text-align: left !important;
  z-index: 80 !important;
  pointer-events: auto !important;
}

.taf-home-hero .taf-hero-food-copy .taf-hero-brand {
  text-align: left !important;
  font-size: 23px !important;
  letter-spacing: 5px !important;
  margin: 0 0 10px 0 !important;
}

.taf-home-hero .taf-hero-food-copy h1,
.taf-home-hero .taf-hero-food-copy .taf-type-target {
  text-align: left !important;
  font-size: 34px !important;
  line-height: 1.12 !important;
  letter-spacing: -.5px !important;
  min-height: 118px !important;
  margin: 0 0 14px !important;
}

.taf-home-hero .taf-hero-food-copy .desc_slide {
  text-align: left !important;
  font-size: 14.5px !important;
  line-height: 1.55 !important;
  max-width: 360px !important;
}

.taf-home-hero .taf-hero-actions {
  justify-content: flex-start !important;
  margin-top: 22px !important;
}

.taf-home-hero .taf-hero-actions a,
.taf-home-hero .taf-btn {
  position: relative !important;
  z-index: 120 !important;
  pointer-events: auto !important;
  cursor: pointer !important;
}

.taf-home-hero .taf-btn-primary {
  min-width: 128px !important;
}

.taf-home-hero .taf-btn-light {
  min-width: 142px !important;
}

.taf-home-hero .owl-nav,
.taf-home-hero .control-slideshow {
  z-index: 60 !important;
}

.taf-home-hero .owl-dots {
  z-index: 60 !important;
}

@media(max-width:1199px) {
  .taf-home-hero .taf-hero-food-copy {
    left: 24px !important;
  }
}

@media(max-width:767px) {
  .taf-header {
    padding: 7px 0 !important;
  }

  .taf-header .wap_1200 {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .taf-header-inner {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    height: auto !important;
    min-height: 64px !important;
    position: relative !important;
  }

  .taf-header .menu {
    display: none !important;
  }

  .taf-logo {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-content: center !important;
    text-align: center !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: 92% !important;
  }

  .taf-logo img {
    max-height: 48px !important;
    margin: 0 !important;
  }

  .taf-logo-text {
    text-align: left !important;
  }

  .taf-home-hero .taf-hero-food-copy {
    left: 16px !important;
    right: 16px !important;
    width: auto !important;
    padding: 22px 20px !important;
  }

  .taf-home-hero .taf-hero-food-copy h1,
  .taf-home-hero .taf-hero-food-copy .taf-type-target {
    font-size: 28px !important;
    min-height: 95px !important;
  }

  .taf-home-hero .taf-hero-food-copy .taf-hero-brand {
    font-size: 18px !important;
    letter-spacing: 3px !important;
  }

  .taf-home-hero .taf-hero-actions {
    gap: 10px !important;
  }

  .taf-home-hero .taf-btn {
    min-width: auto !important;
    padding: 0 16px !important;
    font-size: 13px !important;
  }
}


/* TAF v9: force banner CTA links to be clickable and route correctly */
.taf-home-hero .slideshow-item {
  position: relative !important;
}

.taf-home-hero .taf-hero-actions {
  position: relative !important;
  z-index: 999 !important;
  pointer-events: auto !important;
}

.taf-home-hero .taf-hero-actions .taf-btn {
  position: relative !important;
  z-index: 1000 !important;
  pointer-events: auto !important;
  cursor: pointer !important;
}

.taf-home-hero .taf-hero-actions .taf-btn-zalo {
  background: #ed1c24 !important;
  color: #fff !important;
}

.taf-home-hero .taf-hero-actions .taf-btn-menu {
  background: #fff !important;
  color: #111 !important;
  border: 1px solid #ffd0d0 !important;
}


/* v11: Fix click banner buttons + frontend menu item */
.taf-home-hero .slideshow-image {
  pointer-events: none !important;
}

.taf-home-hero .text-slide,
.taf-home-hero .taf-hero-copybox,
.taf-home-hero .taf-hero-actions,
.taf-home-hero .taf-hero-actions a {
  pointer-events: auto !important;
}

.taf-home-hero .taf-hero-actions {
  position: relative !important;
  z-index: 9999 !important;
}

.taf-home-hero .taf-hero-actions .taf-btn {
  position: relative !important;
  z-index: 10000 !important;
  cursor: pointer !important;
}

.menu-main>li>a[href="menu"] {
  font-weight: 800;
}
/* TAF custom fixes 2026-05-11: mobile header, process redesign, mobile floating CTA */
.menu-res {
  background: #fff !important;
  position: sticky !important;
  position: -webkit-sticky !important;
  top: 0 !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .06) !important;
}

.menu-bar-res {
  position: relative !important;
  justify-content: center !important;
}

.menu-bar-res #hamburger {
  position: absolute !important;
  left: 15px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

.menu-bar-res .search-res {
  position: absolute !important;
  right: 15px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

.logo_mobi {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  float: none !important;
  width: auto !important;
  max-width: 140px !important;
  margin: 0 auto !important;
  padding: 5px 0 !important;
}

.logo_mobi img {
  display: block !important;
  max-width: 88px !important;
  max-height: 68px !important;
  object-fit: contain !important;
}

.taf-process {
  background: linear-gradient(180deg, #fff8ef 0%, #fff 100%);
  overflow: hidden;
}

.taf-process .taf-title {
  margin-bottom: 38px;
}

.taf-process-row {
  display: flex !important;
  flex-wrap: nowrap;
  gap: 20px;
  align-items: stretch;
}

.taf-process-item {
  position: relative;
  flex: 1 1 0;
  min-width: 0;
  padding: 24px 18px 22px;
  border-radius: 26px;
  background: linear-gradient(180deg, #ffffff 0%, #fffaf3 100%);
  border: 1px solid rgba(249, 176, 0, .24);
  box-shadow: 0 18px 42px rgba(17, 24, 39, .07);
  transition: transform .45s ease, box-shadow .45s ease, border-color .45s ease, background .45s ease;
  overflow: hidden;
}

.taf-process-item::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(249, 176, 0, .15), transparent 36%);
  pointer-events: none;
}

.taf-process-item::after {
  content: "";
  position: absolute;
  top: 84px;
  left: calc(100% - 10px);
  width: 20px;
  height: 2px;
  background: linear-gradient(90deg, rgba(237, 28, 36, .55), rgba(249, 176, 0, .35));
}

.taf-process-item:last-child::after {
  display: none;
}

.taf-process-item.is-active {
  transform: translateY(-12px);
  border-color: rgba(237, 28, 36, .36);
  background: linear-gradient(180deg, #fffdf9 0%, #fff3ee 100%);
  box-shadow: 0 28px 56px rgba(237, 28, 36, .16);
}

.taf-process-step {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 84px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(237, 28, 36, .08);
  color: var(--taf-red);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .03em;
  text-transform: uppercase;
  position: relative;
  z-index: 1;
}

.taf-process-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 16px 0 18px;
  position: relative;
  z-index: 1;
}

.taf-process-icon {
  width: 74px;
  height: 74px;
  border-radius: 22px;
  background: linear-gradient(180deg, #fff7e7 0%, #fff2d8 100%);
  border: 1px solid rgba(249, 176, 0, .24);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.82);
  flex-shrink: 0;
  overflow: hidden;
}

.taf-process-icon i {
  font-size: 28px;
  color: var(--taf-red);
}

.taf-process-icon img {
  max-width: 48px;
  max-height: 48px;
  object-fit: contain;
}

.taf-process-number {
  position: relative;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--taf-red) 0%, #ff4d45 100%);
  color: #fff;
  font-size: 22px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 14px 28px rgba(237, 28, 36, .2);
  flex-shrink: 0;
}

.taf-process-number::before {
  content: "";
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  border: 1px solid rgba(237, 28, 36, .18);
}

.taf-process-body {
  position: relative;
  z-index: 1;
}

.taf-process-item h3 {
  margin: 0 0 8px;
  font-size: 18px;
  line-height: 1.32;
  color: #1f2937;
}

.taf-process-item p {
  margin: 0;
  font-size: 14px;
  line-height: 1.58;
  color: #5b6573;
}

.taf-mobile-float {
  display: none !important;
}

.taf-mobile-float.btn-frame i {
  color: #fff;
  font-size: 18px;
}

.taf-mobile-menu.btn-frame i {
  background: #ffb000 !important;
}

.taf-mobile-menu .kenit-alo-circle {
  border-color: #ffb000 !important;
}

.taf-mobile-menu .kenit-alo-circle-fill {
  background-color: rgba(255, 176, 0, .25) !important;
}

@media (max-width: 1199px) {
  .taf-process-row {
    gap: 16px;
  }

  .taf-process-item {
    padding: 22px 16px 20px;
  }

  .taf-process-item h3 {
    font-size: 17px;
  }

  .taf-process-item p {
    font-size: 13px;
  }
}

@media (max-width: 991px) {
  .taf-process-row {
    overflow-x: auto;
    padding-bottom: 6px;
    scroll-snap-type: x mandatory;
  }

  .taf-process-item {
    min-width: 260px;
    flex: 0 0 260px;
    scroll-snap-align: start;
  }

  .taf-process-item::after {
    display: none;
  }
}

@media (max-width: 767px) {
  .taf-process .taf-title {
    margin-bottom: 26px;
  }

  .taf-process-row {
    gap: 14px;
  }

  .taf-process-item {
    min-width: 235px;
    flex-basis: 235px;
    padding: 18px 16px 18px;
    border-radius: 22px;
  }

  .taf-process-step {
    min-width: 76px;
    font-size: 11px;
    padding: 7px 12px;
  }

  .taf-process-top {
    margin: 14px 0 16px;
  }

  .taf-process-icon {
    width: 62px;
    height: 62px;
    border-radius: 18px;
  }

  .taf-process-icon img {
    max-width: 40px;
    max-height: 40px;
  }

  .taf-process-icon i {
    font-size: 24px;
  }

  .taf-process-number {
    width: 52px;
    height: 52px;
    font-size: 19px;
  }

  .taf-process-item h3 {
    font-size: 17px;
  }

  .taf-process-item p {
    font-size: 13px;
    line-height: 1.55;
  }

  .btn-zalo {
    bottom: 330px !important;
  }

  .taf-mobile-float {
    display: block !important;
    right: 20px !important;
    width: 50px;
    height: 50px;
  }

  .taf-mobile-quote {
    bottom: 245px !important;
  }

  .taf-mobile-menu {
    bottom: 160px !important;
  }

  .btn-phone {
    bottom: 75px !important;
  }
}

@media (max-width: 480px) {
  .taf-process-item {
    min-width: 220px;
    flex-basis: 220px;
  }

  .btn-zalo,
  .taf-mobile-float,
  .btn-phone,
  .js-facebook-messenger-box,
  .cart-fixed {
    right: 14px !important;
  }

  .btn-zalo {
    bottom: 320px !important;
  }

  .taf-mobile-quote {
    bottom: 235px !important;
  }

  .taf-mobile-menu {
    bottom: 150px !important;
  }

  .btn-phone {
    bottom: 65px !important;
  }
}


/* TAF v12: premium intro media + search icons on desktop/mobile */
.taf-search-desktop {
  display: flex;
  align-items: center;
}

.taf-header-search {
  float: none !important;
  width: 44px !important;
  height: 44px;
  z-index: 20;
}

.taf-header-search .icon-search,
.menu-bar-res .search-res .icon-search {
  width: 44px !important;
  height: 44px !important;
  line-height: 44px !important;
  border-radius: 50%;
  background: #fff4f4;
  color: var(--taf-red) !important;
  box-shadow: 0 10px 24px rgba(237, 28, 36, .14);
  border: 1px solid rgba(237, 28, 36, .12);
  transition: all .25s ease;
}

.taf-header-search .icon-search:hover,
.taf-header-search .icon-search.active,
.menu-bar-res .search-res .icon-search:hover,
.menu-bar-res .search-res .icon-search.active {
  background: var(--taf-red) !important;
  color: #fff !important;
  transform: translateY(-1px);
}

.taf-header-search .search-grid {
  top: 52px !important;
  right: 0 !important;
  height: 46px !important;
  border: 0 !important;
  border-radius: 999px !important;
  box-shadow: 0 18px 45px rgba(0, 0, 0, .13);
  z-index: 99 !important;
}

.taf-header-search .search-grid input {
  height: 44px !important;
  line-height: 44px !important;
  padding: 0 16px !important;
  font-size: 14px !important;
}

.taf-header-search .search-grid p {
  height: 44px !important;
  line-height: 44px !important;
  color: var(--taf-red) !important;
}

.taf-intro-media {
  isolation: isolate;
  padding: 18px;
  border-radius: 34px;
  background: linear-gradient(135deg, rgba(255, 246, 238, .9), rgba(255, 255, 255, .55));
}

.taf-intro-media::before,
.taf-intro-media::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  filter: blur(2px);
  z-index: -1;
  pointer-events: none;
}

.taf-intro-media::before {
  width: 210px;
  height: 210px;
  right: -36px;
  top: -48px;
  background: rgba(249, 176, 0, .22);
}

.taf-intro-media::after {
  width: 230px;
  height: 230px;
  left: -34px;
  bottom: -42px;
  background: rgba(237, 28, 36, .11);
}

.taf-video-card {
  border-radius: 30px !important;
  border: 8px solid #fff;
  box-shadow: 0 28px 70px rgba(28, 28, 28, .16) !important;
  transform: rotate(-.6deg);
  transition: transform .35s ease, box-shadow .35s ease;
}

.taf-video-card:hover {
  transform: rotate(0deg) translateY(-4px);
  box-shadow: 0 34px 80px rgba(237, 28, 36, .2) !important;
}

.taf-video-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(237, 28, 36, .22), transparent 38%, rgba(249, 176, 0, .18));
  z-index: 1;
  pointer-events: none;
}

.taf-video-card img {
  height: 372px !important;
  display: block;
  filter: saturate(1.08) contrast(1.02);
}

.taf-play {
  z-index: 2;
  background: linear-gradient(180deg, rgba(0, 0, 0, .08), rgba(0, 0, 0, .5)) !important;
}

.taf-play i {
  width: 88px !important;
  height: 88px !important;
  background: linear-gradient(135deg, var(--taf-red), #ff4a21) !important;
  border-width: 5px !important;
  position: relative;
}

.taf-play i::after {
  content: "";
  position: absolute;
  inset: -15px;
  border: 1px solid rgba(255, 255, 255, .58);
  border-radius: 50%;
  animation: tafPlayPulse 1.6s infinite;
}

.taf-play span {
  padding: 8px 18px;
  border-radius: 999px;
  background: rgba(0, 0, 0, .26);
  backdrop-filter: blur(6px);
  text-shadow: 0 2px 10px rgba(0, 0, 0, .35);
}

.taf-year-card {
  border-radius: 26px !important;
  background: linear-gradient(145deg, #ffb800, #ff7a00) !important;
  min-height: 190px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.taf-year-card::after {
  content: "";
  position: absolute;
  width: 120px;
  height: 120px;
  right: -44px;
  bottom: -46px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .22);
}

.taf-year-card strong {
  font-size: 46px !important;
  line-height: 1;
}

.taf-year-card span {
  position: relative;
  z-index: 1;
  font-weight: 700;
  line-height: 1.45;
}

.taf-mini-gallery {
  gap: 12px !important;
}

.taf-mini-gallery img {
  height: 136px !important;
  border: 6px solid #fff;
  border-radius: 22px !important;
  box-shadow: 0 16px 35px rgba(0, 0, 0, .12);
}

@keyframes tafPlayPulse {
  0% { transform: scale(.86); opacity: .85; }
  100% { transform: scale(1.18); opacity: 0; }
}

@media(max-width:1024px) {
  .taf-search-desktop { display: none !important; }
}

@media(max-width:991px) {
  .taf-intro-media {
    max-width: 720px;
    margin: 0 auto;
  }
}

@media(max-width:767px) {
  .menu-bar-res .search-res {
    width: 44px !important;
  }
  .menu-bar-res .search-res .search-grid {
    top: 54px !important;
    right: -4px !important;
    height: 44px !important;
    border: 0 !important;
    border-radius: 999px !important;
    box-shadow: 0 14px 36px rgba(0, 0, 0, .14);
  }
  .menu-bar-res .search-res .search-grid input,
  .menu-bar-res .search-res .search-grid p {
    height: 42px !important;
    line-height: 42px !important;
  }
  .taf-intro-media {
    padding: 10px;
    border-radius: 26px;
  }
  .taf-video-card {
    transform: none;
    border-width: 6px;
    border-radius: 24px !important;
  }
  .taf-video-card img {
    height: 280px !important;
  }
  .taf-play i {
    width: 72px !important;
    height: 72px !important;
  }
  .taf-year-card {
    min-height: auto;
    padding: 20px 18px !important;
  }
  .taf-mini-gallery img {
    height: 120px !important;
  }
}

/* ===== Home intro: match supplied reference layout ===== */
.taf-intro {
  padding: 34px 0 36px !important;
  background: #fff !important;
}

.taf-intro .taf-intro-grid {
  grid-template-columns: 35.5% 64.5% !important;
  gap: 26px !important;
  align-items: center !important;
}

.taf-intro .taf-intro-copy {
  padding: 0 !important;
}

.taf-intro .taf-kicker {
  color: #e51d25 !important;
  font-size: 15px !important;
  line-height: 1.2 !important;
  margin-bottom: 7px !important;
  letter-spacing: 0 !important;
  font-weight: 900 !important;
}

.taf-intro .taf-intro-copy h2 {
  color: #111 !important;
  font-size: 27px !important;
  line-height: 1.18 !important;
  margin: 0 0 14px !important;
  font-weight: 900 !important;
}

.taf-intro .taf-richtext {
  max-width: 460px !important;
  color: #202020 !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  line-height: 1.62 !important;
  margin-bottom: 12px !important;
}

.taf-intro .taf-checklist {
  margin: 13px 0 17px !important;
}

.taf-intro .taf-checklist li {
  display: flex !important;
  align-items: flex-start !important;
  gap: 8px !important;
  margin: 7px 0 !important;
  color: #202020 !important;
  font-size: 13.5px !important;
  line-height: 1.25 !important;
  font-weight: 700 !important;
}

.taf-intro .taf-checklist li:before {
  content: "✓" !important;
  flex: 0 0 auto !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  background: transparent !important;
  color: #ff2b2b !important;
  border-radius: 0 !important;
  font-size: 18px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.taf-intro .taf-btn-primary {
  min-width: 152px !important;
  height: 42px !important;
  padding: 0 22px !important;
  border-radius: 5px !important;
  background: #df171d !important;
  box-shadow: 0 8px 18px rgba(223, 23, 29, .22) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  line-height: 42px !important;
}

.taf-intro .taf-btn-primary i {
  display: none !important;
}

.taf-intro .taf-intro-media {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 302px !important;
  gap: 20px !important;
  align-items: stretch !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  isolation: auto !important;
}

.taf-intro .taf-intro-media:before,
.taf-intro .taf-intro-media:after,
.taf-intro .taf-video-card:before,
.taf-intro .taf-year-card:after {
  display: none !important;
}

.taf-intro .taf-video-card {
  grid-row: auto !important;
  height: 267px !important;
  border: 0 !important;
  border-radius: 4px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 14px rgba(0, 0, 0, .14) !important;
  transform: none !important;
}

.taf-intro .taf-video-card:hover {
  transform: none !important;
  box-shadow: 0 4px 14px rgba(0, 0, 0, .14) !important;
}

.taf-intro .taf-video-card img {
  width: 100% !important;
  height: 267px !important;
  display: block !important;
  object-fit: cover !important;
  filter: none !important;
}

.taf-intro .taf-play {
  background: rgba(0, 0, 0, .04) !important;
  color: #fff !important;
}

.taf-intro .taf-play i {
  width: 78px !important;
  height: 78px !important;
  border: 4px solid #fff !important;
  border-radius: 50% !important;
  background: #d82027 !important;
  font-size: 28px !important;
  box-shadow: 0 6px 14px rgba(0, 0, 0, .25) !important;
}

.taf-intro .taf-play i:after {
  display: none !important;
}

.taf-intro .taf-play span {
  margin-top: 9px !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: rgba(255, 255, 255, .78) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, .35) !important;
}

.taf-intro .taf-intro-side {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  height: 267px !important;
}

.taf-intro .taf-year-card,
.taf-intro .taf-intro-thumb {
  min-height: 0 !important;
  height: 128px !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .12) !important;
}

.taf-intro .taf-year-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 10px !important;
  text-align: center !important;
  color: #fff !important;
  background: linear-gradient(135deg, #ffb000, #ffc20d) !important;
}

.taf-intro .taf-year-card strong {
  font-size: 38px !important;
  line-height: .95 !important;
  font-weight: 900 !important;
  margin-bottom: 10px !important;
}

.taf-intro .taf-year-card span {
  max-width: 118px !important;
  font-size: 13px !important;
  line-height: 1.32 !important;
  font-weight: 800 !important;
}

.taf-intro .taf-intro-thumb img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  transition: none !important;
}

.taf-intro .taf-intro-thumb img:hover,
.taf-intro .taf-video-card img:hover {
  transform: none !important;
  filter: none !important;
}

@media (max-width: 1199px) {
  .taf-intro .taf-intro-grid {
    grid-template-columns: 1fr !important;
  }
  .taf-intro .taf-richtext {
    max-width: none !important;
  }
}

@media (max-width: 767px) {
  .taf-intro .taf-intro-media {
    grid-template-columns: 1fr !important;
  }
  .taf-intro .taf-video-card,
  .taf-intro .taf-video-card img {
    height: 230px !important;
  }
  .taf-intro .taf-intro-side {
    height: auto !important;
  }
  .taf-intro .taf-year-card,
  .taf-intro .taf-intro-thumb {
    height: 118px !important;
  }
}


/* TAF v13: Menu món ăn dạng sản phẩm + search giống mẫu */
.taf-menu-product-page { padding: 55px 0; }
.taf-menu-tabs { display:flex; flex-wrap:wrap; justify-content:center; gap:12px; margin:0 auto 34px; }
.taf-menu-tabs a { display:inline-flex; align-items:center; min-height:44px; padding:10px 22px; border-radius:999px; background:#fff; color:#252525; font-weight:800; text-decoration:none!important; border:1px solid rgba(237,28,36,.16); box-shadow:0 10px 28px rgba(0,0,0,.06); transition:all .25s ease; }
.taf-menu-tabs a:hover,.taf-menu-tabs a.active { background:var(--taf-red,#ed1c24); color:#fff; transform:translateY(-2px); box-shadow:0 16px 38px rgba(237,28,36,.22); }
.taf-menu-items-grid { grid-template-columns:repeat(4,minmax(0,1fr)); gap:24px; }
.taf-menu-product-card { position:relative; display:block; overflow:hidden; border-radius:26px; background:#fff; border:1px solid rgba(237,28,36,.10); box-shadow:0 18px 44px rgba(0,0,0,.08); text-decoration:none!important; transition:all .3s ease; }
.taf-menu-product-card:hover { transform:translateY(-6px); box-shadow:0 28px 70px rgba(237,28,36,.16); }
.taf-menu-img { display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; aspect-ratio:4/3; background:#fff; padding:12px; }
.taf-menu-img:after { content:none; }
.taf-menu-img img { width:100%; height:100%; object-fit:contain; display:block; transition:transform .35s ease; }
.taf-menu-product-card:hover .taf-menu-img img { transform:scale(1.03); }
.taf-menu-body { display:block; padding:18px 18px 20px; }
.taf-menu-name { display:block; font-size:18px; line-height:1.35; color:#181818; font-weight:900; min-height:48px; }
.taf-menu-desc { display:block; color:#666; font-weight:600; line-height:1.55; margin-top:8px; min-height:46px; }
.taf-menu-price { display:flex; align-items:center; gap:10px; margin-top:14px; }
.taf-menu-price strong { color:var(--taf-red,#ed1c24); font-size:20px; line-height:1; font-weight:900; }
.taf-menu-price del { color:#999; font-size:14px; }
.taf-menu-detail-card { display:grid; grid-template-columns:1.05fr .95fr; gap:34px; align-items:center; padding:22px; border-radius:34px; background:linear-gradient(135deg,#fff,#fff8f2); box-shadow:0 24px 70px rgba(0,0,0,.1); border:1px solid rgba(237,28,36,.1); }
.taf-menu-detail-photo { display:flex; align-items:center; justify-content:center; overflow:hidden; border-radius:28px; box-shadow:0 18px 45px rgba(0,0,0,.12); background:#fff; padding:14px; }
.taf-menu-detail-photo img { width:100%; height:auto; max-height:540px; min-height:0; object-fit:contain; display:block; }
.taf-menu-detail-info { padding:10px 12px; }
.taf-menu-detail-cat { display:inline-flex; padding:8px 16px; border-radius:999px; background:#fff0ee; color:var(--taf-red,#ed1c24); font-weight:900; text-decoration:none!important; margin-bottom:12px; }
.taf-menu-detail-info h1 { font-size:42px; line-height:1.16; color:#1d1d1d; font-weight:950; margin:0 0 16px; }
.taf-menu-detail-desc { color:#555; font-size:16px; line-height:1.8; font-weight:600; }
.taf-menu-price-detail { display:flex; align-items:flex-end; gap:12px; margin:22px 0; }
.taf-menu-price-detail strong { color:var(--taf-red,#ed1c24); font-size:34px; line-height:1; font-weight:950; }
.taf-menu-price-detail del { color:#999; font-size:18px; }
.taf-menu-detail-actions { display:flex; flex-wrap:wrap; gap:12px; }
.taf-btn-red,.taf-btn-light { display:inline-flex; align-items:center; gap:8px; min-height:48px; padding:12px 22px; border-radius:16px; font-weight:900; text-decoration:none!important; transition:all .25s ease; }
.taf-btn-red { background:var(--taf-red,#ed1c24); color:#fff!important; box-shadow:0 14px 34px rgba(237,28,36,.22); }
.taf-btn-light { background:#fff; color:#1d1d1d!important; border:1px solid rgba(237,28,36,.18); }
.taf-btn-red:hover,.taf-btn-light:hover { transform:translateY(-2px); }
.taf-menu-gallery { display:grid; grid-template-columns:repeat(6,1fr); gap:12px; margin-top:20px; }
.taf-menu-gallery a { display:flex; align-items:center; justify-content:center; border-radius:18px; overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,.08); background:#fff; padding:8px; }
.taf-menu-gallery img { width:100%; height:120px; object-fit:contain; display:block; }
.taf-menu-content { margin-top:28px; padding:24px; border-radius:24px; background:#fff; box-shadow:0 14px 40px rgba(0,0,0,.06); line-height:1.8; }
.taf-menu-section-title { margin:38px 0 20px; text-align:center; }
.taf-menu-section-title span { display:inline-flex; font-size:28px; font-weight:950; color:#1d1d1d; }
.menu-main > li > a.taf-header-quote + .taf-search-desktop { margin-left:4px; }
.taf-header-search .icon-search, .menu-bar-res .search-res .icon-search { background:#fff!important; border:4px solid var(--taf-red,#ed1c24)!important; color:var(--taf-red,#ed1c24)!important; box-shadow:none!important; font-size:21px!important; }
.taf-header-search .icon-search i, .menu-bar-res .search-res .icon-search i { font-weight:900; }
@media(max-width:1024px){ .taf-menu-items-grid{grid-template-columns:repeat(3,minmax(0,1fr));} }
@media(max-width:767px){ .taf-menu-product-page{padding:35px 0;} .taf-menu-items-grid{grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px;} .taf-menu-body{padding:14px;} .taf-menu-name{font-size:15px; min-height:42px;} .taf-menu-desc{display:none;} .taf-menu-price strong{font-size:17px;} .taf-menu-tabs{justify-content:flex-start; overflow-x:auto; flex-wrap:nowrap; padding-bottom:8px;} .taf-menu-tabs a{white-space:nowrap;} .taf-menu-detail-card{grid-template-columns:1fr; gap:18px; padding:14px; border-radius:24px;} .taf-menu-detail-photo{padding:10px;} .taf-menu-detail-photo img{max-height:320px;} .taf-menu-detail-info h1{font-size:30px;} .taf-menu-gallery{grid-template-columns:repeat(3,1fr);} .taf-menu-gallery img{height:88px;} .menu-bar-res .search-res .icon-search{width:52px!important; height:52px!important; line-height:44px!important; font-size:24px!important;} }

/* TAF v14: hiện nút tìm kiếm nhanh cạnh logo mobile và sau nút nhận báo giá PC */
.taf-search-desktop,
.menu-main > li.taf-search-desktop {
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:54px !important;
  min-width:54px !important;
  margin-left:8px !important;
  position:relative !important;
  z-index:50 !important;
}
.menu-main > li.taf-search-desktop .taf-header-search {
  display:block !important;
  float:none !important;
  width:52px !important;
  height:52px !important;
  position:relative !important;
  z-index:55 !important;
}
.taf-search-trigger,
.taf-header-search .icon-search,
.menu-bar-res .taf-mobile-search .icon-search {
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:52px !important;
  height:52px !important;
  min-width:52px !important;
  min-height:52px !important;
  line-height:52px !important;
  padding:0 !important;
  margin:0 !important;
  border:4px solid var(--taf-red,#ed1c24) !important;
  border-radius:50% !important;
  background:#fff !important;
  color:var(--taf-red,#ed1c24) !important;
  box-shadow:none !important;
  cursor:pointer !important;
  opacity:1 !important;
  visibility:visible !important;
}
.taf-search-icon-shape {
  position:relative;
  display:block;
  width:21px;
  height:21px;
  border:4px solid currentColor;
  border-radius:50%;
  box-sizing:border-box;
  transform:translate(-2px,-2px);
}
.taf-search-icon-shape:after {
  content:"";
  position:absolute;
  width:15px;
  height:4px;
  border-radius:999px;
  background:currentColor;
  right:-12px;
  bottom:-7px;
  transform:rotate(45deg);
  transform-origin:left center;
}
.taf-search-icon-shape.small {
  width:15px;
  height:15px;
  border-width:3px;
  transform:translate(-1px,-1px);
}
.taf-search-icon-shape.small:after {
  width:10px;
  height:3px;
  right:-8px;
  bottom:-5px;
}
.icon-search i { display:none !important; }
.taf-header-search .search-grid {
  top:58px !important;
  right:0 !important;
  z-index:9999 !important;
}
.taf-mobile-brand-search {
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:18px !important;
  margin:0 auto !important;
  position:relative !important;
  z-index:20 !important;
}
.taf-mobile-brand-search .logo_mobi {
  margin:0 !important;
  padding:0 !important;
}
.taf-mobile-brand-search .taf-mobile-search {
  display:block !important;
  position:relative !important;
  float:none !important;
  right:auto !important;
  top:auto !important;
  transform:none !important;
  width:52px !important;
  height:52px !important;
  z-index:35 !important;
}
.taf-mobile-brand-search .taf-mobile-search .search-grid {
  top:60px !important;
  right:0 !important;
  z-index:9999 !important;
}
@media(max-width:1024px){
  .menu-main > li.taf-search-desktop,
  .taf-search-desktop { display:none !important; }
}
@media(max-width:767px){
  .menu-bar-res { height:88px !important; padding:0 16px !important; }
  .menu-bar-res .search-res { position:relative !important; right:auto !important; top:auto !important; transform:none !important; }
  .menu-bar-res .taf-mobile-search .icon-search { width:56px !important; height:56px !important; min-width:56px !important; min-height:56px !important; line-height:56px !important; }
  .taf-mobile-brand-search { gap:20px !important; }
  .taf-mobile-brand-search .logo_mobi img { max-width:92px !important; max-height:70px !important; }
  .taf-mobile-brand-search .taf-mobile-search .search-grid { right:-12px !important; }
}


/* TAF v15: cân đối icon tìm kiếm + phóng to ảnh menu, giảm lề */
:root {
  --taf-search-btn-size: 58px;
  --taf-search-btn-border: 4px;
  --taf-search-icon-size: 23px;
  --taf-search-icon-stroke: 4px;
}

.menu-main > li.taf-search-desktop,
.taf-search-desktop {
  width: var(--taf-search-btn-size) !important;
  min-width: var(--taf-search-btn-size) !important;
  margin-left: 6px !important;
}

.menu-main > li.taf-search-desktop .taf-header-search,
.taf-mobile-brand-search .taf-mobile-search {
  width: var(--taf-search-btn-size) !important;
  height: var(--taf-search-btn-size) !important;
}

.taf-search-trigger,
.taf-header-search .icon-search,
.menu-bar-res .taf-mobile-search .icon-search {
  width: var(--taf-search-btn-size) !important;
  height: var(--taf-search-btn-size) !important;
  min-width: var(--taf-search-btn-size) !important;
  min-height: var(--taf-search-btn-size) !important;
  line-height: var(--taf-search-btn-size) !important;
  border-width: var(--taf-search-btn-border) !important;
}

.taf-search-icon-shape {
  width: var(--taf-search-icon-size);
  height: var(--taf-search-icon-size);
  border-width: var(--taf-search-icon-stroke);
  transform: translate(-2px,-2px);
}

.taf-search-icon-shape:before {
  content: "";
  position: absolute;
  top: 1px;
  right: 0;
  width: 9px;
  height: 4px;
  border-radius: 999px;
  background: currentColor;
  transform: rotate(14deg);
  box-shadow: -10px -4px 0 -1px currentColor;
}

.taf-search-icon-shape:after {
  width: 17px;
  height: 5px;
  right: -14px;
  bottom: -8px;
}

.taf-search-icon-shape.small {
  width: 16px;
  height: 16px;
  border-width: 3px;
}

.taf-search-icon-shape.small:before {
  width: 6px;
  height: 3px;
  top: 1px;
  box-shadow: -7px -3px 0 -1px currentColor;
}

.taf-search-icon-shape.small:after {
  width: 11px;
  height: 3px;
  right: -9px;
  bottom: -5px;
}

.taf-mobile-brand-search {
  gap: 16px !important;
}

.taf-mobile-brand-search .logo_mobi img {
  max-width: 96px !important;
  max-height: 74px !important;
}

.taf-menu-product-page {
  padding: 40px 0 34px;
}

.taf-menu-tabs {
  gap: 10px;
  margin: 0 auto 26px;
}

.taf-menu-items-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.taf-menu-product-card {
  border-radius: 22px;
}

.taf-menu-img {
  aspect-ratio: 1 / 1;
  padding: 8px;
}

.taf-menu-body {
  padding: 14px 14px 16px;
}

.taf-menu-name {
  min-height: 0;
  font-size: 20px;
}

.taf-menu-desc {
  margin-top: 6px;
  min-height: 0;
}

.taf-menu-price {
  margin-top: 10px;
}

.taf-menu-detail-card {
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, .8fr);
  gap: 20px;
  padding: 14px;
  border-radius: 28px;
}

.taf-menu-detail-photo {
  padding: 8px;
  border-radius: 22px;
}

.taf-menu-detail-photo img {
  max-height: 680px;
}

.taf-menu-detail-info {
  padding: 8px 4px;
}

.taf-menu-detail-info h1 {
  margin: 0 0 12px;
}

.taf-menu-gallery {
  gap: 10px;
  margin-top: 14px;
}

.taf-menu-gallery a {
  padding: 6px;
  border-radius: 14px;
}

.taf-menu-gallery img {
  height: 150px;
}

.taf-menu-content {
  margin-top: 18px;
  padding: 18px;
  border-radius: 20px;
}

@media (max-width: 1200px) {
  .taf-menu-items-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
  }
}

@media (max-width: 1024px) {
  .taf-menu-items-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .taf-menu-detail-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  :root {
    --taf-search-btn-size: 56px;
    --taf-search-icon-size: 22px;
  }

  .menu-bar-res {
    position: relative !important;
    height: 88px !important;
    padding: 0 14px !important;
  }

  .taf-mobile-brand-search {
    width: calc(100% - 54px) !important;
    margin: 0 0 0 54px !important;
    gap: 0 !important;
    justify-content: center !important;
  }

  .taf-mobile-brand-search .logo_mobi {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
  }

  .taf-mobile-brand-search .logo_mobi img {
    max-width: 92px !important;
    max-height: 70px !important;
  }

  .taf-mobile-brand-search .taf-mobile-search {
    position: absolute !important;
    right: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
  }

  .taf-menu-product-page {
    padding: 32px 0 28px;
  }

  .taf-menu-items-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .taf-menu-img {
    padding: 6px;
  }

  .taf-menu-body {
    padding: 12px;
  }

  .taf-menu-name {
    font-size: 16px;
  }

  .taf-menu-detail-card {
    padding: 12px;
    gap: 14px;
    border-radius: 22px;
  }

  .taf-menu-detail-photo img {
    max-height: 460px;
  }

  .taf-menu-gallery img {
    height: 100px;
  }

  .taf-menu-content {
    padding: 14px;
  }
}


/* TAF v16: làm đẹp icon tìm kiếm desktop/mobile bằng SVG */
.taf-search-trigger,
.taf-header-search .icon-search,
.menu-bar-res .taf-mobile-search .icon-search {
  overflow: hidden !important;
  transition: all .25s ease !important;
}

.taf-search-trigger:hover,
.taf-header-search .icon-search:hover,
.menu-bar-res .taf-mobile-search .icon-search:hover,
.taf-search-trigger.active,
.taf-header-search .icon-search.active,
.menu-bar-res .taf-mobile-search .icon-search.active {
  background: #fff5f4 !important;
  box-shadow: 0 10px 24px rgba(237,28,36,.16) !important;
  transform: translateY(-1px);
}

.taf-search-svg {
  width: 31px;
  height: 31px;
  display: block;
  color: currentColor;
  overflow: visible;
}

.taf-search-svg--small {
  width: 18px;
  height: 18px;
}

.taf-search-icon-shape,
.taf-search-icon-shape:before,
.taf-search-icon-shape:after,
.taf-search-icon-shape.small,
.taf-search-icon-shape.small:before,
.taf-search-icon-shape.small:after {
  display: none !important;
  content: none !important;
}

.taf-header-search .search-grid,
.taf-mobile-search .search-grid {
  min-width: 280px;
  border: 1px solid rgba(237,28,36,.14) !important;
  border-radius: 16px !important;
  box-shadow: 0 18px 38px rgba(18,18,18,.12) !important;
  background: #fff !important;
  padding: 8px !important;
}

.taf-header-search .search-grid input,
.taf-mobile-search .search-grid input {
  height: 44px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(237,28,36,.12) !important;
  padding: 0 14px !important;
  font-size: 14px !important;
}

.taf-header-search .search-grid p,
.taf-mobile-search .search-grid p {
  width: 46px !important;
  height: 44px !important;
  min-width: 46px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 12px !important;
  background: var(--taf-red,#ed1c24) !important;
  color: #fff !important;
  margin: 0 !important;
  cursor: pointer !important;
  transition: all .2s ease !important;
}

.taf-header-search .search-grid p:hover,
.taf-mobile-search .search-grid p:hover {
  background: #c9151c !important;
}

.menu-main > li.taf-search-desktop,
.taf-search-desktop {
  margin-left: 10px !important;
}

@media (max-width: 767px) {
  .taf-search-svg {
    width: 29px;
    height: 29px;
  }
  .taf-mobile-search .search-grid {
    min-width: 250px;
  }
}


/* TAF v17: sửa dứt điểm header search desktop/mobile cân đối */
:root {
  --taf-nav-font: 15px;
  --taf-nav-gap: 2px;
  --taf-nav-pad-x: 12px;
  --taf-nav-height: 40px;
  --taf-quote-pad-x: 16px;
  --taf-search-size-pc: 44px;
  --taf-search-size-mobile: 48px;
}

.menu .wrap-content {
  overflow: visible !important;
}

.menu-main {
  gap: var(--taf-nav-gap) !important;
}

.menu-main > li > a {
  min-height: var(--taf-nav-height) !important;
  padding: 0 var(--taf-nav-pad-x) !important;
  font-size: var(--taf-nav-font) !important;
}

.menu-main .taf-header-quote {
  min-height: 42px !important;
  padding: 0 var(--taf-quote-pad-x) !important;
  font-size: 15px !important;
}

.menu-main > li.taf-search-desktop,
.taf-search-desktop {
  width: var(--taf-search-size-pc) !important;
  min-width: var(--taf-search-size-pc) !important;
  margin-left: 8px !important;
  flex: 0 0 var(--taf-search-size-pc) !important;
}

.menu-main > li.taf-search-desktop .taf-header-search {
  width: var(--taf-search-size-pc) !important;
  height: var(--taf-search-size-pc) !important;
}

.taf-header-search .icon-search {
  width: var(--taf-search-size-pc) !important;
  height: var(--taf-search-size-pc) !important;
  min-width: var(--taf-search-size-pc) !important;
  min-height: var(--taf-search-size-pc) !important;
  line-height: var(--taf-search-size-pc) !important;
  border-width: 3px !important;
}

.taf-search-svg {
  width: 24px !important;
  height: 24px !important;
}

.taf-search-svg--small {
  width: 16px !important;
  height: 16px !important;
}

.taf-header-search .search-grid {
  top: 52px !important;
  right: 0 !important;
  left: auto !important;
  min-width: 250px !important;
  width: 250px !important;
}

.taf-header-search .search-grid input {
  width: calc(100% - 54px) !important;
}

@media (max-width: 1366px) {
  :root {
    --taf-nav-font: 14px;
    --taf-nav-pad-x: 10px;
    --taf-quote-pad-x: 14px;
    --taf-search-size-pc: 42px;
  }

  .menu-main .taf-header-quote {
    font-size: 14px !important;
  }
}

@media (max-width: 767px) {
  .menu-bar-res {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 84px !important;
    padding: 0 12px !important;
  }

  .menu-bar-res #hamburger {
    left: 12px !important;
  }

  .taf-mobile-brand-search {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 58px !important;
    justify-content: center !important;
    align-items: center !important;
  }

  .taf-mobile-brand-search .logo_mobi {
    width: auto !important;
    flex: 0 0 auto !important;
  }

  .taf-mobile-brand-search .logo_mobi img {
    max-width: 88px !important;
    max-height: 66px !important;
  }

  .taf-mobile-brand-search .taf-mobile-search,
  .menu-bar-res .search-res {
    position: absolute !important;
    right: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: var(--taf-search-size-mobile) !important;
    height: var(--taf-search-size-mobile) !important;
    min-width: var(--taf-search-size-mobile) !important;
    min-height: var(--taf-search-size-mobile) !important;
  }

  .menu-bar-res .taf-mobile-search .icon-search {
    width: var(--taf-search-size-mobile) !important;
    height: var(--taf-search-size-mobile) !important;
    min-width: var(--taf-search-size-mobile) !important;
    min-height: var(--taf-search-size-mobile) !important;
    line-height: var(--taf-search-size-mobile) !important;
    border-width: 3px !important;
  }

  .taf-mobile-search .taf-search-svg,
  .menu-bar-res .taf-mobile-search .taf-search-svg {
    width: 22px !important;
    height: 22px !important;
  }

  .taf-mobile-search .search-grid {
    top: 58px !important;
    right: 0 !important;
    left: auto !important;
    width: min(260px, calc(100vw - 24px)) !important;
    min-width: 0 !important;
    max-width: calc(100vw - 24px) !important;
    padding: 6px !important;
    border-radius: 14px !important;
  }

  .taf-mobile-search .search-grid input {
    width: calc(100% - 50px) !important;
    height: 42px !important;
    font-size: 14px !important;
  }

  .taf-mobile-search .search-grid p {
    width: 44px !important;
    height: 42px !important;
    min-width: 44px !important;
  }
}

/* TAF v18: fix loi khong bam duoc menu mobile */
@media (max-width: 767px) {
  .menu-bar-res {
    position: relative !important;
  }

  .menu-bar-res #hamburger {
    position: absolute !important;
    left: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 999999 !important;
    pointer-events: auto !important;
  }

  .taf-mobile-brand-search {
    pointer-events: none !important;
    z-index: 20 !important;
  }

  .taf-mobile-brand-search .logo_mobi,
  .taf-mobile-brand-search .logo_mobi *,
  .taf-mobile-brand-search .taf-mobile-search,
  .taf-mobile-brand-search .taf-mobile-search *,
  .menu-bar-res .search-res,
  .menu-bar-res .search-res * {
    pointer-events: auto !important;
  }

  .menu-res nav#menu,
  nav#menu,
  .mm-menu,
  .mm-wrapper__blocker,
  .mm-slideout {
    z-index: auto;
  }
}

/* TAF fix 2026-05-12: mobile home sections show 2 cards per row */
@media (max-width: 767px) {
  .taf-why .taf-why-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .taf-why .taf-why-card {
    padding: 16px 10px !important;
    border-radius: 18px !important;
    min-width: 0 !important;
  }

  .taf-why .taf-icon {
    width: 42px !important;
    height: 42px !important;
    margin-bottom: 10px !important;
  }

  .taf-why .taf-why-card h3 {
    font-size: 14px !important;
    line-height: 1.35 !important;
  }

  .taf-why .taf-why-card p {
    font-size: 12px !important;
    line-height: 1.45 !important;
  }

  .taf-process .taf-process-row {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
    overflow: visible !important;
    padding-bottom: 0 !important;
    scroll-snap-type: none !important;
  }

  .taf-process .taf-process-item {
    min-width: 0 !important;
    width: auto !important;
    flex: none !important;
    flex-basis: auto !important;
    padding: 18px 12px !important;
    border-radius: 22px !important;
    scroll-snap-align: none !important;
  }

  .taf-process .taf-process-top {
    gap: 8px !important;
  }

  .taf-process .taf-process-icon {
    width: 56px !important;
    height: 56px !important;
    border-radius: 16px !important;
  }

  .taf-process .taf-process-icon img {
    max-width: 36px !important;
    max-height: 36px !important;
  }

  .taf-process .taf-process-number {
    width: 46px !important;
    height: 46px !important;
    font-size: 18px !important;
  }

  .taf-process .taf-process-item h3 {
    font-size: 16px !important;
    line-height: 1.32 !important;
  }

  .taf-process .taf-process-item p {
    font-size: 12px !important;
    line-height: 1.45 !important;
  }
}

@media (max-width: 380px) {
  .taf-why .taf-why-grid,
  .taf-process .taf-process-row {
    gap: 10px !important;
  }

  .taf-why .taf-why-card,
  .taf-process .taf-process-item {
    padding-left: 9px !important;
    padding-right: 9px !important;
  }

  .taf-process .taf-process-icon {
    width: 50px !important;
    height: 50px !important;
  }

  .taf-process .taf-process-number {
    width: 42px !important;
    height: 42px !important;
    font-size: 16px !important;
  }
}


/* TAF v20: dịch vụ - hiển thị full ảnh, không crop + xoá khối liên hệ trùng */
.left-pro-detail .MagicZoom,
.left-pro-detail .pic-product,
.left-pro-detail .thumb-pro-detail,
.pic-product,
.pic-news,
.pic-album {
    background: #fff !important;
}

.left-pro-detail .MagicZoom img,
.left-pro-detail .thumb-pro-detail img,
.productTop1_fotorama img,
.fotorama img,
.pic-product img,
.box-product img,
.pic-news img,
.pic-album img,
.scale-img img,
.scale_a img {
    object-fit: contain !important;
    background: #fff !important;
}

.pic-product,
.box-product .pic-product {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
}

.left-pro-detail .MagicZoom img,
.productTop1_fotorama img,
.fotorama img {
    width: 100% !important;
    height: auto !important;
    max-height: 560px !important;
}

.gallery-thumb-pro .thumb-pro-detail img,
.owl-pro-detail .thumb-pro-detail img {
    width: 100% !important;
    height: 74px !important;
    object-fit: contain !important;
}

#toc-content .desc-pro-detail,
#toc-content .taf-contact-block,
#toc-content .detail-contact-box,
#toc-content .service-contact-box {
    display: none !important;
}

@media (max-width: 767px) {
    .left-pro-detail .MagicZoom img,
    .productTop1_fotorama img,
    .fotorama img {
        max-height: 360px !important;
    }
    .gallery-thumb-pro .thumb-pro-detail img,
    .owl-pro-detail .thumb-pro-detail img {
        height: 62px !important;
    }
}

/* Fix danh sách dịch vụ: ảnh bằng khung tiêu đề và tiêu đề hiển thị đầy đủ */
.boxProduct .box-product {
    width: 100%;
    max-width: 290px;
    margin: 0 auto;
}

.boxProduct .pic-product,
.boxProduct .box-product .pic-product {
    width: 100% !important;
    aspect-ratio: 1 / 1;
    height: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    overflow: hidden !important;
}

.boxProduct .pic-product img,
.boxProduct .box-product img {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    display: block !important;
    margin: 0 auto !important;
}

.boxProduct .info_product {
    width: 100%;
    min-height: 78px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 12px 10px;
}

.boxProduct .name-product.text-split,
.boxProduct .name-product {
    display: block !important;
    overflow: visible !important;
    text-overflow: unset !important;
    -webkit-line-clamp: unset !important;
    -webkit-box-orient: unset !important;
    white-space: normal !important;
    line-height: 1.35;
    margin-bottom: 6px;
}

@media (max-width: 767px) {
    .boxProduct .box-product {
        max-width: 100%;
    }
}

/* Fix icon chia sẻ bị lỗi ảnh ngoài */
.social-plugin,
.social-plugin-pro-detail {
    align-items: center !important;
    gap: 8px;
    flex-wrap: wrap;
}

.taf-share-buttons {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    flex-wrap: wrap;
}

.taf-share-btn {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff !important;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none !important;
    line-height: 1;
}

.taf-share-facebook { background: #1877f2; }
.taf-share-zalo { background: #0068ff; font-size: 11px; }
.taf-share-twitter { background: #111; }

.taf-share-btn:hover {
    color: #fff !important;
    opacity: .88;
}

.social-plugin .addthis_inline_share_toolbox_dc09,
.social-plugin .zalo-share-button {
    display: none !important;
}

/* TAF final: service/home images full, admin desc, combo 2-line desc, contact duplicate cleanup */
.taf-service-card {
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

.taf-service-img {
    width: 100% !important;
    aspect-ratio: 4 / 3 !important;
    min-height: 0 !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    padding: 8px !important;
    overflow: hidden !important;
}

.taf-service-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    display: block !important;
}

.taf-service-body {
    width: 100% !important;
}

.taf-service-body h3,
.taf-service-body h3 a {
    display: block !important;
    overflow: visible !important;
    text-overflow: unset !important;
    -webkit-line-clamp: unset !important;
    white-space: normal !important;
    line-height: 1.25 !important;
}

.taf-service-body p {
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    min-height: auto !important;
}

.taf-combo-card {
    display: block !important;
    overflow: hidden !important;
}

.taf-combo-card img {
    width: 100% !important;
    height: 150px !important;
    object-fit: contain !important;
    background: #fff !important;
    padding: 6px !important;
    display: block !important;
}

.taf-combo-card strong {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    min-height: 38px !important;
}

.taf-combo-card span {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    line-height: 1.45 !important;
    min-height: 40px !important;
}

/* Ẩn phần liên hệ admin nếu còn sót để tránh hiện 2 lần */
.taf-contact-info .taf-admin-contact {
    display: none !important;
}

@media (max-width: 767px) {
    .taf-service-img {
        padding: 6px !important;
    }
    .taf-combo-card img {
        height: 125px !important;
    }
}


/* TAF v19: sửa nút menu mobile mở menu được, không bị logo/search che */
@media (max-width: 767px) {
  .menu-res,
  .menu-bar-res {
    position: relative !important;
    z-index: 99999 !important;
  }

  .menu-bar-res #hamburger {
    display: block !important;
    position: absolute !important;
    left: 16px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 48px !important;
    height: 30px !important;
    z-index: 1000000 !important;
    pointer-events: auto !important;
    cursor: pointer !important;
    touch-action: manipulation !important;
  }

  .menu-bar-res #hamburger:before,
  .menu-bar-res #hamburger:after,
  .menu-bar-res #hamburger span {
    height: 4px !important;
    border-radius: 4px !important;
    background: #ed1c24 !important;
  }

  .menu-bar-res #hamburger:before { top: 1px !important; }
  .menu-bar-res #hamburger span { top: 13px !important; }
  .menu-bar-res #hamburger:after { top: 25px !important; }

  .taf-mobile-brand-search {
    pointer-events: none !important;
  }

  .taf-mobile-brand-search .logo_mobi,
  .taf-mobile-brand-search .logo_mobi *,
  .taf-mobile-brand-search .taf-mobile-search,
  .taf-mobile-brand-search .taf-mobile-search *,
  .menu-bar-res .search-res,
  .menu-bar-res .search-res * {
    pointer-events: auto !important;
  }

  nav#menu.mm-menu,
  .mm-menu_position-left,
  .mm-menu_position-front {
    z-index: 1000001 !important;
  }

  .mm-wrapper__blocker {
    z-index: 1000000 !important;
  }

  .mm-wrapper_opened .mm-menu_opened {
    display: block !important;
  }
}


/* TAF PATCH 2026-05-27: fix menu cấp 2/cấp 3 hiển thị khi rê chuột */
@media (min-width:1025px){
  .taf-header,
  .taf-header .wap_1200,
  .taf-header-inner,
  .taf-header .menu,
  .taf-header .menu .wrap-content,
  .taf-header .menu-main,
  .taf-header .menu-main>li{
    overflow:visible!important;
  }
  .taf-header{z-index:99999!important;}
  .taf-header .menu-main>li{position:relative!important;z-index:20!important;}
  .taf-header .menu-main>li:hover{z-index:999!important;}
  .taf-header .menu-main li ul{
    position:absolute!important;
    display:block!important;
    width:auto!important;
    min-width:255px!important;
    max-width:none!important;
    margin:0!important;
    padding:14px 0!important;
    background:#fff!important;
    border:1px solid rgba(237,28,36,.12)!important;
    border-radius:18px!important;
    box-shadow:0 24px 55px rgba(0,0,0,.16)!important;
    overflow:visible!important;
    list-style:none!important;
    opacity:0!important;
    visibility:hidden!important;
    pointer-events:none!important;
    transform:translateY(14px) scale(.98)!important;
    transform-origin:top left!important;
    transition:opacity .22s ease,visibility .22s ease,transform .22s ease!important;
    z-index:9999!important;
  }
  .taf-header .menu-main>li>ul{
    top:100%!important;
    left:0!important;
    margin-top:8px!important;
  }
  .taf-header .menu-main>li>ul:before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:-12px;
    height:14px;
    background:transparent;
  }
  .taf-header .menu-main li:hover>ul,
  .taf-header .menu-main li:focus-within>ul{
    opacity:1!important;
    visibility:visible!important;
    pointer-events:auto!important;
    transform:translateY(0) scale(1)!important;
  }
  .taf-header .menu-main ul li{
    position:relative!important;
    display:block!important;
    width:100%!important;
    min-width:255px!important;
    padding:0 14px!important;
    margin:0!important;
    white-space:nowrap!important;
    list-style:none!important;
  }
  .taf-header .menu-main ul li ul{
    top:-14px!important;
    left:100%!important;
    margin-left:8px!important;
    transform:translateX(14px) scale(.98)!important;
  }
  .taf-header .menu-main ul li:hover>ul,
  .taf-header .menu-main ul li:focus-within>ul{
    transform:translateX(0) scale(1)!important;
  }
  .taf-header .menu-main ul li ul:before{
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    left:-10px;
    width:12px;
    background:transparent;
  }
  .taf-header .menu-main ul li a{
    position:relative!important;
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:14px!important;
    width:100%!important;
    min-height:46px!important;
    padding:0 16px!important;
    border-radius:14px!important;
    border-bottom:1px solid rgba(0,0,0,.06)!important;
    color:#2b2b2f!important;
    background:transparent!important;
    font-size:16px!important;
    font-weight:800!important;
    line-height:1.25!important;
    text-decoration:none!important;
    text-transform:none!important;
    transition:all .2s ease!important;
  }
  .taf-header .menu-main ul li:last-child>a{border-bottom:0!important;}
  .taf-header .menu-main ul li:hover>a,
  .taf-header .menu-main ul li>a:hover,
  .taf-header .menu-main ul li:focus-within>a{
    color:var(--taf-red,#ed1c24)!important;
    background:#fff3f3!important;
    box-shadow:inset 4px 0 0 var(--taf-red,#ed1c24)!important;
  }
  .taf-header .menu-main ul li>a.has-child:after{
    content:"\f105"!important;
    font-family:"Font Awesome 6 Free","Font Awesome 5 Free"!important;
    font-weight:900!important;
    position:static!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    flex:0 0 auto!important;
    width:18px!important;
    height:18px!important;
    border:0!important;
    transform:none!important;
    color:var(--taf-red,#ed1c24)!important;
    opacity:.75!important;
  }
  .taf-header .menu-main>li>a.has-child:after{display:none!important;}
}
