@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Geist:wght@400;600;800&display=swap");
.messages {
  display: none !important;
}

.region-content {
  background: #fff;
}

.breadcrumb-nav {
  margin: 1.5rem 0 1.5rem 0;
}

.breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  background: none;
}

.breadcrumb-item {
  color: var(--blue);
  font-size: 0.97rem;
  font-weight: 500;
  margin-right: 0.5rem;
  display: flex;
  align-items: center;
}

.breadcrumb-item:not(:last-child)::after {
  content: "/";
  color: var(--accent);
  margin-left: 0.5rem;
}

.breadcrumb-item a {
  color: var(--blue);
  text-decoration: none;
  transition: color 0.2s;
}

.breadcrumb-item a:hover {
  color: var(--accent);
}

.breadcrumb-current {
  color: #222;
  font-weight: 700;
}

.rights-reserved {
  background: #fff;
  color: #111;
  text-align: center;
  border-radius: 0;
  box-shadow: none;
  padding: 0.7rem 0 0.7rem 0;
  font-size: 0.9rem;
}

.footer-logo {
  height: 110px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.footer-brand {
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
}

body {
  font-family: "Geist", "Arial", "Helvetica", sans-serif;
  font-weight: 400;
}

h2,
h3,
h4,
h5,
h6 {
  font-weight: 800;
}

body,
p,
li,
td,
th,
.body-text,
.service-page-body {
  font-family: "Geist", "Helvetica", "Arial", sans-serif;
  font-weight: 400;
}

.ck-content h1,
.ck-content h2,
.ck-content h3,
.ck-content h4,
.ck-content h5,
.ck-content h6 {
  font-weight: 800;
}

h2 {
  font-family: "Geist", "Helvetica", "Arial", sans-serif !important;
  font-weight: 800 !important;
}

h4 {
  font-size: 21px;
}

.navbar .navbar-nav .nav-link,
nav.navbar .navbar-nav .nav-link {
  font-weight: 500;
}

/* Parent dropdown item */
.navbar-nav .dropdown:hover > .dropdown-menu {
  display: block;
  opacity: 1;
  visibility: visible;
  transition-delay: 0.2s;
  /* delay before opening */
}

/* Remove Bootstrap’s toggle arrow behavior */
.navbar-nav .dropdown-toggle::after {
  display: none;
}

/* Prevent click requirement */
.navbar-nav .dropdown > .nav-link.dropdown-toggle {
  pointer-events: none;
}

/* Smooth menu behavior */
.navbar-nav .dropdown-menu {
  margin-top: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
  transition-delay: 0s;
  /* reset for hide */
}

/* Small close delay to avoid flicker */
.navbar-nav .dropdown:not(:hover) > .dropdown-menu {
  opacity: 0;
  visibility: hidden;
  transition-delay: 0.15s;
  /* delay before closing */
}

/* Base reset */
.navbar-nav .nav-link {
  position: relative;
  display: inline-block;
  padding: 0 !important;
  text-decoration: none;
  margin-left: 20px !important;
}

/* Hover underline effect like satilesanddecor.com.au */
.navbar-nav .nav-link::after {
  content: "";
  position: absolute;
  bottom: 12px;
  /* space below text */
  left: 0;
  width: 0%;
  height: 2.5px;
  background-color: #ed1c24;
  /* gold color like the sample site */
  transition: width 0.35s ease-in-out;
}

/* On hover */
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after {
  width: 100%;
}

.nav-link:focus,
.nav-link:hover {
  color: #fff !important;
}

.navbar-nav button.nav-link::after {
  display: none;
}

.navbar-nav .dropdown .nav-link::after {
  display: none;
}

.navbar-expand-lg .navbar-nav .dropdown-menu {
  top: 80% !important;
}

.navbar-nav .nav-link {
  padding: 15px 0px !important;
}

:root {
  --dark: #000000;
  --blue: #043372;
  --accent: #ed1c24;
  --muted: #f6f0df;
  --card: #ffffff;
  --nav-height: 100px;
  --hero-yellow: #ed1c24;
  --arrow-blue: #033f7b;
  --card-dark: rgba(0, 0, 0, 0.51);
  --card-dark-new: rgba(0, 0, 0, 0.77);
  --number-yellow: #ed1c24;
  --speed-px-per-sec: 70;
}

.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: #043372;
  --bs-btn-border-color: #043372;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #053b83;
  --bs-btn-hover-border-color: #053b83;
  --bs-btn-focus-shadow-rgb: 49, 132, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #043372;
  --bs-btn-active-border-color: #043372;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #053b83;
  --bs-btn-disabled-border-color: #053b83;
}

.btn-outline-primary,
.node-preview-container .node-preview-backlink {
  --bs-btn-color: #043372;
  --bs-btn-border-color: #043372;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #043372;
  --bs-btn-hover-border-color: #043372;
  --bs-btn-focus-shadow-rgb: 13, 110, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #043372;
  --bs-btn-active-border-color: #043372;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #043372;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #043372;
  --bs-gradient: none;
}

body {
  background: linear-gradient(180deg, #2a2a2a 0%, #1f1f1f 45%);
  color: #fff;
  font-family: "Geist", "Helvetica", "Arial", sans-serif;
}

h1 {
  font-size: 48px;
  font-weight: bold;
}

h2 {
  font-size: 40px;
  font-weight: 800;
}

p {
  font-size: 20px;
  font-weight: 400;
}

.site-nav {
  height: var(--nav-height);
  background: #000000;
}

.navbar {
  background: #000;
  box-shadow: 20px 2px 20px #313131;
  z-index: 99;
}

.navbar-nav .nav-link {
  color: #fff;
  margin: 0 8px;
  font-size: 18px;
  font-weight: 500;
}

.navbar-nav .nav-link.active {
  color: var(--accent);
}

.icon-btn {
  background: #2c2c2c;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 10px;
  color: var(--accent);
  font-size: 17px;
  text-decoration: none;
  position: relative;
  /* required for tooltip */
  cursor: pointer;
}

.login-btn {
  background: #2c2c2c !important;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 10px;
  color: var(--accent) !important;
  font-size: 18px;
  text-decoration: none;
  position: relative;
  /* required for tooltip */
  cursor: pointer;
  width: fit-content;
}

.icon-btn-123 {
  background: #2c2c2c;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 10px;
  color: var(--accent);
  font-size: 18px;
  text-decoration: none;
  position: relative;
  cursor: pointer;
}

.icon-btn .tooltip-text {
  visibility: hidden;
  opacity: 0;
  width: auto;
  background: #000;
  color: #fff;
  text-align: center;
  border-radius: 4px;
  padding: 4px 8px;
  position: absolute;
  top: 120%;
  /* above icon */
  left: 50%;
  transform: translateX(-50%);
  font-size: 13px;
  white-space: nowrap;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.icon-btn:hover .tooltip-text {
  visibility: visible;
  opacity: 1;
}

.login-btn:hover {
  background: var(--accent);
}

.navbar-brand img {
  height: 70px;
}

/* Full Height Carousel */
#heroSlider {
  position: relative;
}

.cstm-hero-88 .carousel-item {
  height: 100vh;
  min-height: 600px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

/* Responsive Text */
@media (max-width: 768px) {
  .cstm-team-sec-12 a {
    font-size: 16px !important;
  }
  .img-fluid {
    width: 100%;
    height: auto !important;
  }
  .cstm-hero-88 .carousel-item {
    height: 100%;
    min-height: 475px;
  }
  .navbar {
    padding-bottom: 15px;
  }
  .navbar-nav {
    padding-bottom: 12px;
  }
  .path-user .main-dash-203 {
    padding: 25px 15px !important;
  }
  h2.about-title,
  .about-desc-22 {
    padding: 0px !important;
  }
}
.btn-accent {
  background: var(--accent);
  color: #fff;
  border-radius: 6px;
  font-weight: 500;
  width: fit-content;
  margin-left: 0;
}

.btn-accent:hover {
  border: 1px solid #000000;
  color: #000;
  background-color: #fff;
}

.btn-outline-light {
  border-color: rgba(255, 255, 255, 0.35);
}

.hero-illustration {
  background: #fff;
  border-radius: 28px;
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-illustration img {
  max-width: 100%;
  max-height: 300px;
  display: block;
  border-radius: 28px;
}

.arrow-btn i {
  color: var(--blue);
  font-size: 20px;
}

/* floating card */
.floating-card {
  transform: translateY(-70px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
  border-radius: 8px;
  padding: 1rem;
  position: absolute;
  width: 100%;
  left: 0;
  right: 0;
  margin: 0 auto;
  max-width: 1024px;
  padding: 1rem 1.5rem;
}

.floating-card .col {
  border-right: 1px solid rgba(0, 0, 0, 0.06);
}

.floating-card .col:last-child {
  border-right: 0;
}

.feature-icon {
  font-size: 40px;
  color: var(--blue);
}

.carousel-arrows {
  position: relative;
  margin-top: 2.5rem;
  margin-bottom: 4.5rem;
}

.arrow-btn {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #111;
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.25);
}

.text-muted {
  font-size: 1rem;
}

/* About section */
.about-section {
  background: var(--muted);
  color: #111;
  padding: 2rem 0 3rem;
}

.about-pill {
  background: #000;
  color: var(--accent);
  padding: 0.3rem 2rem;
  border-radius: 30px;
  display: inline-block;
  margin-bottom: 1.25rem;
  font-size: 15px;
  font-weight: 400;
}

.about-title {
  font-weight: 800;
  color: #000;
}

.caret {
  font-size: 15px;
}

/* Carousel customization */
.carousel-control-prev,
.carousel-control-next {
  width: auto;
  opacity: 1;
  top: auto;
  bottom: -80px;
}

.carousel-control-prev {
  left: calc(50% - 60px);
}

.carousel-control-next {
  right: calc(50% - 60px);
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
  background-image: none;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.25);
}

.carousel-control-prev-icon:after {
  content: "\f053";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  color: #fff;
  font-size: 20px;
}

.carousel-control-next-icon:after {
  content: "\f054";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  color: #fff;
  font-size: 20px;
}

.hero-section {
  background: var(--hero-yellow);
  padding: 48px 16px;
}

.hero-heading {
  font-weight: 700;
  color: #000;
}

.arrow-circle {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--arrow-blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  margin-left: 12px;
  border: 6px solid transparent;
}

.arrow-circle:hover {
  background: var(--arrow-blue);
  color: #fff;
}

.feature-card {
  position: relative;
  height: 320px;
  border: none;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.feature-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--card-dark-new);
  opacity: 0.6;
  border-radius: 8px;
}

.card-content {
  position: relative;
  color: #fff;
  text-align: center;
  z-index: 2;
}

.big-number {
  font-size: 48px;
  font-weight: bold;
  color: var(--number-yellow);
  margin-bottom: 10px;
}

.form-item,
.form-actions {
  margin-top: 1em;
  color: black;
  margin-bottom: 1em;
}

span.fieldset-legend {
  display: none;
}

.container-fluid.bg-contact-us.py-5 {
  background-color: #dfc548;
}
.container-fluid.bg-contact-us.py-5 h3 {
  color: #000;
  font-family: "Geist", "Helvetica", "Arial", sans-serif;
  font-weight: 400;
}

.floating-card p {
  margin-bottom: 0px;
}

.cstm-social-footer a {
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  text-decoration: none;
  border-radius: 6px;
}

.cstm-social-footer i {
  color: #000;
}

.cstm-list-footer h6 {
  color: var(--accent);
  font-weight: 600 !important;
  font-size: 20px;
}

.region-content {
  padding: 0px;
}

.path-checkout #edit-login-returning-customer {
  background: var(--accent);
  color: #fff;
  border-radius: 8px;
}

.path-checkout .commerce-checkout-flow .layout-checkout-form label {
  color: #000 !important;
}

.path-checkout #edit-login-returning-customer .js-form-item label {
  color: #fff;
}

.path-checkout #edit-login-returning-customer .form-submit {
  background-color: #000;
  color: #fff;
}

.path-checkout #edit-login-returning-customer .form-submit:hover {
  background-color: rgba(0, 0, 0, 0.8666666667);
}

.path-checkout #edit-login-returning-customer #edit-login-returning-customer-forgot-password {
  color: #fff;
  text-decoration: none;
  margin-left: 10px;
}

.path-user #block-xuan-theme-content {
  min-height: 450px;
  background: #fff;
  padding: 50px 0;
}

.path-user .user-pass {
  background: #000;
  padding: 30px;
  width: 50%;
  margin: 0 auto;
  border-radius: 8px;
  color: #fff;
}

.path-user .user-pass .form-submit {
  background: var(--accent);
  color: #fff;
}

.path-user .user-pass-reset {
  background: #000;
  max-width: 600px;
  border-radius: 8px;
  padding: 30px;
  color: #fff;
  margin: 0 auto;
}
.path-user .user-pass-reset .form-submit {
  background: var(--accent);
  color: #fff;
}
.path-user .user-pass-reset div#edit-actions {
  margin: 0 !important;
}

.path-user .user-login-form {
  background: #000;
  padding: 2rem;
  width: 40%;
  border-radius: 8px;
  margin: 0 auto;
}

.path-user .register-link a {
  border: none;
  color: #fff;
}

.path-user .register-link a:hover {
  background: transparent;
  color: var(--accent);
}

.path-user .user-login-form label,
.path-user .user-register-form label,
.path-user .user-register-form .description {
  color: #fff;
  display: contents;
}

.path-user .user-register-form .label {
  color: #fff;
  font-weight: 400;
}

.path-user .user-login-form div#edit-name--description {
  color: #fff;
}

.path-user .user-login-form .custom-button-123,
.path-user .user-register-form .form-submit {
  background-color: var(--accent);
  color: #ffffff;
  font-size: 16px;
  font-weight: 500;
  border: none;
  border-radius: 8px;
  padding: 10px 22px;
  cursor: pointer;
  width: 100%;
  margin-top: 20px;
}

.path-user .user-login-form .custom-button-123:hover,
.path-user .user-register-form .form-submit:hover {
  background-color: #fff;
  color: #000;
}

.path-user .user-register-form .password-suggestions,
.path-user .user-register-form .password-confirm-message {
  color: white;
}
.path-user .user-register-form {
  background: #000;
  width: 50%;
  padding: 30px;
  margin: 0 auto;
  border-radius: 8px;
}

.path-user .user-register-form #edit-group-main-profile .fieldset-wrapper {
  display: flex;
  gap: 25px;
}
.path-user .user-register-form #edit-group-main-profile #edit-field-date-of-birth-wrapper {
  margin-top: 23px;
}
.path-user .user-register-form #edit-group-main-profile .form-item-field-address-0-address-country-code {
  margin-top: 0px;
}

@media screen and (min-width: 320px) and (max-width: 767px) {
  .test-image {
    width: 250px !important;
    height: 250px !important;
  }
  .testimonial-inner {
    flex-direction: column;
    gap: 1.25rem;
    align-items: start !important;
  }
  .cta-cstm {
    padding: 50px 15px !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .test-image {
    width: 200px !important;
    height: 200px !important;
  }
  .testimonial-inner {
    flex-direction: unset;
  }
  .main-about-flex-12 {
    display: block;
  }
  .main-left-txt-22 {
    width: 100%;
  }
  .about-page-main-img-132 {
    width: 700px;
  }
  .cta-cstm {
    padding: 50px 0px 50px 60px !important;
  }
}
/* responsive tweaks */
@media (max-width: 991px) {
  .path-user .user-pass {
    width: 100%;
    margin-top: 25px;
  }
  .path-user .user-register-form {
    width: 100%;
  }
  .path-user .user-register-form #edit-group-main-profile .fieldset-wrapper {
    display: block;
  }
  .main-package-cls-12 {
    display: block !important;
  }
  .hero {
    padding: 40px 0;
    background: #2a2a2a;
    height: 760px;
  }
  .hero .display-5 {
    font-size: 32px !important;
  }
  .hero-illustration {
    margin-top: 2rem;
  }
  .floating-card {
    transform: translateY(-30px);
    position: unset;
    margin-top: 50px;
  }
  .floating-card .col {
    border-right: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  }
  .floating-card .col:last-child {
    border-bottom: 0;
  }
  .dropdown-menu-end[data-bs-popper] {
    right: -97px;
    left: auto;
  }
  .custom-notification-menu-12 {
    width: 300px !important;
    border: 2px solid var(--accent) !important;
  }
  .carousel-control-prev {
    left: calc(50% - 60px);
  }
  header li.nav-item.dropdown {
    display: flex;
    flex-wrap: wrap;
  }
  header .navbar-nav .dropdown:hover > .dropdown-menu {
    flex-basis: 70%;
    margin-left: 13px;
  }
  #heroSlider .carousel-control-prev-icon,
  #heroSlider .carousel-control-next-icon {
    width: 35px;
    height: 35px;
  }
  #heroSlider .carousel-control-next-icon:after,
  #heroSlider .carousel-control-prev-icon:after {
    font-size: 18px;
  }
  .carousel-control-next {
    right: calc(50% - 60px);
  }
  .about-section {
    padding: 1rem 0 3rem;
  }
  .hero-btn-cstm {
    display: block !important;
  }
  .hero-btn-cstm a {
    margin-top: 10px;
    margin-left: 0px;
  }
  h1 {
    font-size: 30px !important;
  }
  h2 {
    font-size: 28px !important;
  }
  p {
    font-size: 1rem !important;
  }
  .hero-illustration img {
    max-width: 100%;
    max-height: 200px;
  }
  .hero-cstm-44 {
    padding: 10px !important;
  }
  .hero-illustration {
    padding: 0.8rem;
  }
  .hero-btn-cstm a {
    padding: 10px !important;
  }
  .feature-card {
    height: 240px;
  }
  .contact-section {
    padding: 2rem 0px !important;
  }
  .cstm-contact-12 {
    padding: 2rem 1rem !important;
  }
  .courses-cstm,
  .schedules-cstm,
  .shop-cstm {
    border: none !important;
  }
  .test-section {
    padding: 50px 12px;
  }
  .testimonial-card {
    padding: 20px !important;
  }
  .img-frame {
    margin: 25px 0;
  }
  .card-body-custom a {
    margin: 0 !important;
  }
  .custom-field-123 .fieldset-wrapper {
    display: block !important;
  }
  .bg-contact-us h3 {
    text-align: center;
  }
  .bg-contact-us {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .cstm-list-footer {
    text-align: center !important;
    padding-left: 0px !important;
    border: none !important;
  }
  .achieve-cstm-13 {
    text-align: left !important;
  }
  .cstm-social-footer {
    justify-content: center;
  }
  .path-user .user-login-form {
    margin-top: 50px;
    width: 100%;
  }
  .path-user #block-xuan-theme-content {
    padding: 70px 18px;
  }
  .path-user .user-profile {
    padding: 0px;
  }
  .path-user .about-student-12 {
    flex-direction: column;
    gap: 15px;
    justify-content: start !important;
    align-items: start !important;
  }
}
::placeholder {
  font-weight: 500;
  color: #5b6166 !important;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
#book-class-popup .spinner {
  animation: spin 1.5s linear infinite;
}

a.nav-link.is-active {
  color: red;
}

header h3 {
  color: red;
  padding-top: 10px;
}

header button.nav-link.dropdown-toggle-btn {
  padding: 0 !important;
  margin: 0 !important;
}
header li.nav-item.dropdown {
  display: flex;
}
header li.nav-item.dropdown a {
  margin-right: 0px;
  padding-right: 7px !important;
}
header .navbar-expand-lg .navbar-nav .dropdown-menu {
  top: 30px;
  left: 19px;
}

.password-strength__title,
.password-strength__text {
  display: inline;
  color: white;
}

/* Make all checkout address labels black */
.checkout-pane-payment-information label {
  color: #000 !important;
}

.js-form-item-student-id label {
  color: #000 !important;
}

.partner-logo-slider-55 .logo-slider {
  overflow: hidden;
  width: 100%;
  position: relative;
  background: #fff;
  padding: 20px 0;
  /* optional soft border */
  border-radius: 8px;
}
.partner-logo-slider-55 .slide-track {
  display: flex;
  align-items: center;
  gap: 45px;
  will-change: transform;
  /* animation is added dynamically by JS */
}
.partner-logo-slider-55 .slide {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.partner-logo-slider-55 .slide img {
  height: 60px;
  width: auto;
  display: block;
  object-fit: cover;
  width: 180px;
  height: 180px;
  filter: grayscale(100%);
  opacity: 0.85;
  transition: filter 0.25s, opacity 0.25s, transform 0.25s;
}
.partner-logo-slider-55 .slide img:hover {
  filter: grayscale(0%);
  opacity: 1;
  transform: scale(1.02);
}

/* ===== Announcement ticker block ===== */
#block-xuan-theme-views-block-announcement-block-1 {
  overflow: hidden;
  background: var(--accent);
}

/* Hide vertical stacking */
#block-xuan-theme-views-block-announcement-block-1 .views-view-responsive-grid {
  display: inline-flex !important;
  flex-wrap: nowrap !important;
  gap: 80px;
  color: #000;
  animation: announcementTicker 45s linear infinite;
}

/* Each announcement item */
#block-xuan-theme-views-block-announcement-block-1 .views-view-responsive-grid__item {
  flex: 0 0 auto;
  max-width: none;
}

/* Prevent text wrapping vertically */
#block-xuan-theme-views-block-announcement-block-1 .views-view-responsive-grid__item-inner {
  white-space: normal;
  height: 10px;
}

/* Remove line breaks */
#block-xuan-theme-views-block-announcement-block-1 br {
  display: none;
}

/* Animation */
@keyframes announcementTicker {
  0% {
    transform: translateX(100%);
  }
  100% {
    transform: translateX(-100%);
  }
}
.orders-empty {
  color: #000 !important;
}

.blog-body span {
  color: #fff !important;
}

@font-face {
  font-family: "Geist Thin";
  font-style: normal;
  font-weight: 100;
  src: url("../fonts/geist/geist-v3-latin-100.woff2") format("woff2");
}
@font-face {
  font-family: "Geist ExtraLight";
  font-style: normal;
  font-weight: 200;
  src: url("../fonts/geist/geist-v3-latin-200.woff2") format("woff2");
}
@font-face {
  font-family: "Geist Light";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/geist/geist-v3-latin-300.woff2") format("woff2");
}
@font-face {
  font-family: "Geist";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/geist/geist-v3-latin-regular.woff2") format("woff2");
}
@font-face {
  font-family: "Geist Medium";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/geist/geist-v3-latin-500.woff2") format("woff2");
}
@font-face {
  font-family: "Geist SemiBold";
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/geist/geist-v3-latin-600.woff2") format("woff2");
}
@font-face {
  font-family: "Geist Bold";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/geist/geist-v3-latin-700.woff2") format("woff2");
}
@font-face {
  font-family: "Geist ExtraBold";
  font-style: normal;
  font-weight: 800;
  src: url("../fonts/geist/geist-v3-latin-800.woff2") format("woff2");
}
@font-face {
  font-family: "Geist Black";
  font-style: normal;
  font-weight: 900;
  src: url("../fonts/geist/geist-v3-latin-900.woff2") format("woff2");
}
.test-section {
  padding: 60px 20px;
  background: #ffffff;
}

.section-title {
  text-align: center;
  font-weight: 700;
  font-size: 36px;
  margin-bottom: 12px;
  color: #000000;
}

.courses-title {
  text-align: center;
  font-weight: 700;
  font-size: 40PX;
  margin-bottom: 12px;
  color: #fff;
  margin-left: auto;
  margin-right: auto;
}

.courses-desc {
  max-width: 900px;
  margin: 0 auto 28px;
  text-align: center;
  color: var(--muted-gray);
  line-height: 1.6;
  color: #ffffff;
  font-size: 20px;
}

.testimonial-wrap {
  max-width: 1100px;
  margin: 0 auto;
}

.testimonial-card {
  background: var(--dark);
  color: #fff;
  border-radius: 8px;
  padding: 28px;
  position: relative;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
}

.testimonial-quote {
  display: flex;
  justify-content: end;
}

.img-frame {
  background: #fff;
  padding: 8px;
  border-radius: 10px;
  display: inline-block;
}

.test-image {
  width: 260px;
  height: 260px;
  object-fit: cover;
  border-radius: 8px;
  display: block;
}

.testimonial-name {
  color: var(--accent);
  font-weight: 700;
  font-size: 22px;
  margin-bottom: 12px;
}

.testimonial-text {
  color: #fff;
  line-height: 1.7;
  font-size: 15px;
}

.carousel-controls {
  margin-top: 30px;
  display: flex;
  gap: 18px;
  justify-content: center;
}

button.control-circle {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--accent);
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  font-size: 20px;
  color: #fff;
}

.topbar {
  background: linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.7)), url(/sites/default/files/slider-images/002.png);
  background-repeat: no-repeat;
  background-position: 2% center;
  height: 290px;
  color: #fff;
  padding: 28px 0;
  text-align: center;
  background-size: cover;
}
.topbar a {
  color: inherit;
  text-decoration: none;
  font-weight: 600;
}

.about {
  background-color: #fff;
  padding: 50px 0;
}

.about-sub {
  color: var(--dark);
}

.photo {
  max-width: 100%;
  width: 500px;
  border-radius: 8px;
}

.sub-left-img {
  max-width: 100%;
}

.subscribe-section {
  background-color: #000000;
}

.form-cstm-subscribe form {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 60%;
  margin: 0 auto;
  gap: 10px;
}

.news-subscribe {
  background-color: var(--accent);
}

.news-subscribe:hover {
  border: 1px solid var(--accent);
  color: var(--accent);
}

.form-cstm-subscribe .form-type-email label {
  display: none;
}

@media screen and (min-width: 768px) and (max-width: 990px) {
  .sub-left-img {
    max-width: 290px;
    height: 307px;
  }
  .form-cstm-subscribe form {
    display: flex !important;
  }
}
.testimonials-section {
  padding: 3rem 0;
  background-color: var(--muted);
}

/* Outer testimonial card */
.testimonial-card-12 {
  background: #000000;
  border: none;
  position: relative;
  overflow: visible;
  padding: 2rem 1.25rem;
  border-radius: 8px;
}

/* layout container to mimic image on left, text on right */
.testimonial-inner {
  display: flex;
  align-items: center;
  gap: 3rem;
  background: transparent;
  position: relative;
}

/* framed photo */
.photo-wrap,
.photo-wrap-12 {
  position: relative;
  flex-shrink: 0;
  width: 180px;
  height: 220px;
  display: grid;
  place-items: center;
}

.photo-accent-12 {
  position: absolute;
  right: -44px;
  top: -38px;
  width: 65%;
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
  z-index: 1;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
}

.carousel-item-12 {
  background-color: #000000;
}

/* background accent block behind the image (offset) */
.photo-accent {
  position: absolute;
  right: -18px;
  top: -14px;
  width: 70%;
  height: 80%;
  background: var(--accent);
  border-radius: 2px;
  z-index: 1;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
}

/* white framed photo */
.photo-frame {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 300px;
  background: #fff;
  padding: 8px;
  z-index: 2;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.photo-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 2px;
  display: block;
}

/* testimonial text area */
.testimonial-content {
  flex: 1;
  max-width: 820px;
  position: relative;
}

.testimonial-quote-mark {
  width: 30px;
  height: 30px;
  margin-bottom: 0.7rem;
}

.testimonial-text {
  color: #f1f1f1;
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 1rem;
  padding-right: 1rem;
}

.testimonial-name {
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 0.02em;
}

.testimonial-role {
  color: var(--muted);
  font-size: 0.85rem;
}

.photo-wrap-12 {
  max-width: 100%;
  width: 400px;
}

.photo-wrap-12 .photo-frame {
  min-height: 365px !important;
}

.photo-wrap-12 {
  animation: organicDrift 8s ease-in-out infinite;
  will-change: transform;
}

@keyframes organicDrift {
  0% {
    transform: translate(0, 0) scale(1);
  }
  20% {
    transform: translate(6px, -4px) scale(1.02);
  }
  40% {
    transform: translate(-5px, 6px) scale(1.015);
  }
  60% {
    transform: translate(4px, 3px) scale(1.01);
  }
  80% {
    transform: translate(-3px, -4px) scale(1);
  }
  100% {
    transform: translate(0, 0) scale(1);
  }
}
body.path-our-team .views-element-container {
  background-color: #fff;
  padding-bottom: 50px;
}

body.path-store .views-element-container {
  background-color: #fff;
}

body.path-store .view--custom {
  padding: 50px 0;
}

body.path-our-team .field-content {
  background: var(--accent);
  padding: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 8px;
}

body.path-store .views-field-field-image {
  background: #f2f5f8;
  padding: 20px;
  border-right: 1px solid var(--blue);
  border-left: 1px solid var(--blue);
  border-top: 1px solid var(--blue);
  margin-right: 20px;
  border-top-right-radius: 8px;
  border-top-left-radius: 8px;
}

body.path-store .views-field-title {
  background: var(--blue);
  padding: 10px 20px 0 20px;
  margin-right: 20px;
  white-space: nowrap;
  overflow-x: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
  transition: all 0.2s ease-in-out;
  max-width: 100%;
}

body.path-store .views-field-title:hover {
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  color: #fff;
  position: relative;
  z-index: 10;
}

body.path-store .views-field-type {
  background: var(--blue);
  padding: 0px 20px 0 20px;
  margin-right: 20px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom-right-radius: 8px;
  border-bottom-left-radius: 8px;
}

.cstm-team-sec-12 {
  width: 100%;
}

body.path-our-team .views-view-grid {
  padding-bottom: 50px;
}

.cstm-team-sec-12 a,
body.path-store .field-content a {
  text-decoration: none;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
}

body.path-store h3 {
  color: var(--accent);
}

/*-------------------------------------
    cart page css start **********
    -----------------------------------*/
.path-cart #block-xuan-theme-content {
  padding: 100px 0;
  background: #fff;
  min-height: 500px;
}

.path-cart .cart-empty-page {
  background: #000000;
  padding: 100px 0;
  border-radius: 8px;
  width: 65%;
}

.path-cart .cstm-empty-btn-12 {
  background: var(--accent);
  border: none;
  padding: 10px 20px;
  color: #fff;
  text-decoration: none;
  border-radius: 4px;
}

/*-------------------------------------
    cart page css end **********
    -----------------------------------*/
/*-------------------------------------
    order information page css start **********
    -----------------------------------*/
.path-checkout main {
  padding: 50px 0;
  background: #fff;
}
.path-checkout .layout-checkout-form {
  min-height: 500px;
}
.path-checkout .form-wrapper__guest-checkout {
  background: #000;
  color: #fff;
  border-radius: 8px;
}
.path-checkout .address-book-edit-button {
  background: var(--accent);
  color: #fff;
  margin-left: 0;
}
.path-checkout .form-check-input:checked {
  background-color: var(--accent);
  border-color: var(--accent);
}
.path-checkout .address {
  color: #000;
}
.path-checkout .form-wrapper__guest-checkout .form-submit {
  background: var(--accent);
  color: #fff;
}
.path-checkout span.fieldset-legend {
  display: block;
}
.path-checkout .section-title-12 {
  font-weight: 700;
  font-size: 28px;
  text-align: left;
}
.path-checkout .layout-region-checkout-secondary h3 {
  color: #fff;
}
.path-checkout .layout-region-checkout-secondary {
  background: #000;
  padding: 20px;
  border-radius: 8px;
}
.path-checkout .order-total-line {
  color: var(--accent);
}
.path-checkout #edit-sidebar-coupon-redemption-form label {
  color: #000;
}
.path-checkout #edit-actions-next,
.path-checkout .form-submit {
  background: #000;
  color: #fff;
}
.path-checkout #edit-sidebar-coupon-redemption-form .form-submit {
  background: var(--accent);
  color: #fff;
  margin-left: 0;
}
.path-checkout .layout-region-checkout-main {
  background: rgba(156, 36, 36, 0.1294117647);
  padding: 20px;
  border: 1px solid var(--accent);
  border-radius: 8px;
  width: 62%;
}
.path-checkout span.fieldset-legend {
  font-size: 1.5rem;
  font-weight: 600;
}
.path-checkout .link--previous {
  background: var(--accent);
  padding: 9px 20px;
  color: #fff;
  text-decoration: none;
  border-radius: 6px;
}
.path-checkout .action-buttons .action-link {
  background: #000;
  color: #fff;
  padding: 8px 20px;
  text-decoration: none;
  border-radius: 4px;
}

/*-------------------------------------
  order information page css end **********
  -----------------------------------*/
/*-------------------------------------
  page not found page css start **********
  -----------------------------------*/
/* General layout */
.error-page {
  background: linear-gradient(135deg, #f8f9fc 0%, #e9ecf1 100%);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

/* Header */
.error-header {
  margin-bottom: 2rem;
}

.error-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Message */
.error-message {
  font-size: 1.1rem;
  line-height: 1.7;
  color: #000;
  background: #fff;
  padding: 1.5rem 2rem;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05);
}

/* Home Button */
.home-link {
  display: inline-block;
  margin-top: 1.5rem;
  font-size: 1rem;
  text-decoration: none;
  background: #000;
  border-radius: 50px;
  padding: 0.9rem 2.2rem;
  color: #fff;
  font-weight: 500;
  transition: all 0.3s ease;
}

.home-link:hover {
  transform: translateY(-2px);
}

/* Hint text */
.error-hint {
  margin-top: 2.5rem;
  font-size: 0.95rem;
  color: #fff;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .topbar {
    background-size: cover;
  }
  .error-title {
    font-size: 2rem;
  }
  .error-message {
    font-size: 1rem;
    padding: 1rem 1.5rem;
  }
}
/*-------------------------------------
  page not found page css end **********
  -----------------------------------*/
/*-------------------------------------
  notification pop up css start **********
  -----------------------------------*/
.custom-notification-menu-12 {
  width: 500px;
  max-height: 600px;
  overflow-y: auto;
  margin-top: 20px !important;
  padding: 20px;
}

.custom-notification-menu-12 h6 {
  color: var(--accent);
  font-size: 18px;
}

.custom-notification-menu-12 p {
  font-size: 16px;
}

/*-------------------------------------
  notification pop up css end **********
  -----------------------------------*/
/*-------------------------------------
  schedule and fees page css start **********
  -----------------------------------*/
.path-class-booking input#edit-submit-lessons {
  background: var(--blue);
  color: #fff;
  margin-top: 21px;
}
.path-class-booking input#edit-reset-lessons {
  background: #000;
  color: #fff;
  margin-left: 0px;
  margin-top: 21px;
}
.path-class-booking .form--inline.clearfix {
  display: flex;
  align-items: center;
  padding-top: 20px;
}

.custom-schedule-fee-page .fc-day-number {
  color: #000;
  text-decoration: none;
}
.custom-schedule-fee-page .fc-prev-button,
.custom-schedule-fee-page .fc-next-button {
  background: #000;
}
.custom-schedule-fee-page .fc-today-button {
  background: var(--blue);
  border-color: var(--blue);
}
.custom-schedule-fee-page .fc-button-group .fc-button-primary {
  background: #000;
}
.custom-schedule-fee-page .fc-button-group .fc-button-active {
  background: var(--accent);
  border-color: var(--accent);
}
.custom-schedule-fee-page .fc-day-header {
  padding: 10px !important;
  background: #000;
}
.custom-schedule-fee-page .fc-header-toolbar .fc-center h2 {
  color: var(--accent);
}
.custom-schedule-fee-page .fc-list-heading-main,
.custom-schedule-fee-page .fc-list-heading-alt {
  color: var(--blue);
  text-decoration: none;
}
.custom-schedule-fee-page .fc-has-url {
  color: #000;
}

@media (max-width: 991px) {
  .path-class-booking input#edit-submit-lessons {
    margin-top: 0px;
  }
  .path-class-booking input#edit-reset-lessons {
    margin-top: 0px;
  }
  .path-class-booking .form--inline.clearfix {
    flex-direction: column;
    align-items: start;
  }
  .path-class-booking .form-actions {
    margin-top: 0px !important;
  }
  .custom-schedule-fee-page .fc-header-toolbar {
    display: block;
  }
  .custom-schedule-fee-page .fc-view-container .fc-view {
    overflow-x: scroll;
  }
  .custom-schedule-fee-page .fc table {
    width: 1000px;
  }
  .custom-schedule-fee-page .fc-scroller {
    overflow: scroll !important;
  }
  .custom-schedule-fee-page .fc-header-toolbar .fc-center {
    margin: 20px 0;
  }
}
.path-test-lessons .js-drupal-fullcalendar {
  background: #fff;
  padding: 60px 35px;
}
.path-test-lessons .fc-toolbar .fc-button-group .fc-prev-button,
.path-test-lessons .fc-toolbar .fc-button-group .fc-next-button {
  background: var(--blue);
}
.path-test-lessons .fc-toolbar .fc-button-group .fc-prev-button:hover,
.path-test-lessons .fc-toolbar .fc-button-group .fc-next-button:hover {
  background: rgba(4, 51, 114, 0.8901960784);
}
.path-test-lessons .fc-today-button:disabled {
  background: #ffeeef;
  opacity: 0.7;
  color: var(--accent);
  border: 1px solid var(--accent);
}
.path-test-lessons .fc-today-button {
  background: var(--accent);
  border: none;
}
.path-test-lessons .fc-toolbar .fc-center h2 {
  color: var(--accent);
}
.path-test-lessons .fc-unthemed td,
.path-test-lessons .fc-unthemed th {
  border-color: #000;
  color: var(--accent);
}
.path-test-lessons .fc-day-top a {
  color: #000;
  text-decoration: none;
}

/*-------------------------------------
  schedule and fees page css end **********
  -----------------------------------*/
/*-------------------------------------
  blog  page css start **********
  -----------------------------------*/
body.path-blogs {
  background: #fff !important;
}

.blog-sidebar {
  padding: 1.5rem;
  background: #fff;
  border: 1px solid #e9ecef;
  border-radius: 8px;
  margin-bottom: 2rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.blog-sidebar .search-section {
  margin-bottom: 2rem;
}

body.path-blogs .blog-sidebar .search-section form #edit-actions {
  margin: 0 !important;
}

body.path-blogs .blog-sidebar .search-section form #edit-submit-blogs-listing-page {
  background-color: var(--accent);
  color: #fff;
  margin-right: 0px;
}

body.path-blogs .blog-sidebar .search-section form #edit-reset-blogs-listing-page {
  background-color: #000;
  color: #fff;
}

.blog-sidebar .search-section h5 {
  font-weight: 600;
  margin-bottom: 1rem;
  color: #333;
}

.blog-sidebar .search-section .form-control {
  margin-bottom: 0px !important;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 8px 12px;
}

.blog-sidebar .search-section .btn {
  width: 100%;
  padding: 8px 16px;
  border-radius: 4px;
}

.blog-sidebar .archives {
  margin-bottom: 2rem;
}

.blog-sidebar .archives h5 {
  font-weight: 600;
  margin-bottom: 1rem;
  color: #333;
}

.blog-sidebar .archives ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.blog-sidebar .archives ul li {
  margin-bottom: 0.5rem;
}

.blog-sidebar .archives ul li a {
  color: #666;
  text-decoration: none;
  font-size: 14px;
}

.blog-sidebar .archives ul li a:hover {
  color: var(--accent) !important;
  text-decoration: underline;
}

.blog-sidebar .tags h5 {
  font-weight: 600;
  margin-bottom: 1rem;
  color: #333;
}

.blog-sidebar .tags .tag-cloud a {
  display: inline-block;
  background: #e9ecef;
  color: #666;
  padding: 4px 8px;
  margin: 2px;
  border-radius: 12px;
  font-size: 12px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.blog-sidebar .tags .tag-cloud a:hover {
  background: var(--accent) !important;
  color: #fff;
}

.blog-main-content {
  background: #fff;
}

.blog-main-content .blog-post {
  margin-bottom: 2rem;
  padding: 1.5rem;
  background: #000;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.blog-main-content .blog-post .blog-title,
.blog-main-content .blog-post h4 {
  margin-bottom: 0.5rem;
}

.blog-main-content .blog-post .blog-title a,
.blog-main-content .blog-post h4 a {
  color: #ffffff;
  text-decoration: none;
  font-weight: 600;
}

.blog-main-content .blog-post .blog-title a:hover,
.blog-main-content .blog-post h4 a:hover {
  color: var(--accent);
}

.blog-main-content .blog-post .blog-meta {
  color: var(--accent);
  font-size: 14px;
  margin-bottom: 1rem;
}

.blog-main-content .blog-post .blog-excerpt {
  color: #ffffff;
  line-height: 1.6;
  font-size: 15px;
}

.blog-main-content .blog-post img {
  border-radius: 8px;
  object-fit: cover;
  height: 200px;
  width: 100%;
  aspect-ratio: 1;
  border: 2px solid #e9ecef;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
}

.blog-main-content .blog-post img:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transform: translateY(-2px);
}

.blog-main-content hr {
  display: none;
}

.blog-main-content .pagination-wrapper {
  margin-top: 3rem;
  text-align: center;
}

.blog-main-content .pagination-wrapper .pagination {
  justify-content: center;
  margin-bottom: 0;
}

.blog-main-content .pagination-wrapper .pagination .page-link {
  color: #666 !important;
  border: 1px solid #ddd !important;
  padding: 10px 16px;
  margin: 0 2px;
  border-radius: 4px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.blog-main-content .pagination-wrapper .pagination .page-link:hover {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff;
  transform: translateY(-1px);
}

.blog-main-content .pagination-wrapper .pagination .page-item.active .page-link {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff;
}

@media (max-width: 768px) {
  .blog-sidebar {
    margin-bottom: 2rem;
  }
  .blog-main-content .blog-post img {
    margin-bottom: 1rem;
    height: auto;
    width: 100%;
    border: 2px solid #e9ecef;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }
}
/*-------------------------------------
  blog  page css end **********
  -----------------------------------*/
/* responsive: stack on small screens */
@media (max-width: 991px) {
  .photo-wrap {
    width: 140px;
    height: 180px;
  }
  .photo-accent {
    right: -12px;
    top: -10px;
    width: 60%;
    height: 70%;
  }
  .testimonial-card-12 .photo-wrap {
    width: 220px;
    height: 220px;
  }
  .testimonial-card-12 .photo-accent {
    right: -30px;
    top: -13px;
    width: 60%;
    height: 60%;
  }
  .testimonial-card-12 .photo-frame {
    min-height: 200px;
  }
  .photo-wrap-12 .photo-frame {
    min-height: 260px;
  }
  .form-cstm-subscribe form {
    width: 100%;
    display: block;
  }
  .subscribe-text {
    font-size: 18px;
  }
  .testimonial-content {
    padding-left: 0;
  }
  body.path-our-team .views-view-responsive-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, 1fr);
  }
  body.path-store .views-view-grid .views-row .views-col {
    width: 50% !important;
  }
  body.path-store .views-view-grid .views-row {
    flex-wrap: wrap;
    display: flex;
    margin-left: 5px;
  }
  body.path-store .views-field-field-image {
    padding: 10px;
    margin-right: 10px;
  }
  body.path-store .views-field-title {
    margin-right: 10px;
  }
  body.path-store .views-field-type {
    padding-bottom: 10px;
    margin-bottom: 10px;
    margin-right: 10px;
  }
  body.path-our-team .views-element-container {
    padding-top: 0;
    padding-bottom: 50px;
  }
  .photo-accent-12 {
    position: absolute;
    right: -20px;
    top: -28px;
    width: 52%;
    height: 75%;
  }
  .photo-wrap-12 {
    width: 260px;
  }
  .about {
    padding: 0;
  }
  .path-cart #block-xuan-theme-content {
    padding: 50px 15px;
  }
  .commerce-cart-page .custom-table .commerce-cart-items form .table-responsive {
    width: 100%;
    overflow-x: scroll;
  }
  .commerce-cart-page .custom-table .commerce-cart-items form .table-responsive table {
    width: 100%;
    min-width: 600px;
  }
  .commerce-cart-page .commerce-cart-items table thead th {
    width: 100% !important;
  }
  .commerce-cart-page .commerce-cart-items {
    overflow-x: hidden;
  }
  .path-cart .cart-empty-page {
    width: 100%;
    padding: 30px 20px;
  }
  .path-checkout .layout-region-checkout-main {
    width: 100%;
    margin-bottom: 25px;
  }
  .path-checkout .layout-checkout-form {
    padding: 12px;
  }
  .path-checkout .action-buttons {
    flex-direction: column;
  }
}
/* tighten up on very large screens */
@media (min-width: 1400px) {
  .photo-wrap {
    width: 220px;
    height: 270px;
  }
}
.pagination-wrapper ul.pagination {
  justify-content: center;
}

.path-courses .view.view-announcement.view-id-announcement.view-display-id-block_1 {
  color: black;
  padding: 12px;
}
.path-courses .update-pill {
  background: var(--blue);
  border-radius: 4px;
  color: #fff;
  font-size: 22px;
  font-weight: 500;
}
.path-courses .latest-update-12 h6 {
  color: var(--accent);
}
.path-courses .latest-update-12 p {
  font-size: 16px;
}

.error-page .container {
  background: #cc0909;
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.error-code {
  font-size: 5rem;
  color: #000;
}

.error-title {
  font-weight: bold;
}

.home-link {
  text-decoration: none;
}

.order-view-title {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 20px;
  color: #000;
}

a.nav-link.dropdown-toggle.show {
  color: #ffffff;
}

.custom-exposed-filter-55 {
  padding: 20px 0;
}
.custom-exposed-filter-55 .form--inline.clearfix {
  display: flex;
  align-items: center;
}
.custom-exposed-filter-55 input#edit-submit-students,
.custom-exposed-filter-55 input#edit-submit-lesson-list {
  background: var(--blue);
  color: #fff;
  margin-top: 21px;
}
.custom-exposed-filter-55 input#edit-reset-students,
.custom-exposed-filter-55 input#edit-reset-lesson-list {
  background: #000;
  color: #fff;
  margin-left: 0px;
  margin-top: 21px;
}

@media (max-width: 991px) {
  .custom-exposed-filter-55 input#edit-submit-students,
  .custom-exposed-filter-55 input#edit-submit-lesson-list {
    margin-top: 0px;
  }
  .custom-exposed-filter-55 input#edit-reset-students,
  .custom-exposed-filter-55 input#edit-reset-lesson-list {
    margin-top: 0px;
  }
  .custom-exposed-filter-55 .form--inline.clearfix {
    flex-direction: column;
    align-items: start;
    padding: 0px 15px;
  }
  .custom-exposed-filter-55 .form-actions {
    margin-top: 0px !important;
  }
}
.single-table {
  background: #fff;
  padding: 15px 20px;
  color: var(--blue);
  border-radius: 8px;
}

.single-table a {
  color: #000;
  text-decoration: none;
}

.single-table a:hover {
  color: var(--accent);
}

@media (max-width: 768px) {
  .single-table table {
    white-space: nowrap;
  }
  .product-top-section .product-main-image img {
    width: 100%;
    height: 100%;
  }
  .product-top-section .product-thumbnails {
    width: 100%;
  }
  .product-top-section .product-thumbnails img {
    margin-bottom: 10px;
  }
  .product-top-section .product-details {
    width: 260px;
  }
  .product-top-section .cstm-single-table-23 {
    flex-direction: column;
  }
}
.custom-class-repeater-management .table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.26);
  border-radius: 8px;
  overflow: hidden;
}
.custom-class-repeater-management .table th {
  background: #000;
  text-align: left;
  padding: 12px;
  font-weight: 500;
  color: #fff;
  border-right: 1px solid #e5e7eb;
}
.custom-class-repeater-management .table td {
  padding: 10px 8px;
  border-bottom: 1px solid #e5e7eb;
  vertical-align: middle;
  color: #222;
  font-size: 15px;
}
.custom-class-repeater-management .table .views-field-field-lesson {
  border-top-left-radius: 8px;
}
.custom-class-repeater-management .table .views-field-field-status {
  border-top-right-radius: 8px;
}

.custom-exposed-filter-55 .form--inline.clearfix {
  display: flex;
  align-items: center;
}
.custom-exposed-filter-55 input#edit-submit-students,
.custom-exposed-filter-55 input#edit-submit-lesson-list {
  background: var(--blue);
  color: #fff;
  margin-top: 21px;
}
.custom-exposed-filter-55 input#edit-reset-students,
.custom-exposed-filter-55 input#edit-reset-lesson-list {
  background: #000;
  color: #fff;
  margin-left: 0px;
  margin-top: 21px;
}

#edit-submit-class-repeater-management {
  background: var(--blue);
  color: #fff;
  margin-top: 21px;
}

.path-transactions table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.26);
  border-radius: 8px;
  overflow: hidden;
}
.path-transactions th {
  background: #000 !important;
  text-align: left;
  padding: 12px !important;
  font-weight: 500;
  color: #fff !important;
  border-right: 1px solid #e5e7eb;
}

@media screen and (min-width: 320px) and (max-width: 767px) {
  .path-class-booking .form--inline.clearfix,
  .custom-exposed-filter-55 .form--inline.clearfix {
    flex-direction: column;
    align-items: start !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .path-class-booking .form--inline.clearfix,
  .custom-exposed-filter-55 .form--inline.clearfix {
    flex-direction: row;
    align-items: center;
  }
  .custom-exposed-filter-55 .form-actions {
    margin-bottom: -18px !important;
  }
  .custom-student-profile-55 .profile-image {
    width: 130px !important;
    height: 100px !important;
  }
  .student-routine-12 .btn {
    width: fit-content;
  }
  .student-routine-12 {
    justify-content: end !important;
  }
}
@media (max-width: 991px) {
  .custom-exposed-filter-55 input#edit-submit-students,
  .custom-exposed-filter-55 input#edit-submit-lesson-list {
    margin-top: 0px;
  }
  .custom-exposed-filter-55 input#edit-reset-students,
  .custom-exposed-filter-55 input#edit-reset-lesson-list {
    margin-top: 0px;
  }
  .custom-exposed-filter-55 .form-actions {
    margin-top: 0px !important;
  }
  .table {
    white-space: nowrap;
  }
  .table-responsive {
    padding: 15px 0 15px;
  }
  .partner-logo-slider-55 .slide img {
    width: 135px;
    height: 135px;
  }
  .partner-logo-slider-55 {
    padding: 30px 0 !important;
  }
}
.about-page-main-img-132 img {
  border-radius: 8px;
  width: 100%;
  height: 100%;
}

/* Student Level Logo Styling */
.student-level-logo-circle {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  overflow: hidden;
}

.main-level-profile-19 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.student-level-logo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

/* Responsive adjustments */
@media (max-width: 1200px) {
  .student-level-logo-circle {
    width: 90px;
    height: 90px;
  }
}
@media (max-width: 767px) {
  .student-level-logo-wrapper {
    position: relative;
    margin-top: 20px;
    transform: unset;
    right: 0;
  }
  .student-level-logo-circle {
    width: 80px;
    height: 80px;
  }
  .main-level-profile-19 {
    align-items: start;
    flex-direction: column;
  }
}
.student-routine-12 .btn {
  background: #c8bf7a;
  border-radius: 25px;
  padding: 2px 16px;
  color: #fff;
  border-color: #c8bf7a;
  font-weight: 600;
}

/* Student Routine Button */
.student-routine-12 {
  margin-top: 15px;
}

.btn-routine {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: var(--blue);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  font-size: 16px;
  text-decoration: none;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.btn-routine:hover {
  background: #043372;
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}
.btn-routine i {
  font-size: 20px;
}

@media (max-width: 767px) {
  .student-routine-12 {
    justify-content: start !important;
    margin-top: 20px;
  }
  .student-routine-12 .btn {
    width: fit-content;
  }
  .btn-routine {
    width: 100%;
    justify-content: center;
  }
}
.js-wishlist-toggle.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.custom-view-all-card-12 {
  display: flex !important;
  align-items: center !important;
  height: 508px !important;
}

@media (max-width: 767px) {
  .achieve-cstm-13 {
    margin-top: 10px !important;
  }
  .achieve-cstm-13 .slick-prev-custom {
    margin-right: 0px !important;
  }
  .course-img {
    height: 245px;
  }
  .courses-section .carousel-controls {
    margin-top: 0px !important;
  }
  .card-body-custom {
    gap: 20px;
  }
  .courses-section .carousel-controls .control-circle {
    margin-right: 0px !important;
  }
}
/* courses css start  */
.courses-section {
  background: var(--blue);
  padding: 56px 18px 90px;
  color: #fff;
}

.badge-pill {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  padding: 0.3rem 2rem;
  border-radius: 999px;
  font-weight: 400;
  font-size: 15px;
  margin-bottom: 18px;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
}

.section-title {
  text-align: center;
  font-weight: 700;
  font-size: clamp(24px, 3.4vw, 36px);
  margin-bottom: 12px;
}

.section-desc {
  max-width: 957px;
  margin: 0 auto 36px;
  text-align: center;
  color: #000;
  line-height: 1.55;
  font-size: 20px;
}

.course-card {
  background: var(--card);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18);
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.course-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
}

.course-img {
  width: 100%;
  height: 412px;
  object-fit: cover;
  display: block;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.course-card:hover .course-img {
  transform: scale(1.05);
}

.card-body-custom {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1 1 auto;
}

.title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.course-title {
  font-weight: 700 !important;
  font-size: 18px;
  color: #111;
  margin: 0;
  line-height: 1.2;
}

.price-col {
  text-align: center;
  white-space: nowrap;
}

.price-now {
  color: var(--accent);
  font-weight: 700;
  font-size: 15px;
}

.price-old {
  color: grey;
  text-decoration: line-through;
  font-size: 13px;
  display: block;
}

.course-desc-wrapper {
  display: flex;
  flex-direction: column;
  margin-bottom: 8px;
  min-height: 72px;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  max-height: 72px;
}

.course-desc {
  color: #555;
  font-size: 16px;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 72px;
}

.btn-read {
  background: var(--accent);
  color: var(--blue);
  border: none;
  padding: 8px 14px;
  border-radius: 8px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
  text-decoration: none;
  width: fit-content;
}

.btn-read .chev {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.06);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  font-size: 12px;
}

/* center controls */
.carousel-controls {
  margin-top: 28px;
  display: flex;
  justify-content: center;
  gap: 18px;
}

.contact-section {
  padding: 56px 20px;
  background: #faf6e4;
}

.hero-title {
  font-weight: 800;
  font-size: clamp(26px, 3.2vw, 42px);
  margin-top: 4px;
  margin-bottom: 12px;
  text-align: center;
}

.hero-sub {
  max-width: 820px;
  margin: 0 auto 36px;
  text-align: center;
  color: #5b6166;
  line-height: 1.6;
}

.left-col {
  padding-top: 8px;
}

/* info boxes */
.info-box {
  background: #f2f5f8;
  border: 1px solid #043372;
  border-radius: 10px;
  padding: 14px;
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 18px;
  box-shadow: 0 6px 18px rgba(4, 51, 114, 0.03);
}

.info-contact-box {
  display: flex;
  gap: 14px;
  align-items: center;
}

.cstm-contact-12 {
  background: #fff;
  padding: 2rem;
  border-radius: 8px;
}

.custom-field-123 .fieldset-wrapper {
  display: flex;
  gap: 15px;
}

form#webform-submission-contact-us-form-node-1-add-form .form-control {
  width: 100%;
  padding: 0.375rem 0;
  font-size: 1rem;
  background-color: rgba(255, 255, 255, 0);
  border-bottom: 1.5px solid #000000;
  color: #000;
  border-top: none;
  border-right: none;
  border-left: none;
  border-radius: unset;
}

.cstm-contect-11 {
  background-color: #ffeeef;
  border: 1px solid var(--accent);
  border-radius: 8px;
  margin-top: 25px;
}

.custom-button-123 {
  background-color: #e10600;
  /* Yellow */
  color: #ffffff;
  /* Dark blue */
  font-size: 16px;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  padding: 8px 24px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  gap: 8px;
  width: 100%;
  margin-top: 20px;
}

.account-links a {
  font-size: 14px;
  border-radius: 6px;
  padding: 8px 10px;
}

.account-links {
  gap: 10px;
}

.custom-button-123:hover {
  background-color: #000;
  color: #fff;
}

.contact-title {
  color: var(--blue);
  font-weight: 700 !important;
  margin-bottom: 18px;
}

.btn-accent-contact {
  background-color: var(--blue);
  color: #fff;
  border-radius: 6px;
  font-weight: 500;
  width: fit-content;
}

.btn-accent-contact:hover {
  border: 1px solid var(--blue);
  color: #000;
}

.icon-circle {
  min-width: 46px;
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--accent);
  color: #fff;
  font-size: 24px;
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.06);
}

.icon-circle-12 {
  min-width: 35px;
  min-height: 35px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--accent);
  color: #fff;
  font-size: 24px;
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.06);
}

.info-text {
  font-size: 15px;
  color: inherit;
  text-decoration: none;
}

.info-title {
  font-weight: 600;
  margin: 0 0 4px 0;
  font-size: 18px;
  text-decoration: none;
  color: #000;
}

.info-sub {
  margin: 0;
  color: #6b7280;
  font-size: 14px;
}

/* contact form */
.contact-card {
  background: var(--muted);
  border-radius: 10px;
  padding: 26px;
  border: 1px solid rgba(230, 201, 72, 0.25);
}

.form-row .form-floating > .form-control {
  border: none;
  border-bottom: 2px solid rgba(0, 0, 0, 0.2);
  border-radius: 0;
  background: transparent;
  padding: 0.5rem 0;
  box-shadow: none;
  height: auto;
}

.form-row .form-floating > .form-control:focus {
  box-shadow: none;
  outline: none;
}

.form-floating > label {
  color: rgba(4, 51, 114, 0.5);
  font-weight: 600;
  font-size: 0.92rem;
  left: 0.6rem;
  top: -0.6rem;
  transform: none;
}

.textarea-underline {
  border: none;
  border-bottom: 2px solid rgba(0, 0, 0, 0.2);
  background: transparent;
  border-radius: 0;
  padding: 0.5rem 0;
  resize: vertical;
  min-height: 120px;
  color: var(--dark);
}

.send-btn {
  background: var(--accent);
  color: var(--blue);
  border: none;
  padding: 14px 20px;
  border-radius: 8px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
}

.cta-section {
  background-color: var(--accent);
}

/* responsive heights */
@media (max-width: 991px) {
  .course-img {
    height: auto;
  }
  .info-title {
    font-size: 1rem;
  }
}
@media (max-width: 575.98px) {
  .course-img {
    height: 220px;
  }
  .courses-section {
    padding-bottom: 70px;
  }
}
.course-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.course-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
}

.view-all-card {
  border: 2px dashed #e5e5e5;
  background: linear-gradient(180deg, #fff, #f9f9f9);
  text-align: center;
  transition: border-color 0.4s cubic-bezier(0.4, 0, 0.2, 1), transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.view-all-card:hover {
  border-color: #d32f2f;
  transform: translateY(-4px);
}

.view-all-card i {
  color: #d32f2f;
  background: #f0f0f0;
  border-radius: 50%;
  padding: 20px;
  transition: color 0.4s cubic-bezier(0.4, 0, 0.2, 1), background 0.4s cubic-bezier(0.4, 0, 0.2, 1), transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.view-all-card:hover i {
  color: #fff;
  background: #d32f2f;
  transform: scale(1.1) rotate(5deg);
}

.view-all-card .btn-accent {
  background: #d32f2f;
  color: #fff;
  border: none;
  transition: background 0.3s cubic-bezier(0.4, 0, 0.2, 1), transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.view-all-card .btn-accent:hover {
  background: #b71c1c;
  transform: translateY(-2px) scale(1.05);
}

/* courses css end  */
div#block-xuan-theme-views-block-contact-block-1 {
  font-family: "Geist";
  color: black;
}

.webform-submission-contact-us-form-form label {
  display: none;
}

/* styles for team member nodes */
.team-member {
  display: flex;
  align-items: flex-start;
  margin-bottom: 1.5rem;
}

.team-member-icon img {
  width: 120px;
  height: 120px;
  /* Make it square */
  object-fit: cover;
  /* Cover the frame without distortion */
  border: 2px solid #ccc;
  /* Optional border */
}

.team-member-placeholder {
  width: 120px;
  height: 120px;
  background-color: #e0e0e0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  color: #777;
  border: 2px solid #ccc;
}

.team-member-details {
  flex: 1;
}

.team-member-name {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 600;
}

.team-member-position {
  font-size: 0.95rem;
  color: #666;
}

.team-member-bio {
  margin-top: 0.5rem;
  font-size: 0.9rem;
  background-color: black;
}

.team-member-social a {
  margin-right: 10px;
  font-size: 0.85rem;
  text-decoration: none;
  color: #0073e6;
}

/* Responsive adjustments */
.product-container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  font-family: "Arial", sans-serif;
  color: #fff;
  background: #0d0d0d;
  padding: 20px 25px;
  border-radius: 10px;
}

.relavent-package a {
  background: rgba(255, 0, 0, 0.1);
  border-radius: 8px;
  color: #ff1a1a;
  font-weight: 500;
  border: 1px solid rgba(255, 0, 0, 0.2);
  transition: all 0.3s ease;
  padding: 10px 15px;
  text-decoration: none;
}

.relavent-package a:hover {
  background: #ff1a1a;
  box-shadow: 0 4px 15px rgba(255, 0, 0, 0.3);
  text-decoration: none;
  color: #fff;
}

.product-body * {
  color: #fff !important;
  line-height: 1.6;
  background: transparent !important;
  font-size: 14px !important;
}

.product-body p {
  color: #fff !important;
  line-height: 1.6;
  background: transparent !important;
  font-size: 14px !important;
}

.product-body-12 {
  background: none !important;
  color: #fff !important;
}

.product-body-12 p {
  background: none !important;
  color: #fff !important;
  font-size: 16px !important;
  line-height: 1.5;
}

.product-body-12 li div {
  background: none !important;
  color: #fff !important;
}

.single-table p {
  color: #000 !important;
}

/* --- Product Images --- */
.product-images {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.product-main-image img {
  width: 400px;
  height: 400px;
  border-radius: 10px;
  border: 2px solid rgba(237, 28, 35, 0.2901960784);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.product-thumbnails {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  /* 3 images per row */
  gap: 10px;
  margin-top: 10px;
  width: 400px;
}

.product-thumbnails img {
  width: 100%;
  /* Fill the grid cell */
  aspect-ratio: 1/1;
  border: 2px solid #444;
  border-radius: 5px;
  cursor: pointer;
  transition: border 0.3s ease, transform 0.3s ease;
}

/* --- Product Details --- */
.product-details {
  flex: 1 1 40%;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.product-title {
  font-size: 2em;
  color: var(--accent);
  /* Red title */
  margin: 0;
}

.product-pricing {
  display: flex;
  align-items: baseline;
  gap: 15px;
}

.product-price {
  font-size: 1.5em;
  color: var(--accent);
  /* Red price */
  font-weight: bold;
}

.product-list-price {
  font-size: 1em;
  color: #888;
  text-decoration: line-through;
}

/* --- Add to Cart Button --- */
.add-to-cart {
  padding: 12px 20px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
}

.add-to-cart:hover {
  background: #ff3b3b;
  color: #fff;
  transform: translateY(-2px);
}

/* --- Tabs --- */
.product-tabs {
  width: 100%;
}

.flex-1 {
  flex: 1;
  text-align: center;
}

.product-tabs ul {
  display: flex;
  list-style: none;
  padding: 0;
  border-radius: 10px;
  background: rgba(116, 58, 58, 0);
  background: rgba(156, 36, 36, 0.1294117647);
}

.product-tabs li {
  padding: 10px 20px;
  cursor: pointer;
  transition: all 0.3s ease;
  border-bottom: 2px solid transparent;
  color: #ccc;
}

.product-tabs li.active {
  border-bottom-color: var(--accent);
  font-weight: bold;
  color: var(--accent);
  background: rgba(255, 0, 0, 0.1);
  border-radius: 8px;
}

.tab-content-wrapper {
  width: 100%;
  margin-top: 20px;
}

.tab-content {
  display: block;
}

.tab-content h2 {
  margin-top: 0;
  color: var(--accent);
}

.product-description {
  color: #ddd;
  line-height: 1.6;
}

.added-to-cart {
  padding: 12px 20px;
  background: rgba(255, 0, 0, 0.1019607843);
  color: #fff;
  border: 1px solid var(--accent);
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
}

#commerce-product-add-to-cart-form form label {
  color: #fff !important;
}

#commerce-product-add-to-cart-form form .form-submit {
  background: var(--accent) !important;
  color: #fff !important;
}

#commerce-product-add-to-cart-form form .form-submit:hover {
  background: #c31f26 !important;
}

.button--add-to-cart {
  background: var(--accent) !important;
  color: #fff !important;
}

.button--add-to-cart:hover {
  background: #c31f26 !important;
}

.js-form-required {
  color: #f30707 !important;
}

body.path-product main {
  background: #fff !important;
}

.review {
  border-bottom: 1px solid #444;
  padding: 10px 0;
  color: #ccc;
}

.review p {
  margin: 5px 0 0;
}

#tab-menu li:hover {
  color: #ff4d4d;
  background: rgba(255, 0, 0, 0.1);
  border-radius: 8px;
}

.page-node-type-team-member #block-xuan-theme-content {
  background: #fff;
}

.team-card {
  background: rgba(0, 0, 0, 0.95);
  backdrop-filter: blur(10px);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255, 0, 0, 0.2);
  color: #f5f5f5;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.profile-img {
  width: 100%;
  object-fit: fill;
  border-right: 1px solid var(--accent);
  border-radius: 10px;
  box-shadow: 0 0 8px rgba(255, 0, 0, 0.2);
  width: 350px;
  border: 4px solid #fff;
  object-fit: cover;
  height: 350px;
}

.team-card:hover {
  box-shadow: 0 20px 60px rgba(255, 0, 0, 0.35);
}

/* === DETAILS SECTION === */
.details-section {
  padding: 20px;
  background: linear-gradient(to bottom right, #0d0d0d 0%, #1a1a1a 100%);
  color: #ddd;
}

.member-name {
  font-size: 2.5rem;
  font-weight: 800;
  background: linear-gradient(135deg, #ff1a1a 0%, #b30000 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 10px;
  letter-spacing: -0.5px;
  color: #fff;
}

.member-position {
  display: inline-block;
  background: rgba(255, 0, 0, 0.1);
  border: 1px solid rgba(255, 0, 0, 0.3);
  color: var(--accent);
  padding: 8px 18px;
  border-radius: 30px;
  font-size: 0.85rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 25px;
}

.member-bio {
  line-height: 1.8;
  border-radius: 12px;
  color: #e0e0e0;
}

.member-bio p {
  font-size: 16px;
}

.member-bio * {
  background: transparent !important;
  color: #e0e0e0 !important;
}

.member-achievements {
  font-size: 1rem;
  color: #e6e6e6;
  padding: 15px 20px;
  z-index: 2;
  position: relative;
  text-align: left;
}

.member-achievements ul {
  list-style: none;
  padding-left: 0;
}

.member-achievements li::before {
  content: "- ";
  color: #ff3333;
}

.member-date {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: rgba(255, 0, 0, 0.1);
  border-radius: 10px;
  color: #ff1a1a;
  font-weight: 500;
  border: 1px solid rgba(255, 0, 0, 0.2);
  transition: all 0.3s ease;
}

.member-date i {
  font-size: 1.2rem;
  color: #ff4d4d;
}

.btn-back {
  background: rgba(255, 0, 0, 0.1);
  border-radius: 8px;
  color: #ff1a1a;
  font-weight: 500;
  border: 1px solid rgba(255, 0, 0, 0.2);
  transition: all 0.3s ease;
}

.btn-back:hover {
  background: #ff1a1a;
  box-shadow: 0 4px 15px rgba(255, 0, 0, 0.3);
  text-decoration: none;
  color: #fff;
}

.btn-back-mobile {
  background: rgba(255, 0, 0, 0.1);
  border-radius: 8px;
  color: #ff1a1a;
  font-weight: 500;
  border: 1px solid rgba(255, 0, 0, 0.2);
  transition: all 0.3s ease;
}

.btn-back-mobile:hover {
  background: #ff1a1a;
  box-shadow: 0 4px 15px rgba(255, 0, 0, 0.3);
  text-decoration: none;
  color: #fff;
}

/* === RESPONSIVE === */
@media (max-width: 992px) {
  .details-section {
    padding: 40px 30px;
  }
}
@media (max-width: 768px) {
  .team-card {
    border-radius: 16px;
  }
  .profile-section {
    border-right: none;
    gap: 20px;
  }
  .profile-img {
    object-fit: fill;
    width: 250px;
    height: 250px;
  }
  .details-section {
    padding: 30px 20px;
    text-align: left;
  }
  .member-name {
    font-size: 2rem;
  }
  .custom-product-title-99 {
    display: block !important;
  }
  .custom-product-title-99 .product-title {
    margin-bottom: 10px !important;
  }
}
/* --- Responsive --- */
@media (max-width: 768px) {
  .page-node-type-courses #block-xuan-theme-content {
    padding: 20px 0px !important;
  }
  .product-body-12 .time-table-wrapper {
    flex-direction: column;
  }
  .product-container {
    padding: 20px 15px;
  }
  .product-images,
  .product-details {
    flex: 1 1 100%;
  }
  .product-main-image img {
    max-width: 100%;
    height: 250px;
  }
  .product-thumbnails {
    justify-content: center;
    width: 100%;
  }
  .commerce-product .product-card {
    padding: 24px 5px !important;
  }
  .commerce-product .added-to-cart {
    padding: 12px !important;
    text-align: left;
  }
  .commerce-product .product-info .no-gutters {
    display: block;
  }
}
/* Lesson Calendar Event Styles */
/* Lesson Calendar Event Styles */
.lesson-calendar-event {
  background-color: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 2rem 2.5rem;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.06);
  font-family: "Poppins", "Noto Sans", sans-serif;
  color: #222;
  max-width: 850px;
  margin: 3rem auto;
}

/* Header */
.lesson-header {
  border-bottom: 2px solid #b91c1c;
  margin-bottom: 1.5rem;
  padding-bottom: 0.7rem;
  text-align: center;
}

.lesson-title {
  font-size: 1.9rem;
  font-weight: 600;
  color: #b91c1c;
  margin: 0;
}

/* Edit Button */
.button-edit {
  background: #b91c1c;
  color: #fff;
  padding: 0.45rem 1rem;
  border-radius: 6px;
  font-size: 0.95rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.button-edit:hover {
  opacity: 0.9;
}

/* Meta Grid Layout */
.lesson-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 2rem;
  margin-top: 1rem;
}

.lesson-field {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
}

.lesson-label {
  font-weight: 600;
  color: #444;
  min-width: 140px;
}

.lesson-value {
  color: #333;
  flex: 1;
}

/* Full width fields (like Students later) */
.lesson-field.students {
  grid-column: 1/3;
}

/* Description Box */
.lesson-description {
  background-color: #f9fafb;
  border-top: 1px solid #e5e7eb;
  padding: 1rem;
  border-radius: 8px;
  margin-top: 1.5rem;
}

/* Responsive */
@media (max-width: 640px) {
  .lesson-meta {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
  .lesson-label {
    min-width: 110px;
  }
  .lesson-field.students {
    grid-column: 1/2;
  }
}
.student-level-logo-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.student-level-logo-circle {
  display: flex;
  justify-content: center;
  align-items: center;
}

.student-level-logo-text {
  display: block;
  text-align: center;
  color: var(--accent);
  margin-top: 6px;
  font-weight: 600;
  background: #fff;
  width: fit-content;
  padding: 0px 12px;
  border-radius: 57px;
}

.cstm-horizontal-12 p {
  margin-bottom: 0px;
  padding: 4px 0px;
}

.blog-cstm-image {
  object-fit: cover;
  width: 100%;
  height: auto;
}

body.path-book-a-trail {
  background: #fff !important;
  min-height: 100vh;
}

.contact-us-section {
  background: #fff;
}

.contact-us-wrapper {
  background: none;
  padding: 60px 0;
}

.contact-us-row {
  color: black;
  max-width: 1200px;
  margin: 0 auto;
  align-items: center;
}

.contact-info-static {
  background: rgba(166, 189, 235, 0.1019607843);
  border: 1px solid var(--blue);
  padding: 1.6rem 1.5rem;
  border-radius: 8px;
  min-height: 100%;
}

.contact-info-static h5 {
  color: var(--blue);
}

.contact-form-container {
  color: black;
  padding: 2rem 1.5rem;
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.contact-form-container .contact-header {
  text-align: center;
}
.contact-form-container .contact-header .contact-badge {
  color: var(--accent);
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.contact-form-container .contact-header .contact-title {
  color: #000000;
  font-weight: 600;
  margin-bottom: 1.5rem;
}

.webform-submission-contact-us-form-form .form-item {
  margin-bottom: 1rem;
}
.webform-submission-contact-us-form-form .form-item label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: #333;
}
.webform-submission-contact-us-form-form .form-item input[type=text],
.webform-submission-contact-us-form-form .form-item input[type=email],
.webform-submission-contact-us-form-form .form-item input[type=tel],
.webform-submission-contact-us-form-form .form-item textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  background: #fff;
  transition: border-color 0.3s ease;
}
.webform-submission-contact-us-form-form .form-item input[type=text]:focus,
.webform-submission-contact-us-form-form .form-item input[type=email]:focus,
.webform-submission-contact-us-form-form .form-item input[type=tel]:focus,
.webform-submission-contact-us-form-form .form-item textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(223, 197, 72, 0.1);
}
.webform-submission-contact-us-form-form .form-item input[type=text]::placeholder,
.webform-submission-contact-us-form-form .form-item input[type=email]::placeholder,
.webform-submission-contact-us-form-form .form-item input[type=tel]::placeholder,
.webform-submission-contact-us-form-form .form-item textarea::placeholder {
  color: #888;
}
.webform-submission-contact-us-form-form .form-item textarea {
  min-height: 120px;
  resize: vertical;
}
.webform-submission-contact-us-form-form .webform-actions {
  text-align: left;
  margin-top: 1.5rem;
}
.webform-submission-contact-us-form-form .webform-actions .webform-button--submit {
  background: #e53e3e;
  color: #fff;
  border: none;
  padding: 12px 32px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.3s ease;
}
.webform-submission-contact-us-form-form .webform-actions .webform-button--submit:hover {
  background: #c53030;
  transform: translateY(-1px);
}
.webform-submission-contact-us-form-form .form-item--name,
.webform-submission-contact-us-form-form .form-item--e-mail {
  display: inline-block;
  width: calc(50% - 10px);
  margin-right: 20px;
}
.webform-submission-contact-us-form-form .form-item--name:last-child,
.webform-submission-contact-us-form-form .form-item--e-mail:last-child {
  margin-right: 0;
}
@media (max-width: 768px) {
  .webform-submission-contact-us-form-form .form-item--name,
  .webform-submission-contact-us-form-form .form-item--e-mail {
    display: block;
    width: 100%;
    margin-right: 0;
  }
}

.trail-appointment-wrapper {
  max-width: 960PX;
  margin: 0 auto;
  padding: 1rem;
  border-radius: 8px;
  background: #fff;
}

.trail-form-header {
  text-align: center;
  margin-bottom: 2rem;
}
.trail-form-header .trail-form-title {
  color: var(--accent);
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}
.trail-form-header .trail-form-subtitle {
  color: #fff;
  font-size: 1rem;
  margin-bottom: 0;
}

.trail-appointment-form {
  background: #ffffff;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  border: 1px solid #f5f1e8;
  padding: 0 2rem 2rem 2rem;
  width: 85%;
  margin: 0 auto;
}
.trail-appointment-form .trail-form-row {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.trail-appointment-form .trail-form-field {
  flex: 1;
}
@media (max-width: 768px) {
  .trail-appointment-form .trail-form-field {
    margin-bottom: 1.5rem;
  }
}
.trail-appointment-form .trail-form-field .form-item {
  margin-bottom: 0;
}
.trail-appointment-form .trail-form-field label {
  display: block;
  font-weight: 600;
  color: #333;
  margin-bottom: 0.5rem;
  font-size: 14px;
}
.trail-appointment-form .trail-form-field input[type=text],
.trail-appointment-form .trail-form-field input[type=email],
.trail-appointment-form .trail-form-field input[type=tel],
.trail-appointment-form .trail-form-field input[type=date] {
  width: 100%;
  padding: 12px 16px;
  border: 2px solid #e1e5e9;
  border-radius: 6px;
  font-size: 14px;
  background: #fff;
  transition: all 0.3s ease;
  box-sizing: border-box;
}
.trail-appointment-form .trail-form-field input[type=text]:focus,
.trail-appointment-form .trail-form-field input[type=email]:focus,
.trail-appointment-form .trail-form-field input[type=tel]:focus,
.trail-appointment-form .trail-form-field input[type=date]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(223, 197, 72, 0.1);
  transform: translateY(-1px);
}
.trail-appointment-form .trail-form-field input[type=text]::placeholder,
.trail-appointment-form .trail-form-field input[type=email]::placeholder,
.trail-appointment-form .trail-form-field input[type=tel]::placeholder,
.trail-appointment-form .trail-form-field input[type=date]::placeholder {
  color: #999;
  font-style: normal;
  font-weight: 400;
}
.trail-appointment-form .trail-form-field input[type=date] {
  color: #555;
}
.trail-appointment-form .trail-form-field input[type=date]:focus, .trail-appointment-form .trail-form-field input[type=date]:valid {
  color: #333;
}
.trail-appointment-form .trail-form-field input[type=date]::-webkit-calendar-picker-indicator {
  color: #666;
  cursor: pointer;
}
.trail-appointment-form .trail-form-actions {
  text-align: center;
  margin-top: 2rem;
}
.trail-appointment-form .trail-form-actions input,
.trail-appointment-form .trail-form-actions button,
.trail-appointment-form .trail-form-actions .webform-button--submit,
.trail-appointment-form .trail-form-actions input[type=submit],
.trail-appointment-form .trail-form-actions .form-submit {
  background: #e53e3e !important;
  color: #fff !important;
  border: none !important;
  padding: 15px 50px !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
  font-size: 16px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 3px 12px rgba(229, 62, 62, 0.3) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  min-width: 200px !important;
  display: inline-block !important;
  text-decoration: none !important;
}
.trail-appointment-form .trail-form-actions input:hover,
.trail-appointment-form .trail-form-actions button:hover,
.trail-appointment-form .trail-form-actions .webform-button--submit:hover,
.trail-appointment-form .trail-form-actions input[type=submit]:hover,
.trail-appointment-form .trail-form-actions .form-submit:hover {
  background: #c53030 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 5px 16px rgba(229, 62, 62, 0.4) !important;
}
.trail-appointment-form .trail-form-actions input:active,
.trail-appointment-form .trail-form-actions button:active,
.trail-appointment-form .trail-form-actions .webform-button--submit:active,
.trail-appointment-form .trail-form-actions input[type=submit]:active,
.trail-appointment-form .trail-form-actions .form-submit:active {
  transform: translateY(0) !important;
  box-shadow: 0 2px 8px rgba(229, 62, 62, 0.3) !important;
}
.trail-appointment-form .trail-form-actions input:focus,
.trail-appointment-form .trail-form-actions button:focus,
.trail-appointment-form .trail-form-actions .webform-button--submit:focus,
.trail-appointment-form .trail-form-actions input[type=submit]:focus,
.trail-appointment-form .trail-form-actions .form-submit:focus {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(229, 62, 62, 0.2) !important;
}
.trail-appointment-form .form-submit {
  background: var(--accent);
  width: 100%;
  padding: 0.5rem;
  color: #fff;
  margin-top: 20px;
}
.trail-appointment-form .form-submit:hover {
  background: #000;
  color: #fff;
}

.appointment-section-23 {
  background-color: #f7f2e9;
}

@media (max-width: 991px) {
  .trail-appointment-form {
    padding: 1rem;
    width: 100%;
  }
  .trail-appointment-wrapper {
    overflow-x: auto; /* better than scroll */
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    box-sizing: border-box;
  }
  .trail-form-row {
    display: block !important;
  }
  .contact-us-wrapper {
    padding: 50px 10px;
  }
  .contact-form-container {
    padding: 50px 10px;
  }
  .custom-exposed-filter-55 {
    padding-left: 0px;
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
body.path-blogs {
  background: #fff !important;
}

.blog-sidebar {
  padding: 1.5rem;
  background: #fff;
  border: 1px solid #e9ecef;
  border-radius: 8px;
  margin-bottom: 2rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.blog-sidebar .search-section {
  margin-bottom: 2rem;
}
.blog-sidebar .search-section h5 {
  font-weight: 600;
  margin-bottom: 1rem;
  color: #333;
}
.blog-sidebar .search-section .form-control {
  margin-bottom: 0.5rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 8px 12px;
}
.blog-sidebar .search-section .btn {
  width: 100%;
  padding: 8px 16px;
  border-radius: 4px;
}
.blog-sidebar .recent-posts {
  margin-bottom: 2rem;
}
.blog-sidebar .recent-posts h5 {
  font-weight: 700;
  margin-bottom: 1.5rem;
  color: #333;
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 2px solid var(--accent);
  padding-bottom: 0.5rem;
  position: relative;
}
.blog-sidebar .recent-posts h5::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 30px;
  height: 2px;
  background: var(--accent);
}
.blog-sidebar .recent-posts .recent-post-item {
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #eee;
}
.blog-sidebar .recent-posts .recent-post-item:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.blog-sidebar .recent-posts .recent-post-item img {
  width: 60px;
  height: 100px;
  margin-right: 1rem;
  border-radius: 6px;
  object-fit: cover;
  flex-shrink: 0;
  border: 1px solid #e9ecef;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}
.blog-sidebar .recent-posts .recent-post-item .recent-post-content {
  flex: 1;
}
.blog-sidebar .recent-posts .recent-post-item .recent-post-content h6 {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 0.5rem;
  line-height: 1.4;
  color: #2c3e50;
}
.blog-sidebar .recent-posts .recent-post-item .recent-post-content h6 a {
  color: #2c3e50;
  text-decoration: none;
  transition: all 0.3s ease;
}
.blog-sidebar .recent-posts .recent-post-item .recent-post-content h6 a:hover {
  color: var(--accent);
}
.blog-sidebar .recent-posts .recent-post-item .recent-post-content small {
  color: #666;
  font-size: 12px;
}
.blog-sidebar .archives {
  margin-bottom: 2rem;
}
.blog-sidebar .archives h5 {
  font-weight: 600;
  margin-bottom: 1rem;
  color: #333;
}
.blog-sidebar .archives ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.blog-sidebar .archives ul li {
  margin-bottom: 0.5rem;
}
.blog-sidebar .archives ul li a {
  color: #666;
  text-decoration: none;
  font-size: 14px;
}
.blog-sidebar .archives ul li a:hover {
  color: var(--accent);
  text-decoration: underline;
}
.blog-sidebar .tags h5 {
  font-weight: 600;
  margin-bottom: 1rem;
  color: #333;
}
.blog-sidebar .tags .tag-cloud .tag {
  display: inline-block;
  background: #e9ecef;
  color: #666;
  padding: 4px 8px;
  margin: 2px;
  border-radius: 12px;
  font-size: 12px;
  text-decoration: none;
  transition: all 0.3s ease;
}
.blog-sidebar .tags .tag-cloud .tag:hover {
  background: var(--accent);
  color: #fff;
}

.blog-main-content {
  background: #fff;
}
.blog-main-content .blog-archive-post {
  margin-bottom: 2rem;
  padding: 1.5rem;
  background: #f7f2e9;
  border: 1px solid #e9ecef;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.blog-main-content .blog-archive-post .blog-title,
.blog-main-content .blog-archive-post h4 {
  margin-bottom: 0.5rem;
}
.blog-main-content .blog-archive-post .blog-title a,
.blog-main-content .blog-archive-post h4 a {
  color: #333;
  text-decoration: none;
  font-weight: 600;
}
.blog-main-content .blog-archive-post .blog-title a:hover,
.blog-main-content .blog-archive-post h4 a:hover {
  color: var(--accent);
}
.blog-main-content .blog-archive-post .blog-meta {
  color: #666;
  font-size: 14px;
  margin-bottom: 1rem;
}
.blog-main-content .blog-archive-post .blog-excerpt {
  color: #555;
  line-height: 1.6;
  font-size: 15px;
}
.blog-main-content .blog-archive-post img {
  border-radius: 8px;
  object-fit: cover;
  height: 200px;
  width: 100%;
  aspect-ratio: 1;
  border: 2px solid #e9ecef;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
}
.blog-main-content .blog-archive-post img:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transform: translateY(-2px);
}
.blog-main-content hr {
  display: none;
}
.blog-main-content .pagination-wrapper {
  margin-top: 3rem;
  text-align: center;
}
.blog-main-content .pagination-wrapper .pagination {
  justify-content: center;
  margin-bottom: 0;
}
.blog-main-content .pagination-wrapper .pagination .page-link {
  color: #666;
  border: 1px solid #ddd;
  padding: 10px 16px;
  margin: 0 2px;
  border-radius: 4px;
  text-decoration: none;
  transition: all 0.3s ease;
}
.blog-main-content .pagination-wrapper .pagination .page-link:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  transform: translateY(-1px);
}
.blog-main-content .pagination-wrapper .pagination .page-item.active .page-link {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

@media (max-width: 768px) {
  .blog-sidebar {
    margin-bottom: 2rem;
  }
  .blog-main-content .blog-archive-post .row {
    flex-direction: column;
  }
  .blog-main-content .blog-archive-post img {
    margin-bottom: 1rem;
    height: 250px;
    width: 100%;
    border: 2px solid #e9ecef;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }
}
.webform-submission-newspaper-form .alert,
.webform-submission-contact-us-form-add-form .alert {
  position: fixed !important;
  top: 30px !important;
  right: 30px !important;
  z-index: 9999 !important;
  background: #ffffff !important;
  padding: 20px 25px !important;
  border-left: 6px solid #28a745 !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15) !important;
  font-size: 16px !important;
  text-align: left !important;
  max-width: 350px !important;
  width: fit-content !important;
  animation: slideIn 0.3s ease-out !important;
  padding-right: 40px !important;
}

.webform-submission-newspaper-form .btn-close {
  position: absolute !important;
  top: 8px !important;
  right: 10px !important;
  opacity: 0.6 !important;
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.lesson-simple-repeater-form {
  padding: 50px 0;
}

.lesson-simple-repeater-form div#edit-wrapper {
  background: #000;
  width: 650px;
  padding: 25px;
  border-radius: 8px;
}

.lesson-simple-repeater-form .form-check-label {
  color: #fff;
}

.lesson-simple-repeater-form .form-submit {
  background: var(--accent);
  padding: 10px 15px;
  border-radius: 8px;
  color: #fff;
}

.lesson-simple-repeater-form .form-submit:hover {
  background: #fff;
  color: #000;
}

.lesson-repeater-title {
  color: var(--accent);
  margin-bottom: 30px;
  text-align: center;
}

@media (max-width: 768px) {
  .lesson-simple-repeater-form div#edit-wrapper {
    width: 90% !important;
    margin: 0 auto;
  }
}
.path-user .card-header {
  background: var(--blue);
  color: #fff;
}
.path-user .icon-btns {
  text-decoration: none;
  position: relative;
  cursor: pointer;
}
.path-user .icon-btns .tooltip-text {
  visibility: hidden;
  opacity: 0;
  width: auto;
  background: #000;
  color: #fff;
  text-align: center;
  border-radius: 4px;
  padding: 4px 8px;
  position: absolute;
  top: -28px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 12px;
  white-space: nowrap;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
.path-user .icon-btns:hover .tooltip-text {
  visibility: visible;
  opacity: 1;
}
.path-user .about-student-12 h4,
.path-user .text-primary {
  color: var(--blue) !important;
}
.path-user .cstm-btn-accent-12 {
  background: var(--accent);
  color: #fff;
  padding: 8px 12px;
}
.path-user .cstm-btn-accent-12:hover {
  background: #000;
  color: #fff;
}
.path-user .user-profile .profile-header {
  background: #f2f5f8;
}

.user-profile .profile-header {
  transition: all 0.2s ease;
}
.user-profile .profile-header .profile-picture-wrapper .profile-picture,
.user-profile .profile-header .profile-picture-wrapper .profile-picture-placeholder {
  transition: all 0.2s ease;
}
.user-profile .profile-header .profile-picture-wrapper .profile-picture img,
.user-profile .profile-header .profile-picture-wrapper .profile-picture-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.user-profile .profile-header .profile-picture-wrapper .profile-picture-placeholder i {
  opacity: 0.6;
}
.user-profile .profile-header .profile-info .profile-name {
  font-weight: 600;
}
@media (max-width: 768px) {
  .user-profile .profile-header .profile-info .profile-name {
    font-size: 1.5rem;
    text-align: center;
  }
}
.user-profile .profile-section .card,
.user-profile .profile-sidebar-section .card {
  transition: all 0.2s ease;
}
.user-profile .profile-section .card:hover,
.user-profile .profile-sidebar-section .card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.user-profile .profile-section .card .card-header .card-title,
.user-profile .profile-sidebar-section .card .card-header .card-title {
  font-weight: 600;
}
.user-profile .profile-section .card .card-header .card-title i,
.user-profile .profile-sidebar-section .card .card-header .card-title i {
  opacity: 0.8;
}
.user-profile .profile-section .card .card-body .contact-item,
.user-profile .profile-section .card .card-body .field-item,
.user-profile .profile-sidebar-section .card .card-body .contact-item,
.user-profile .profile-sidebar-section .card .card-body .field-item {
  padding: 0.75rem 0;
  border-bottom: 1px solid #f8f9fa;
}
.user-profile .profile-section .card .card-body .contact-item:last-child,
.user-profile .profile-section .card .card-body .field-item:last-child,
.user-profile .profile-sidebar-section .card .card-body .contact-item:last-child,
.user-profile .profile-sidebar-section .card .card-body .field-item:last-child {
  border-bottom: none;
}
.user-profile .profile-section .card .card-body .contact-item strong,
.user-profile .profile-section .card .card-body .field-item strong,
.user-profile .profile-sidebar-section .card .card-body .contact-item strong,
.user-profile .profile-sidebar-section .card .card-body .field-item strong {
  font-weight: 600;
}
.user-profile .profile-section .card .card-body .contact-item .field-value,
.user-profile .profile-section .card .card-body .field-item .field-value,
.user-profile .profile-sidebar-section .card .card-body .contact-item .field-value,
.user-profile .profile-sidebar-section .card .card-body .field-item .field-value {
  margin-top: 0.25rem;
}
.user-profile .profile-section .card .card-body .contact-item .field-value:empty::after,
.user-profile .profile-section .card .card-body .field-item .field-value:empty::after,
.user-profile .profile-sidebar-section .card .card-body .contact-item .field-value:empty::after,
.user-profile .profile-sidebar-section .card .card-body .field-item .field-value:empty::after {
  content: "Not provided";
  color: #6c757d;
  font-style: italic;
  font-size: 0.9rem;
}
.user-profile .profile-section .card .card-body .account-stats .stat-item,
.user-profile .profile-sidebar-section .card .card-body .account-stats .stat-item {
  transition: all 0.2s ease;
}
.user-profile .profile-section .card .card-body .account-stats .stat-item:hover,
.user-profile .profile-sidebar-section .card .card-body .account-stats .stat-item:hover {
  background-color: #f8f9fa;
  margin: 0 -1rem;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
  border-radius: 4px;
}
.user-profile .profile-section .card .card-body .account-stats .stat-item:last-child,
.user-profile .profile-sidebar-section .card .card-body .account-stats .stat-item:last-child {
  border-bottom: none !important;
}
.user-profile .profile-section .card .card-body .account-stats .stat-item .stat-label,
.user-profile .profile-sidebar-section .card .card-body .account-stats .stat-item .stat-label {
  font-weight: 500;
}
.user-profile .profile-section .card .card-body .account-stats .stat-item .stat-label i,
.user-profile .profile-sidebar-section .card .card-body .account-stats .stat-item .stat-label i {
  width: 16px;
  text-align: center;
  opacity: 0.7;
}
.user-profile .profile-section .card .card-body .account-stats .stat-item .stat-value,
.user-profile .profile-sidebar-section .card .card-body .account-stats .stat-item .stat-value {
  font-weight: 500;
}
.user-profile .profile-section .card .card-body .account-stats .stat-item .stat-value .badge,
.user-profile .profile-sidebar-section .card .card-body .account-stats .stat-item .stat-value .badge {
  font-size: 0.75rem;
  padding: 0.35em 0.65em;
}
.user-profile .profile-section .card .card-body .d-grid .btn,
.user-profile .profile-sidebar-section .card .card-body .d-grid .btn {
  font-weight: 500;
  transition: all 0.2s ease;
}
.user-profile .profile-section .card .card-body .d-grid .btn:hover,
.user-profile .profile-sidebar-section .card .card-body .d-grid .btn:hover {
  transform: translateY(-1px);
}
.user-profile .card details summary {
  cursor: pointer;
}
.user-profile .card details summary:hover {
  background-color: #f8f9fa;
}
.user-profile .card details pre {
  background-color: #f8f9fa;
  border: 1px solid #dee2e6;
  border-radius: 4px;
  padding: 1rem;
  max-height: 400px;
  overflow-y: auto;
}
.user-profile .std-excellance-level {
  margin-right: 15px;
}

.profile-header.custom.level-basic {
  background-image: url("/sites/default/files/inline-images/1.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.level-basic .routine-popup-title,
.level-basic .routine-check-icon {
  color: #1E4FA3;
}

.level-basic .routine-popup-list li {
  border-left: 4px solid #1E4FA3;
}

.profile-header.custom.level-intermediate {
  background-image: url("/sites/default/files/inline-images/2.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.level-intermediate .routine-popup-title,
.level-intermediate .routine-check-icon {
  color: #5A6B7A;
}

.level-intermediate .routine-popup-list li {
  border-left: 4px solid #5A6B7A;
}

.profile-header.custom.level-advanced {
  background-image: url("/sites/default/files/inline-images/3.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.level-advanced .routine-popup-title,
.level-advanced .routine-check-icon {
  color: #C82426;
}

.level-advanced .routine-popup-list li {
  border-left: 4px solid #C82426;
}

.profile-header.custom.level-elite {
  background-image: url("/sites/default/files/inline-images/4.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.level-elite .routine-popup-title,
.level-elite .routine-check-icon {
  color: #D4A017;
}

.level-elite .routine-popup-list li {
  border-left: 4px solid #D4A017;
}

.custom-student-profile-55 .level-basic .attended-section h2 {
  color: #1E4FA3;
}

.student-excellence-level-1 {
  color: #c09722;
}

.user-profile-compact {
  transition: all 0.2s ease;
}
.user-profile-compact:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.user-profile-compact .card-body .profile-picture-wrapper .profile-picture img,
.user-profile-compact .card-body .profile-picture-wrapper .profile-picture-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.user-profile-compact .card-body .profile-name {
  font-weight: 600;
}
.user-profile-compact .card-body .user-roles .badge {
  font-size: 0.7rem;
  padding: 0.3em 0.6em;
  margin: 0 0.2rem 0.2rem 0;
}
.user-profile-compact .card-body .profile-actions .btn {
  font-weight: 500;
  transition: all 0.2s ease;
}
.user-profile-compact .card-body .profile-actions .btn:hover {
  transform: translateY(-1px);
}

.user-profile-teaser {
  transition: all 0.2s ease;
  overflow: hidden;
}
.user-profile-teaser:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.user-profile-teaser .profile-header .profile-picture-wrapper .profile-picture img,
.user-profile-teaser .profile-header .profile-picture-wrapper .profile-picture-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.user-profile-teaser .card-body .profile-name {
  font-weight: 600;
}
.user-profile-teaser .card-body .user-roles .badge {
  font-size: 0.7rem;
  padding: 0.3em 0.6em;
  margin: 0 0.2rem 0.2rem 0;
}
.user-profile-teaser .card-body .bio-excerpt {
  line-height: 1.5;
  max-height: 4.5em;
  overflow: hidden;
  text-overflow: ellipsis;
}
.user-profile-teaser .card-footer .btn {
  font-weight: 500;
  transition: all 0.2s ease;
}
.user-profile-teaser .card-footer .btn:hover {
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .user-profile .profile-header {
    text-align: center;
  }
  .user-profile .profile-header .profile-picture-wrapper {
    margin-bottom: 1rem;
  }
  .user-profile .profile-section,
  .user-profile .profile-sidebar-section {
    margin-bottom: 1.5rem;
  }
  .user-profile-teaser .card-footer .d-md-flex {
    flex-direction: column !important;
    gap: 0.5rem;
  }
}
@media (max-width: 576px) {
  .user-profile .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .user-profile .profile-section .card .card-body,
  .user-profile .profile-sidebar-section .card .card-body {
    padding: 1rem;
  }
}
@media print {
  .user-profile .profile-actions,
  .user-profile .profile-sidebar-section {
    display: none !important;
  }
  .user-profile .card {
    box-shadow: none !important;
    border: 1px solid #000 !important;
  }
  .user-profile .profile-header {
    background: #fff !important;
  }
}
.img-fluid {
  max-width: 100%;
  height: 412px;
  object-fit: cover;
}

.custom-node-122 body {
  background-color: #f8f9fa;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
}
.custom-node-122 .card {
  border: none;
  border-radius: 1rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.2s;
}
.custom-node-122 .branch-dashboard {
  width: 100%;
  margin: 0;
  padding: 25px;
  border-radius: 8px;
  background: #f2f5f8;
}
.custom-node-122 .profile-picture {
  width: 120px;
  height: 120px;
  border: 3px solid var(--blue);
}
.custom-node-122 .profile-picture img {
  object-fit: cover;
}
.custom-node-122 .dash-tile {
  transition: all 0.3s ease;
  border-radius: 1rem !important;
}
.custom-node-122 .dash-tile:hover {
  transform: translateY(-6px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
}
.custom-node-122 .icon-circle {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  transition: transform 0.3s ease;
}
.custom-node-122 .dash-tile:hover .icon-circle {
  transform: scale(1.1);
}
.custom-node-122 .card {
  border-radius: 1rem !important;
}
.custom-node-122 .profile-card {
  border-right: 2px solid var(--blue);
}
.custom-node-122 .cstm-btn-outline-primary {
  border: 1px solid var(--blue);
  background: transparent;
  color: var(--blue);
}
.custom-node-122 .cstm-btn-outline-primary:hover {
  background-color: var(--blue);
  color: #fff;
}

@media (max-width: 991px) {
  .custom-node-122 .branch-dashboard {
    padding: 0px;
  }
  .custom-node-122 .profile-card {
    padding-right: 0px !important;
    border-right: unset;
  }
  .custom-node-122 .card-footer {
    margin: 10px;
  }
  .custom-node-122 .quick-acc-main {
    padding: 10px;
  }
}
.custom-node-blog-55 {
  /* === GRID === */
}
.custom-node-blog-55 .views-view-responsive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
}
.custom-node-blog-55 {
  /* === GLOBAL === */
}
.custom-node-blog-55 .page-node-type-blog #block-xuan-theme-content {
  background: #fff;
}
.custom-node-blog-55 .blog-main-wrapper {
  background: #111;
  padding: 40px;
  border-radius: 12px;
  box-shadow: 0 0 20px rgba(255, 255, 255, 0.05);
}
.custom-node-blog-55 .blog-container {
  font-family: "Segoe UI", Arial, sans-serif;
  color: #e6e6e6;
  border-radius: 10px;
  background-color: #0d0d0d;
  padding: 25px;
}
.custom-node-blog-55 {
  /* === HEADER === */
}
.custom-node-blog-55 .blog-title {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.3;
  color: #fff;
}
.custom-node-blog-55 .blog-meta {
  font-size: 0.95rem;
  color: #bbb;
}
.custom-node-blog-55 .blog-meta .author {
  font-weight: 500;
  color: #fff;
}
.custom-node-blog-55 {
  /* === BODY === */
}
.custom-node-blog-55 .blog-body p {
  line-height: 1.8;
  margin-bottom: 1.25rem;
  color: #ddd;
  word-wrap: break-word;
}
.custom-node-blog-55 .blog-body img {
  border-radius: 8px;
  margin: 1em 0;
  max-width: 100%;
  height: auto;
}
.custom-node-blog-55 .blog-body * {
  color: #ddd;
  font-size: 1rem;
}
.custom-node-blog-55 {
  /* === RELATED BLOGS === */
}
.custom-node-blog-55 .related-blogs {
  background: #111;
  padding: 1.5em;
  border-radius: 10px;
  border: 1px solid #222;
  margin-top: 2.5em;
}
.custom-node-blog-55 .related-blogs h2 {
  font-size: 1.3em;
  font-weight: 600;
  margin-bottom: 1em;
  color: #ff1a1a;
  text-transform: uppercase;
  border-bottom: 2px solid #ff1a1a;
  display: inline-block;
  padding-bottom: 4px;
}
.custom-node-blog-55 .related-blogs .card {
  background: #1a1a1a;
  border: 1px solid #222;
  border-radius: 10px;
  transition: all 0.3s ease;
}
.custom-node-blog-55 .related-blogs .card:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 16px rgba(255, 0, 0, 0.25);
  border-color: #ff1a1a;
}
.custom-node-blog-55 .related-blogs .card-body a {
  color: #fff;
  font-weight: 600;
  text-decoration: none;
}
.custom-node-blog-55 .related-blogs .card-body a:hover {
  color: var(--accent);
  text-decoration: underline;
}
.custom-node-blog-55 {
  /* === SIDEBAR === */
}
.custom-node-blog-55 .sidebar {
  background: #0d0d0d;
  padding: 1.5rem;
  padding-top: 0;
  border-radius: 10px;
}
.custom-node-blog-55 .sidebar-block h3 {
  border-bottom: 2px solid #ff1a1a;
  color: #fff;
  padding-bottom: 0.5rem;
}
.custom-node-blog-55 .sidebar a {
  color: #bbb;
  transition: color 0.3s ease;
}
.custom-node-blog-55 .sidebar a:hover {
  color: #ff1a1a;
}
.custom-node-blog-55 .tags .badge {
  background-color: #393939;
  color: #fff;
  font-size: 0.9rem;
  border-radius: 50px;
  padding: 0.4rem 0.9rem;
  margin: 3px;
  transition: background 0.3s;
}
.custom-node-blog-55 .tags .badge:hover {
  background-color: #b30000 !important;
}
.custom-node-blog-55 {
  /* === RECENT BLOGS VIEW === */
}
.custom-node-blog-55 .recent-blogs-wrapper {
  background: #0d0d0d;
}
.custom-node-blog-55 .recent-blogs-wrapper .section-title {
  font-size: 1.5em;
  font-weight: 600;
  margin-bottom: 1em;
  text-align: left;
  color: #ff1a1a;
  text-transform: uppercase;
}
.custom-node-blog-55 .recent-blogs-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5em;
}
.custom-node-blog-55 .recent-blogs-grid .views-row {
  background: #1a1a1a;
  border: 1px solid #222;
  border-radius: 10px;
  overflow: hidden;
  transition: all 0.3s ease;
}
.custom-node-blog-55 .recent-blogs-grid .views-row:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 16px rgba(255, 0, 0, 0.25);
  border-color: #ff1a1a;
}
.custom-node-blog-55 .recent-blogs-grid img {
  width: 100%;
  height: 160px;
  object-fit: cover;
}
.custom-node-blog-55 .recent-blogs-grid .views-field-title {
  padding: 1em;
}
.custom-node-blog-55 .recent-blogs-grid .views-field-title a {
  color: #ff1a1a;
  text-decoration: none;
  font-weight: 600;
  transition: color 0.2s ease;
}
.custom-node-blog-55 .recent-blogs-grid .views-field-title a:hover {
  color: #fff;
  text-decoration: underline;
}
.custom-node-blog-55 {
  /* === COMMENTS === */
}
.custom-node-blog-55 .blog-comments h2 {
  border-bottom: 2px solid #ff1a1a;
  padding-bottom: 6px;
}
.custom-node-blog-55 {
  /* === UTILITIES === */
}
.custom-node-blog-55 a,
.custom-node-blog-55 a:visited {
  color: #ff1a1a;
}
.custom-node-blog-55 a:hover {
  color: #fff;
}
.custom-node-blog-55 .text-red {
  color: #ff1a1a;
}
.custom-node-blog-55 .bg-black {
  background-color: #000;
}

@media (min-width: 768px) {
  .custom-node-blog-55 .recent-blogs-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  }
}
.custom-student-profile-55 {
  max-width: 1320px;
  margin: 0 auto;
  background: white;
  border-radius: 20px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  overflow: hidden;
}

.custom-student-profile-55 .std-excellance-level {
  background: #fff;
  width: fit-content;
  padding: 2px 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 57px;
}
.custom-student-profile-55 .std-excellance-level-1 {
  font-size: 18px;
  font-weight: 600;
}
.custom-student-profile-55 {
  /* Apply button */
}
.custom-student-profile-55 input.form-submit[value=Apply] {
  background-color: var(--blue);
  color: #fff;
  margin-top: 21px;
}
.custom-student-profile-55 {
  /* Reset button */
}
.custom-student-profile-55 input.form-submit[value=Reset] {
  background-color: #000;
  color: #fff;
  margin-top: 21px;
  margin-left: 0px;
}
.custom-student-profile-55 {
  /* Header */
}
.custom-student-profile-55 .profile-header {
  padding: 30px;
  color: white;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
.custom-student-profile-55 input#edit-submit-book-class,
.custom-student-profile-55 input#edit-submit-book-class--2 {
  background: var(--blue);
  color: #fff;
  margin-top: 21px;
}
.custom-student-profile-55 input#edit-submit-book-class:hover,
.custom-student-profile-55 input#edit-submit-book-class--2:hover {
  background: #053b83;
}
.custom-student-profile-55 input#edit-reset,
.custom-student-profile-55 input#edit-reset--2 {
  background: #000;
  color: #fff;
  margin-left: 0px;
  margin-top: 21px;
}
.custom-student-profile-55 input#edit-reset:hover,
.custom-student-profile-55 input#edit-reset--2:hover {
  background: #131313;
}
.custom-student-profile-55 .form--inline.clearfix {
  display: flex;
  align-items: center;
}
.custom-student-profile-55 .user-logged-in div#block-xuan-theme-content {
  background: #fff;
  padding: 50px 0;
}
.custom-student-profile-55 .profile-image {
  width: 125px;
  height: 125px;
  border-radius: 50%;
  background: white;
  padding: 4px;
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.3);
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}
.custom-student-profile-55 .profile-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
.custom-student-profile-55 .profile-info h1 {
  font-size: 32px;
  margin-bottom: 10px;
}
.custom-student-profile-55 .info-badge {
  display: inline-block;
  background: #fff;
  color: var(--accent);
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
  margin-top: 6px;
  margin-right: 6px;
}
.custom-student-profile-55 .info-badge hr {
  margin: 0.2rem 0;
}
.custom-student-profile-55 .back-btn {
  background: #000;
  color: #fff;
  border-radius: 25px;
  padding: 10px 20px;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
  transition: all 0.3s ease;
}
.custom-student-profile-55 .back-btn:hover {
  background: #fff;
  color: #000;
}
.custom-student-profile-55 {
  /* Attended Lessons Table */
}
.custom-student-profile-55 .attended-section {
  padding: 40px 30px;
}
.custom-student-profile-55 .attended-section h2 {
  font-size: 28px;
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--accent);
}
.custom-student-profile-55 .level-basic h2 {
  color: #1E4FA3;
}
.custom-student-profile-55 .level-intermediate h2 {
  color: #5A6B7A;
}
.custom-student-profile-55 .level-advance h2 {
  color: #C82426;
}
.custom-student-profile-55 .level-elite h2 {
  color: #D4A017;
}
.custom-student-profile-55 .level-basic h2::before {
  background: #1E4FA3;
}
.custom-student-profile-55 .level-intermediate h2::before {
  background: #5A6B7A;
}
.custom-student-profile-55 .level-advance h2::before {
  background: #C82426;
}
.custom-student-profile-55 .level-elite h2::before {
  background: #D4A017;
}
.custom-student-profile-55 .attended-section h2::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 28px;
  border-radius: 2px;
}
.custom-student-profile-55 .std-excellance-level {
  color: #000;
}
.custom-student-profile-55 .table {
  width: 100%;
  border-collapse: collapse;
  background: #000;
  border-radius: 6px;
  overflow: hidden;
}
.custom-student-profile-55 .table td {
  padding: 12px 15px;
  text-align: left;
  color: #000;
}
.custom-student-profile-55 .table th {
  background: #000;
  color: #fff;
  font-weight: 600;
}
.custom-student-profile-55 .table tbody tr:hover {
  background-color: rgba(197, 48, 48, 0.2);
  transition: background-color 0.2s ease-in-out;
}
.custom-student-profile-55 .table td img {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  object-fit: cover;
}
.custom-student-profile-55 .view-btn {
  background: var(--accent);
  color: white;
  padding: 6px 14px;
  border-radius: 6px;
  font-size: 13px;
  text-decoration: none;
  transition: all 0.3s ease;
}
.custom-student-profile-55 .view-btn:hover {
  background: var(--accent);
}
.custom-student-profile-55 {
  /* Empty state */
}
.custom-student-profile-55 .empty-state {
  text-align: center;
  padding: 60px 30px;
  color: var(--accent);
}
.custom-student-profile-55 .empty-state-icon {
  font-size: 64px;
  margin-bottom: 20px;
  opacity: 0.5;
}
.custom-student-profile-55 .user-logged-in .attended-section .form--inline {
  display: flex;
  gap: 6px;
  align-items: center;
}
.custom-student-profile-55 .user-logged-in .attended-section .form-actions {
  margin-top: 36px;
}
.custom-student-profile-55 .user-logged-in .attended-section .form-actions .form-submit {
  background: var(--accent);
  color: #fff;
  padding: 6px 10px;
}
.custom-student-profile-55 .user-logged-in .attended-section .form-actions .form-submit:hover {
  background: #000;
  color: #fff;
}

@media (max-width: 767px) {
  .custom-student-profile-55 {
    margin: 10px;
    padding: 10px;
  }
  .custom-student-profile-55 input#edit-submit-book-class,
  .custom-student-profile-55 input#edit-reset,
  .custom-student-profile-55 input#edit-reset--2,
  .custom-student-profile-55 input#edit-submit-book-class--2 {
    margin-top: 0px;
  }
  .custom-student-profile-55 .std-excellance-level-main {
    justify-content: left !important;
    margin-top: 20px;
  }
  .custom-student-profile-55 .form--inline.clearfix {
    display: flex;
    flex-direction: column;
    align-items: unset;
  }
  .custom-student-profile-55 .js-form-item-field-branch-target-id {
    margin: 20px 0 0;
  }
  .custom-student-profile-55 .back-btn-wrapper {
    flex-direction: column;
    width: fit-content;
  }
  .custom-student-profile-55 .profile-header {
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    padding: 20px 12px;
  }
  .custom-student-profile-55 table {
    white-space: nowrap;
  }
  .custom-student-profile-55 .attended-section h2 {
    justify-content: left;
    margin-bottom: 12px;
    font-size: 22px !important;
  }
  .custom-student-profile-55 .profile-info h1 {
    margin-bottom: 10px;
    margin-top: 20px;
    text-align: left;
  }
  .custom-student-profile-55 .back-btn {
    padding: 7px 11px;
    font-size: 12px;
  }
  .custom-student-profile-55 .attended-section {
    padding: 30px 15px;
  }
  .custom-student-profile-55 .profile-info div {
    display: flex;
    justify-content: left;
  }
  .custom-student-profile-55 .profile-info-card-88 {
    flex-direction: column;
    justify-content: left;
  }
  .custom-student-profile-55 .user-logged-in .attended-section table {
    white-space: nowrap;
  }
  .custom-student-profile-55 .cstm-main-profile-13 {
    display: block !important;
  }
}
.user-orders-page-55 .user-orders-container {
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 6px 32px rgba(0, 0, 0, 0.1);
  padding: 3em 2em 2em 2em;
  margin: 2.5em auto 2em auto;
  max-width: 1200px;
}
.user-orders-page-55 .user-orders-container h2 {
  font-size: 2.2em;
  font-weight: 700;
  color: #222;
  margin-bottom: 1.2em;
  letter-spacing: 1px;
  text-align: center;
}
.user-orders-page-55 .table th {
  background: #2563eb;
  color: #fff;
  font-weight: 600;
  padding: 1.2em 1em;
  border-bottom: 2px solid #eaeaea;
  text-align: left;
  font-size: 1.08em;
}
.user-orders-page-55 .table td {
  padding: 1.1em 1em;
  border-bottom: 1px solid #eaeaea;
  color: #222;
  font-size: 1.05em;
}
.user-orders-page-55 .table-striped tbody tr:nth-of-type(odd) {
  background-color: #f6f8fa;
}
.user-orders-page-55 .table-bordered {
  border: 1px solid #eaeaea;
  border-radius: 12px;
  overflow: hidden;
}
.user-orders-page-55 .table th,
.user-orders-page-55 .table td {
  vertical-align: middle;
}
.user-orders-page-55 .table td:last-child {
  text-align: center;
}
.user-orders-page-55 .orders-pagination {
  margin-top: 2em;
  text-align: center;
}

@media (max-width: 900px) {
  .user-orders-page-55 .user-orders-container {
    padding: 1.2em 0.5em;
    max-width: 100%;
  }
  .user-orders-page-55 .table th,
  .user-orders-page-55 .table td {
    padding: 0.7em 0.3em;
    font-size: 0.98em;
  }
  .user-orders-page-55 .user-orders-container h2 {
    font-size: 1.5em;
  }
}
.class-wise-attendance-page-55 .table-responsive {
  padding: 10px;
}
.class-wise-attendance-page-55 .cstm-pre-12,
.class-wise-attendance-page-55 .cstm-abs-12 {
  display: flex;
  gap: 7px;
  align-items: center;
  margin-left: 10px;
}
.class-wise-attendance-page-55 caption {
  display: none;
}
.class-wise-attendance-page-55 .table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.26);
  border-radius: 8px;
  overflow: hidden;
}
.class-wise-attendance-page-55 .table th {
  background: #000;
  text-align: left;
  padding: 12px;
  font-weight: 500;
  color: #fff;
  border-right: 1px solid #e5e7eb;
}
.class-wise-attendance-page-55 .table td {
  padding: 10px 8px;
  border-bottom: 1px solid #e5e7eb;
  vertical-align: middle;
  color: #222;
  font-size: 15px;
}
.class-wise-attendance-page-55 .table .views-field-field-lesson {
  border-top-left-radius: 8px;
}
.class-wise-attendance-page-55 .table .views-field-field-status {
  border-top-right-radius: 8px;
}
.class-wise-attendance-page-55 .view-class-wise-attendance {
  width: 100%;
  background: #fff;
}
.class-wise-attendance-page-55 .view-class-wise-attendance .class-wise-attendance-container {
  background-color: white;
  margin: 20px 0;
}
.class-wise-attendance-page-55 .view-class-wise-attendance .contextual-lesson-header {
  margin-bottom: 15px;
}
.class-wise-attendance-page-55 .view-class-wise-attendance .caption {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 15px;
}

@media (max-width: 991px) {
  .class-wise-attendance-page-55 .table {
    white-space: nowrap;
  }
  .class-wise-attendance-page-55 .table-responsive {
    padding: 15px 0 15px;
  }
}
.cstm-hero-88 {
  /* Simple red-black carousel buttons */
}
.cstm-hero-88 #heroSlider .carousel-control-prev,
.cstm-hero-88 #heroSlider .carousel-control-next {
  width: 50px;
  height: 50px;
  background-color: rgba(204, 204, 204, 0.6235294118);
  /* Black background */
  /* border: 2px solid #ff0000;  */
  border-radius: 50%;
  top: 50%;
  color: #fff !important;
  transform: translateY(-50%);
  opacity: 0.9;
  transition: 0.3s ease;
}
.cstm-hero-88 {
  /* Position buttons */
}
.cstm-hero-88 #heroSlider .carousel-control-prev {
  left: 25px;
}
.cstm-hero-88 #heroSlider .carousel-control-next {
  right: 25px;
}
.cstm-hero-88 {
  /* Make icons white (remove aqua tint) */
}
.cstm-hero-88 #heroSlider .carousel-control-prev-icon,
.cstm-hero-88 #heroSlider .carousel-control-next-icon {
  background-color: transparent !important;
  color: #fff !important;
  filter: invert(1) brightness(200%) saturate(0%) !important;
  /* Pure white */
}
.cstm-hero-88 {
  /* Hover effect: red background */
}
.cstm-hero-88 #heroSlider .carousel-control-prev:hover,
.cstm-hero-88 #heroSlider .carousel-control-next:hover {
  background-color: #ff0000;
  /* Red background */
  border-color: #000;
  /* Black border */
  opacity: 1;
}

.custom-lesson-list-page-55 .table-responsive {
  padding: 10px;
}
.custom-lesson-list-page-55 .class-list-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.26);
  border-radius: 8px;
  overflow: hidden;
}
.custom-lesson-list-page-55 .class-list-table th {
  background: #000;
  text-align: left;
  padding: 12px;
  font-weight: 500;
  color: #fff;
  border-right: 1px solid #e5e7eb;
}
.custom-lesson-list-page-55 .class-list-table td {
  padding: 10px 8px;
  border-bottom: 1px solid #e5e7eb;
  vertical-align: middle;
  color: #222;
  font-size: 15px;
}
.custom-lesson-list-page-55 .class-list-table tr:last-child td {
  border-bottom: none;
}
.custom-lesson-list-page-55 .class-list-table tbody tr:hover {
  background: #f9fafb;
  transition: background 0.2s;
}
.custom-lesson-list-page-55 .btn.btn-primary {
  background: var(--blue);
  border: none;
  color: #fff;
  padding: 4px 14px;
  border-radius: 4px;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  transition: background 0.2s;
}
.custom-lesson-list-page-55 .btn.btn-primary:hover {
  background: #1d4ed8;
  color: #fff;
}
.custom-lesson-list-page-55 .breadcrumb-small {
  font-size: 14px;
  color: #888;
  margin-top: 8px;
}
.custom-lesson-list-page-55 .breadcrumb-small a {
  color: var(--blue);
  text-decoration: none;
}
.custom-lesson-list-page-55 .breadcrumb-small a:hover {
  text-decoration: underline;
}
.custom-lesson-list-page-55 .view-empty {
  padding: 40px 0;
  text-align: center;
  color: #888;
  font-size: 18px;
}

@media (max-width: 991px) {
  .custom-lesson-list-page-55 .class-list-table {
    white-space: nowrap;
  }
  .custom-lesson-list-page-55 .table-responsive {
    padding: 15px 0 15px;
  }
}
.class-list-container .table-responsive {
  padding: 10px;
}
.class-list-container .class-list-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.26);
  border-radius: 8px;
  overflow: hidden;
}
.class-list-container .class-list-table th {
  background: #000;
  text-align: left;
  padding: 12px;
  font-weight: 500;
  color: #fff;
  border-right: 1px solid #e5e7eb;
}
.class-list-container .class-list-table td {
  padding: 10px 8px;
  border-bottom: 1px solid #e5e7eb;
  vertical-align: middle;
  color: #222;
  font-size: 15px;
}
.class-list-container .class-list-table tr:last-child td {
  border-bottom: none;
}
.class-list-container .class-list-table tbody tr:hover {
  background: #f9fafb;
  transition: background 0.2s;
}
.class-list-container .btn.btn-primary {
  background: var(--blue);
  border: none;
  color: #fff;
  padding: 4px 14px;
  border-radius: 4px;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  transition: background 0.2s;
}
.class-list-container .btn.btn-primary:hover {
  background: var(--blue);
  color: #fff;
}
.class-list-container .breadcrumb-small {
  font-size: 14px;
  color: #888;
  margin-top: 8px;
}
.class-list-container .breadcrumb-small a {
  color: var(--blue);
  text-decoration: none;
}
.class-list-container .breadcrumb-small a:hover {
  text-decoration: underline;
}
.class-list-container .view-empty {
  padding: 40px 0;
  text-align: center;
  color: #888;
  font-size: 18px;
}

@media (max-width: 991px) {
  .class-list-container .class-list-table {
    white-space: nowrap;
  }
  .class-list-container .table-responsive {
    padding: 15px 0 15px;
  }
}
.custom-students-page-112 .students-view-container {
  margin: 2.5em auto 2em;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 6px 32px rgba(0, 0, 0, 0.1);
  padding: 3em 2em 2em;
  max-width: 1200px;
}
.custom-students-page-112 .students-view-container h2 {
  font-size: 2.5em;
  font-weight: 700;
  color: #222;
  margin-bottom: 1.2em;
  letter-spacing: 1px;
  text-align: center;
}
.custom-students-page-112 .table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  font-size: 1.12em;
  margin: 2% auto;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.26);
}
.custom-students-page-112 .table th {
  background: #000;
  text-align: left;
  padding: 12px;
  font-weight: 500;
  color: #fff;
  border-right: 1px solid #e5e7eb;
}
.custom-students-page-112 .table td {
  padding: 10px 8px;
  border-bottom: 1px solid #e5e7eb;
  vertical-align: middle;
  color: #222;
  font-size: 15px;
}
.custom-students-page-112 .table-striped tbody tr:nth-of-type(odd) {
  background-color: #f6f8fa;
}
.custom-students-page-112 .table-bordered {
  border: 1px solid #eaeaea;
  border-radius: 12px;
  overflow: hidden;
}
.custom-students-page-112 .table th,
.custom-students-page-112 .table td {
  vertical-align: middle;
}
.custom-students-page-112 .table td:last-child {
  text-align: center;
}
.custom-students-page-112 .table-responsive {
  padding: 10px;
}

@media (max-width: 991px) {
  .custom-students-page-112 .class-list-table {
    white-space: nowrap;
  }
  .custom-students-page-112 .table-responsive {
    padding: 15px 0 15px;
  }
}
@media (max-width: 900px) {
  .custom-students-page-112 .students-view-container {
    max-width: 100%;
  }
  .custom-students-page-112 .table th,
  .custom-students-page-112 .table td {
    padding: 0.7em 0.3em;
    font-size: 0.98em;
  }
  .custom-students-page-112 .students-view-container h2 {
    font-size: 1.5em;
  }
}
.recent-post-page-55 .recent-post-wrapper {
  background: #fff;
  border-radius: 10px;
  padding: 20px;
}
.recent-post-page-55 .recent-post-heading {
  font-size: 1rem;
  font-weight: 600;
  text-transform: uppercase;
  background: #f7f7f7;
  padding: 8px 12px;
  border-radius: 4px;
  display: inline-block;
  margin-bottom: 15px;
}
.recent-post-page-55 .recent-post-list {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
.recent-post-page-55 .recent-post-item {
  display: flex;
  align-items: center;
  gap: 15px;
  background: #fafafa;
  border-radius: 8px;
  padding: 5px;
  transition: 0.3s ease;
  margin-bottom: 13px;
}
.recent-post-page-55 .recent-post-item:hover {
  background: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}
.recent-post-page-55 .recent-post-image img {
  width: 80px !important;
  height: 60px !important;
  object-fit: fill !important;
  border-radius: 6px !important;
  flex-shrink: 0 !important;
}
.recent-post-page-55 .recent-post-content {
  flex: 1;
}
.recent-post-page-55 .recent-post-title {
  font-size: 0.85rem;
  font-weight: 700;
  margin: 0 0 5px;
}
.recent-post-page-55 .recent-post-title a {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  /* Show 2 lines */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.4em;
  max-height: 4.2em;
  /* = line-height × number of lines */
  text-decoration: none;
  color: #000 !important;
  transition: color 0.2s ease;
}
.recent-post-page-55 .recent-post-title a:hover {
  color: #d62828 !important;
}
.recent-post-page-55 .recent-post-summary {
  font-size: 0.85rem;
  color: #555;
  line-height: 1.4;
  margin: 0;
}

/* Responsive */
@media (max-width: 600px) {
  .recent-post-page-55 .recent-post-item {
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 13px;
  }
  .recent-post-page-55 .recent-post-image img {
    width: 100%;
    height: 180px;
  }
}
.student-edit-from-55 .node-student-form {
  margin: 0;
  padding: 20px 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.student-edit-from-55 .xuan-student-form {
  width: 100%;
}
.student-edit-from-55 .xuan-student-form h3 {
  color: #000;
}
.student-edit-from-55 .xuan-student-form label {
  color: #000 !important;
}
.student-edit-from-55 .layout--twocol {
  display: block;
}
.student-edit-from-55 .layout__region .layout__region--first {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin: 0 -1rem;
}
.student-edit-from-55 .d-flex #edit-submit {
  background: #d32f2f !important;
  color: white !important;
  border: none !important;
  padding: 0.5rem 1rem !important;
  border-radius: 6px !important;
  font-size: 0.9rem !important;
  margin-top: 0.5rem !important;
  cursor: pointer !important;
}
.student-edit-from-55 .xuan-student-form .card {
  max-width: 900px;
  margin: 0 auto;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  background: #fff;
}
.student-edit-from-55 .xuan-student-form .card-header {
  background: var(--primary);
  color: white;
  padding: 1.5rem;
  text-align: center;
  font-weight: 600;
  font-size: 1.5rem;
}
.student-edit-from-55 .xuan-student-form .card-body {
  padding: 2rem;
}
.student-edit-from-55 .xuan-student-form .row.g-4 {
  margin: -1rem;
}
.student-edit-from-55 .xuan-student-form .col-md-6 {
  padding: 1rem;
}
.student-edit-from-55 .xuan-student-form label {
  font-weight: 600;
  color: var(--text);
  margin-bottom: 0.5rem;
  font-size: 0.95rem;
}
.student-edit-from-55 .xuan-student-form input[type=text],
.student-edit-from-55 .xuan-student-form input[type=date] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid var(--accent);
  border-radius: 8px;
  font-size: 1rem;
  transition: all 0.3s ease;
}
.student-edit-from-55 .xuan-student-form input:focus {
  outline: none;
  border-color: var(--accent-dark);
  box-shadow: 0 0 0 4px rgba(211, 47, 47, 0.15);
}
.student-edit-from-55 .xuan-student-form input[type=file] {
  width: 100%;
  padding: 0.5rem;
  border: 2px dashed var(--accent);
  border-radius: 8px;
  background: #fdf2f2;
}
.student-edit-from-55 .image-widget {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.student-edit-from-55 .image-preview img {
  width: 100px;
  height: 100px;
  object-fit: cover;
  border-radius: 12px;
  border: 3px solid var(--accent);
}
.student-edit-from-55 .image-widget-data {
  flex: 1;
  min-width: 200px;
}
.student-edit-from-55 .xuan-student-form input[type=submit][value=Upload] {
  background: var(--accent);
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  margin-top: 0.5rem;
}
.student-edit-from-55 .xuan-student-form .form-check {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.student-edit-from-55 .xuan-student-form .form-check-input {
  width: 1.5rem;
  height: 1.5rem;
  border: 2px solid var(--accent);
  border-radius: 4px;
}
.student-edit-from-55 .xuan-student-form .form-check-input:checked {
  background-color: var(--accent);
  border-color: var(--accent);
}
.student-edit-from-55 .xuan-student-form .button--primary {
  background: var(--accent) !important;
  color: white !important;
  border: none !important;
  padding: 0.75rem 2rem !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 12px rgba(211, 47, 47, 0.3);
}
.student-edit-from-55 .xuan-student-form .button--primary:hover {
  background: var(--accent-dark) !important;
  transform: translateY(-2px);
}
.student-edit-from-55 {
  /* HIDE DRUPAL JUNK */
}
.student-edit-from-55 .xuan-student-form .vertical-tabs,
.student-edit-from-55 .xuan-student-form .entity-meta,
.student-edit-from-55 .xuan-student-form .moderation-state-wrapper,
.student-edit-from-55 .xuan-student-form input[type=hidden],
.student-edit-from-55 .xuan-student-form .description,
.student-edit-from-55 .xuan-student-form .js-hide,
.student-edit-from-55 .xuan-student-form .layout__region:empty {
  display: none !important;
}

@media (max-width: 768px) {
  .student-edit-from-55 .xuan-student-form .card-body {
    padding: 1.5rem;
  }
  .student-edit-from-55 .xuan-student-form .col-md-6 {
    padding: 0.75rem;
  }
  .student-edit-from-55 .image-widget {
    flex-direction: column;
    align-items: flex-start;
  }
  .path-student .node-student-form {
    padding: 30px 15px !important;
  }
}
.node-student-form {
  margin: 0;
  padding: 20px 50px;
  display: flex;
  align-items: center;
  width: 100%;
}

.node-student-form .xuan-student-form {
  width: 100%;
}
.node-student-form .xuan-student-form h2 {
  color: #000;
}
.node-student-form .xuan-student-form label {
  color: #000 !important;
}
.node-student-form .layout--twocol {
  display: block;
}
.node-student-form .layout__region .layout__region--first {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin: 0 -1rem;
}
.node-student-form .d-flex #edit-submit {
  background: var(--accent) !important;
  color: white !important;
  border: none !important;
  padding: 0.5rem 1rem !important;
  border-radius: 6px !important;
  font-size: 0.9rem !important;
  margin-top: 0.5rem !important;
  cursor: pointer !important;
}
.node-student-form {
  /* Hide empty regions */
}
.node-student-form .layout__region:empty {
  display: none !important;
}
.node-student-form {
  /* Form Wrappers */
}
.node-student-form .js-form-wrapper {
  margin-bottom: 1.5rem;
}
.node-student-form {
  /* Labels */
}
.node-student-form label {
  font-weight: 600;
  color: #212529;
  margin-bottom: 0.5rem;
  display: block;
  font-size: 0.95rem;
}
.node-student-form {
  /* Text Input */
}
.node-student-form input[type=text].form-control {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid var(--accent);
  border-radius: 8px;
  font-size: 1rem;
  transition: all 0.3s ease;
}
.node-student-form input[type=text].form-control:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(211, 47, 47, 0.15);
}
.node-student-form {
  /* File Input */
}
.node-student-form input[type=file].form-file {
  width: 100%;
  padding: 0.5rem;
  border: 2px dashed var(--accent);
  border-radius: 8px;
  background: #fdf2f2;
  color: #212529;
  font-size: 0.95rem;
}
.node-student-form {
  /* Image Widget */
}
.node-student-form .image-widget {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.node-student-form .image-preview img {
  width: 100px;
  height: 100px;
  object-fit: cover;
  border-radius: 12px;
  border: 3px solid var(--accent);
  transition: transform 0.3s ease;
}
.node-student-form .image-preview img:hover {
  transform: scale(1.1);
}
.node-student-form .image-widget-data {
  flex: 1;
  min-width: 200px;
}
.node-student-form {
  /* Upload Button */
}
.node-student-form input[type=submit][value=Upload] {
  background: var(--accent);
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  font-size: 0.9rem;
  margin-top: 0.5rem;
  cursor: pointer;
}
.node-student-form input[type=submit][value=Upload]:hover {
  background: var(--accent);
}
.node-student-form {
  /* Checkboxes */
}
.node-student-form .form-check {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding-left: 0px;
}
.node-student-form .form-check-input {
  width: 1.5rem;
  height: 1.5rem;
  border: 2px solid var(--accent);
  border-radius: 4px;
  margin: 0;
  cursor: pointer;
  appearance: none;
  position: relative;
}
.node-student-form .form-check-input:checked {
  background-color: var(--accent);
  border-color: var(--accent);
}
.node-student-form .vertical-tabs__menu-item a {
  color: var(--accent);
}
.node-student-form .form-check-label {
  margin: 0;
  font-weight: 500;
  color: #212529;
  cursor: pointer;
}
.node-student-form {
  /* Date Field */
}
.node-student-form h4.label {
  font-weight: 600;
  color: #212529;
  margin-bottom: 0.5rem;
  font-size: 0.95rem;
}
.node-student-form input[type=date].form-date {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid var(--accent);
  border-radius: 8px;
  font-size: 1rem;
  transition: all 0.3s ease;
}
.node-student-form input[type=date].form-date:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(211, 47, 47, 0.15);
}
.node-student-form {
  /* Description */
}
.node-student-form .description {
  font-size: 0.85rem;
  color: #6c757d;
  margin-top: 0.5rem;
}

button.carousel-control-prev {
  position: absolute;
  top: 50%;
  left: 25px;
  transform: translateY(-50%);
}

button.carousel-control-next {
  position: absolute;
  top: 50%;
  right: 25px;
  transform: translateY(-50%);
}

.lesson-popup {
  max-width: 480px;
  background: #fff;
  color: #333;
  padding: 20px;
  border-radius: 8px;
}

.popup-title {
  margin: 0 0 15px 0;
  color: #333;
  border-bottom: 2px solid #DFC548;
  padding-bottom: 8px;
  font-size: 20px;
  font-weight: 700;
}

.popup-footer {
  text-align: center;
  margin-top: 15px;
}

.popup-row {
  margin: 6px 0;
  padding: 4px 0;
  border-bottom: 1px solid #e9ecef;
  display: flex;
  align-items: center;
}

.popup-label {
  display: inline-block;
  width: 100px;
  font-weight: 600;
  color: #495057;
  font-size: 13px;
}

.popup-value {
  color: #212529;
  font-size: 14px;
}

.popup-cost {
  color: #d4a012;
  font-size: 15px;
  font-weight: 600;
}

.booking-box {
  border-top: 2px solid #DFC548;
  padding-top: 15px;
  background: #fff;
  border-radius: 6px;
}

.booking-title {
  margin: 0 0 10px 0;
  color: #333;
  font-size: 16px;
  text-align: center;
}

.student-select {
  padding: 4px 6px;
  border: 1px solid #ced4da;
  border-radius: 4px;
  font-size: 14px;
  width: 200px;
}

.popup-actions {
  text-align: center;
  margin-top: 15px;
}

.contact-btn {
  display: inline-block;
  background: linear-gradient(45deg, #DFC548, #f1d65a);
  color: #fff;
  padding: 10px 20px;
  border-radius: 5px;
  margin-right: 10px;
  font-weight: 600;
  font-size: 14px;
  box-shadow: 0 2px 6px rgba(223, 197, 72, 0.3);
  text-decoration: none;
}

.book-btn {
  display: inline-block;
  background: linear-gradient(45deg, #e53e3e, #ff5555);
  color: #fff;
  padding: 10px 20px;
  border-radius: 5px;
  font-weight: 600;
  font-size: 14px;
  border: none;
  box-shadow: 0 2px 6px rgba(229, 62, 62, 0.3);
}

.close-btn {
  background: #6c757d;
  color: #fff;
  border: none;
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  margin-top: 15px;
  display: inline-block;
}

/* Overlay */
.booking-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100000;
  animation: fadeIn 0.3s ease-in-out;
}

/* Modal Box */
.booking-modal-box {
  background: #fff;
  padding: 28px 35px;
  border-radius: 10px;
  text-align: center;
  max-width: 420px;
  width: 90%;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
  transform: scale(0.95);
  animation: popIn 0.25s ease-out forwards;
}

/* Icon */
.booking-modal-icon {
  font-size: 36px;
  margin-bottom: 8px;
}

/* Title */
.booking-modal-title {
  font-weight: 700;
  font-size: 20px;
  margin-bottom: 10px;
}

.booking-description {
  margin: 0 0 15px 0;
  color: #666;
  line-height: 1.4;
  text-align: center;
  font-size: 13px;
}

/* Message */
.booking-modal-message {
  color: #444;
  font-size: 15px;
  line-height: 1.5;
  margin-bottom: 20px;
}

/* Button */
.booking-modal-btn {
  color: #fff;
  border: none;
  padding: 8px 18px;
  border-radius: 5px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.25s ease;
}

/* Color Variants */
.success-bg {
  background: #28a745 !important;
}

.warning-bg {
  background: #ffc107 !important;
  color: #000 !important;
}

.error-bg {
  background: var(--accent) !important;
}

/* Animations */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes popIn {
  from {
    transform: scale(0.9);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.booking-history-page {
  padding: 20px 0;
  max-width: 1400px;
}
.booking-history-page .filters-section {
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  margin-bottom: 30px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}
.booking-history-page .filters-section > div {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 15px;
  align-items: end;
}
.booking-history-page .filters-section label {
  display: block;
  font-weight: 600;
  color: #495057;
  font-size: 13px;
  margin-bottom: 6px;
}
.booking-history-page .filters-section .form-control {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #ced4da;
  border-radius: 6px;
  font-size: 14px;
}
.booking-history-page .filters-section .btn-primary {
  padding: 8px 20px;
  background: #007bff;
  border: none;
  border-radius: 6px;
  color: #fff;
  font-weight: 600;
  cursor: pointer;
  font-size: 14px;
  white-space: nowrap;
}
.booking-history-page .filters-section .btn-primary:hover {
  background: #0056b3;
}
.booking-history-page .section-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  padding-bottom: 12px;
}
.booking-history-page .section-header h2 {
  font-size: 22px;
  font-weight: 700;
  margin: 0;
}
.booking-history-page .section-header .badge-count {
  color: #fff;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
}
.booking-history-page .bookings-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.booking-history-page .booking-card {
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.1);
}
.booking-history-page .booking-card .card-content {
  display: grid;
  gap: 12px;
}
.booking-history-page .booking-card .card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 10px;
  padding-bottom: 12px;
  border-bottom: 1px solid #e0e0e0;
}
.booking-history-page .booking-card .student-info,
.booking-history-page .booking-card .lesson-info {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.booking-history-page .booking-card .student-info .icon,
.booking-history-page .booking-card .lesson-info .icon {
  font-size: 18px;
}
.booking-history-page .booking-card .student-info strong,
.booking-history-page .booking-card .lesson-info strong {
  font-size: 16px;
  color: #212529;
}
.booking-history-page .booking-card .lesson-info strong {
  font-size: 17px;
}
.booking-history-page .booking-card .status-badge {
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
  display: inline-block;
}
.booking-history-page .booking-card .date-time-box {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 8px;
}
.booking-history-page .booking-card .date-time-box .icon {
  font-size: 18px;
}
.booking-history-page .booking-card .date-time-box .date-text {
  color: #495057;
  font-size: 15px;
  font-weight: 600;
}
.booking-history-page .booking-card .date-time-box .time-text {
  color: #6c757d;
  font-size: 14px;
}
.booking-history-page .booking-card .card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  padding-top: 8px;
}
.booking-history-page .booking-card .card-footer .info-item {
  display: flex;
  align-items: center;
  gap: 8px;
}
.booking-history-page .booking-card .card-footer .info-item .icon {
  font-size: 16px;
}
.booking-history-page .booking-card .card-footer .info-item .text {
  font-size: 13px;
}
.booking-history-page .booking-card .card-footer .credits {
  font-weight: 700;
  color: #007bff;
  font-size: 14px;
}
.booking-history-page .booking-card .transaction-id {
  padding-top: 6px;
  border-top: 1px solid #e0e0e0;
  font-size: 11px;
  color: #adb5bd;
}
.booking-history-page .upcoming-section {
  margin-bottom: 40px;
}
.booking-history-page .upcoming-section .section-header {
  border-bottom: 3px solid #28a745;
}
.booking-history-page .upcoming-section .section-header h2 {
  color: #28a745;
}
.booking-history-page .upcoming-section .section-header .badge-count {
  background: #28a745;
}
.booking-history-page .upcoming-section .upcoming-card {
  background: linear-gradient(135deg, #f8fff9 0%, #ffffff 100%);
  border: 2px solid #28a745;
  transition: all 0.3s ease;
}
.booking-history-page .upcoming-section .upcoming-card .status-badge {
  background: #28a745;
  color: #fff;
}
.booking-history-page .upcoming-section .upcoming-card .date-time-box {
  background: #f0f9f4;
}
.booking-history-page .upcoming-section .upcoming-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(40, 167, 69, 0.25);
}
.booking-history-page .attended-section {
  margin-bottom: 40px;
}
.booking-history-page .attended-section .section-header {
  border-bottom: 3px solid #218838;
}
.booking-history-page .attended-section .section-header h2 {
  color: #218838;
}
.booking-history-page .attended-section .section-header .badge-count {
  background: #218838;
}
.booking-history-page .attended-section .attended-card {
  background: #f1f9f3;
  border: 1px solid #c3e6cb;
  border-left: 5px solid #28a745;
  padding: 18px;
  opacity: 0.95;
}
.booking-history-page .attended-section .attended-card .card-content {
  gap: 10px;
}
.booking-history-page .attended-section .attended-card .student-info,
.booking-history-page .attended-section .attended-card .lesson-info {
  margin-bottom: 4px;
}
.booking-history-page .attended-section .attended-card .student-info .icon,
.booking-history-page .attended-section .attended-card .lesson-info .icon {
  font-size: 16px;
}
.booking-history-page .attended-section .attended-card .student-info strong,
.booking-history-page .attended-section .attended-card .lesson-info strong {
  font-size: 15px;
}
.booking-history-page .attended-section .attended-card .lesson-info strong {
  color: #495057;
}
.booking-history-page .attended-section .attended-card .status-badge {
  background: #d4edda;
  color: #155724;
  display: flex;
  align-items: center;
  gap: 6px;
}
.booking-history-page .attended-section .attended-card .card-footer {
  padding-top: 8px;
}
.booking-history-page .attended-section .attended-card .card-footer .date-text {
  color: #6c757d;
  font-size: 14px;
}
.booking-history-page .attended-section .attended-card .card-footer .credits {
  font-weight: 600;
  color: #6c757d;
}
.booking-history-page .not-attended-section .section-header {
  border-bottom: 3px solid #dc3545;
}
.booking-history-page .not-attended-section .section-header h2 {
  color: #dc3545;
}
.booking-history-page .not-attended-section .section-header .badge-count {
  background: #dc3545;
}
.booking-history-page .not-attended-section .absent-card {
  background: #fff5f5;
  border: 1px solid #f5c6cb;
  border-left: 5px solid #dc3545;
  padding: 18px;
  opacity: 0.95;
}
.booking-history-page .not-attended-section .absent-card .card-content {
  gap: 10px;
}
.booking-history-page .not-attended-section .absent-card .student-info,
.booking-history-page .not-attended-section .absent-card .lesson-info {
  margin-bottom: 4px;
}
.booking-history-page .not-attended-section .absent-card .student-info .icon,
.booking-history-page .not-attended-section .absent-card .lesson-info .icon {
  font-size: 16px;
}
.booking-history-page .not-attended-section .absent-card .student-info strong,
.booking-history-page .not-attended-section .absent-card .lesson-info strong {
  font-size: 15px;
}
.booking-history-page .not-attended-section .absent-card .lesson-info strong {
  color: #495057;
}
.booking-history-page .not-attended-section .absent-card .status-badge {
  background: #f8d7da;
  color: #721c24;
  display: flex;
  align-items: center;
  gap: 6px;
}
.booking-history-page .not-attended-section .absent-card .card-footer {
  padding-top: 8px;
}
.booking-history-page .not-attended-section .absent-card .card-footer .date-text {
  color: #6c757d;
  font-size: 14px;
}
.booking-history-page .not-attended-section .absent-card .card-footer .credits {
  font-weight: 600;
  color: #dc3545;
  text-decoration: line-through;
}
.booking-history-page .not-attended-section .absent-card .card-footer .refunded-label {
  font-size: 11px;
  color: #28a745;
  font-weight: 600;
}
.booking-history-page .empty-state {
  padding: 30px;
  text-align: center;
  background: linear-gradient(135deg, #e8f5e9 0%, #f1f8f4 100%);
  border: 2px dashed #81c784;
  border-radius: 12px;
  margin-bottom: 30px;
}
.booking-history-page .empty-state .icon {
  font-size: 48px;
  margin-bottom: 10px;
}
.booking-history-page .empty-state h4 {
  color: #2e7d32;
  margin: 0 0 8px 0;
  font-size: 18px;
}
.booking-history-page .empty-state p {
  color: #558b2f;
  margin: 0;
  font-size: 14px;
}
.booking-history-page .empty-state p a {
  font-weight: 600;
  color: #1b5e20;
  text-decoration: underline;
}
.booking-history-page .no-past-bookings {
  padding: 30px;
  text-align: center;
  background: #f8f9fa;
  border: 2px dashed #dee2e6;
  border-radius: 12px;
}
.booking-history-page .no-past-bookings .icon {
  font-size: 48px;
  margin-bottom: 10px;
}
.booking-history-page .no-past-bookings h4 {
  color: #6c757d;
  margin: 0 0 8px 0;
  font-size: 18px;
}
.booking-history-page .no-past-bookings p {
  color: #868e96;
  margin: 0;
  font-size: 14px;
}

@media (max-width: 768px) {
  .booking-history-page .bookings-grid {
    grid-template-columns: 1fr !important;
  }
  .booking-history-page .filters-section > div {
    grid-template-columns: 1fr !important;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .booking-history-page .bookings-grid {
    grid-template-columns: 1fr !important;
  }
}
.path-user .messages--error {
  color: #fff !important;
  background: #dc3545 !important;
  border: 1px solid #c82333 !important;
  border-radius: 4px !important;
  padding: 12px 15px !important;
  margin-bottom: 20px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  box-shadow: 0 2px 8px rgba(220, 53, 69, 0.3) !important;
}
.path-user .messages--error a {
  color: #fff !important;
  text-decoration: underline !important;
}
.path-user .messages--error:before {
  content: "⚠ " !important;
  font-weight: bold !important;
}
.path-user .form-item--error-message {
  display: none !important;
}
.path-user .user-login-form input[type=text],
.path-user .user-login-form input[type=email],
.path-user .user-login-form input[type=password] {
  color: #fff !important;
  background-color: rgba(255, 255, 255, 0.1) !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
}
.path-user .user-login-form input[type=text]::placeholder,
.path-user .user-login-form input[type=email]::placeholder,
.path-user .user-login-form input[type=password]::placeholder {
  color: rgba(255, 255, 255, 0.5) !important;
}
.path-user .user-login-form input[type=text]:focus,
.path-user .user-login-form input[type=email]:focus,
.path-user .user-login-form input[type=password]:focus {
  background-color: rgba(255, 255, 255, 0.15) !important;
  border-color: rgba(255, 255, 255, 0.5) !important;
}
.path-user .user-login-form label {
  color: #fff !important;
  font-weight: 500 !important;
}
.path-user .user-login-form .description {
  color: rgba(255, 255, 255, 0.7) !important;
}
.path-user .user-login-form .validation-error {
  display: none;
  color: #fff !important;
  background: #dc3545 !important;
  border: 1px solid #c82333 !important;
  border-radius: 4px !important;
  padding: 10px 12px !important;
  margin-top: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
}
.path-user .user-login-form input.has-error {
  border: 2px solid #ff6b6b !important;
  background-color: rgba(255, 107, 107, 0.08) !important;
  box-shadow: 0 0 0 3px rgba(255, 107, 107, 0.15) !important;
}
.path-user .user-login-form input.has-error:focus {
  outline: none !important;
  box-shadow: 0 0 0 4px rgba(255, 107, 107, 0.25) !important;
}
.path-user .user-form label {
  color: #fff;
  display: block;
  margin-bottom: 8px;
}

.page-node-type-courses #block-xuan-theme-content {
  background: #fff;
  padding: 50px 100px;
}

.commerce-cart-page {
  /* Page container: center content and split columns */
  background: #000;
  border-radius: 8px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 2.25rem 1rem;
}
.commerce-cart-page__body {
  /* use theme's Bootstrap row/col markup (do not force grid here) */
  margin: 0;
  padding: 0;
}
.commerce-cart-page .commerce-cart-items {
  background: var(--card, #ffffff);
  border-radius: 4px;
  padding: 0.25rem 0.25rem;
  color: #111;
  box-shadow: none;
  border: 1px solid rgba(0, 0, 0, 0.06);
}
.commerce-cart-page .commerce-cart-summary {
  background: var(--card, #ffffff);
  /* summary white */
  border-radius: 6px;
  padding: 1rem;
  color: #111;
  border: 1px solid rgba(0, 0, 0, 0.06);
  min-height: 80px;
  max-width: 360px;
  margin-left: auto;
  /* align to the right within the items column */
}
.commerce-cart-page {
  /* widen the items column so table has room for an extra visual column */
}
.commerce-cart-page .commerce-cart-page__items {
  max-width: 1160px;
  margin-left: auto;
  margin-right: auto;
}
.commerce-cart-page .commerce-cart-summary-wrapper {
  display: block;
}
.commerce-cart-page .commerce-cart-form-actions {
  margin-top: 1rem;
  display: flex;
  gap: 1rem;
  align-items: center;
}
.commerce-cart-page .commerce-cart-form-actions .btn-update {
  background: transparent;
  color: #111;
  border: 1px solid rgba(0, 0, 0, 0.08);
  padding: 0.5rem 0.9rem;
}
.commerce-cart-page .commerce-cart-form-actions .btn-checkout {
  background: var(--accent, #ed1c24);
  color: #fff;
  padding: 0.5rem 1rem;
  border-radius: 6px;
}
.commerce-cart-page {
  /* Title wrapper */
}
.commerce-cart-page__title-wrapper {
  text-align: center;
  margin-bottom: 1rem;
}
.commerce-cart-page__title {
  font-size: 28px;
  font-weight: 700;
  color: #fff;
  /* white title for dark header background */
  margin: 0 0 0.5rem 0;
}
.commerce-cart-page .commerce-cart-summary__inner {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.commerce-cart-page .commerce-cart-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.45rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.04);
}
.commerce-cart-page .commerce-cart-summary__row.commerce-cart-summary__total {
  font-weight: 700;
}
.commerce-cart-page .commerce-cart-summary__label {
  color: #444;
}
.commerce-cart-page .commerce-cart-summary__value {
  color: #111;
}
.commerce-cart-page {
  /* Cart table / rows */
}
.commerce-cart-page .views-table,
.commerce-cart-page .commerce-cart-items table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid rgba(0, 0, 0, 0.08);
}
.commerce-cart-page {
  /* table header: black background with white text like screenshot */
}
.commerce-cart-page .commerce-cart-items table thead th {
  color: #fff;
  font-weight: 700;
  padding: 0.9rem 0.75rem;
  background: var(--dark, #000);
  border-right: 1px solid rgba(255, 255, 255, 0.03);
  text-align: left;
}
.commerce-cart-page {
  /* set column widths to leave space for a separate 'Credits Provided' column */
}
.commerce-cart-page .commerce-cart-items table thead th:nth-child(1) {
  width: 36%;
}
.commerce-cart-page .commerce-cart-items table thead th:nth-child(2) {
  width: 12%;
}
.commerce-cart-page .commerce-cart-items table thead th:nth-child(3) {
  width: 12%;
}
.commerce-cart-page .commerce-cart-items table thead th:nth-child(4) {
  width: 12%;
}
.commerce-cart-page .commerce-cart-items table thead th:nth-child(5) {
  width: 10%;
}
.commerce-cart-page .commerce-cart-items table thead th:nth-child(6) {
  width: 18%;
}
.commerce-cart-page .commerce-cart-items table tbody td {
  padding: 0.85rem 0.75rem;
  vertical-align: middle;
  color: #222;
  border-bottom: 1px solid rgba(0, 0, 0, 0.03);
  background: #fff;
}
.commerce-cart-page .commerce-cart-items table tbody td {
  border-right: 1px solid rgba(0, 0, 0, 0.04);
}
.commerce-cart-page .commerce-cart-items table tbody td:last-child {
  border-right: none;
}
.commerce-cart-page .commerce-cart-items table tbody tr:nth-child(odd) td {
  background: #f7f7f7;
}
.commerce-cart-page .commerce-cart-items .quantity input[type=number] {
  max-width: 120px;
  padding: 0.5rem 0.6rem;
  border-radius: 6px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  background: #fff;
}
.commerce-cart-page {
  /* visual divider below the table */
}
.commerce-cart-page .xuan-cart-divider {
  height: 12px;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.06), rgba(0, 0, 0, 0));
  margin: 0.75rem 0 1rem 0;
  border-radius: 4px;
}
.commerce-cart-page {
  /* Actions row: use .commerce-cart-form-actions (defined above) */
}
.commerce-cart-page .commerce-cart-empty {
  padding: 1rem;
  background: transparent;
  color: inherit;
}
.commerce-cart-page .commerce-cart-summary--placeholder {
  padding: 0.75rem;
  background: rgba(0, 0, 0, 0.03);
  border-radius: 6px;
  color: inherit;
}
.commerce-cart-page #edit-checkout {
  background: var(--accent);
  color: #fff;
  padding: 8px 20px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 500;
}
.commerce-cart-page #edit-checkout:hover {
  background: #000;
}
.commerce-cart-page #edit-submit {
  background: #000;
  color: #fff;
  padding: 8px 20px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 500;
}
.commerce-cart-page #edit-submit:hover {
  background: var(--accent);
}
.commerce-cart-page #edit-actions {
  display: flex;
  justify-content: center;
}
.commerce-cart-page {
  /* If the view or module outputs multiple summary or action blocks,
     only show the first occurrence (prevent duplicate UI) */
}
.commerce-cart-page .commerce-cart-summary:not(:first-of-type),
.commerce-cart-page .commerce-cart-form-actions:not(:first-of-type) {
  display: none !important;
}
.commerce-cart-page {
  /* Small responsive tweak: stack columns on small screens */
}
@media (max-width: 991.98px) {
  .commerce-cart-page {
    /* On small screens, the existing Bootstrap cols will stack naturally */
  }
  .commerce-cart-page .commerce-cart-items,
  .commerce-cart-page .commerce-cart-summary {
    width: 100%;
  }
  .commerce-cart-page {
    margin: 1rem 0;
  }
}
@media (min-width: 1200px) {
  .commerce-cart-page {
    padding: 3rem 0;
  }
}

.commerce-cart-page .view-content .views-form form .table-responsive {
  width: 100%;
}

.commerce-cart-page .view-content .views-form form .table-responsive table {
  width: 100%;
  overflow-x: auto;
}

.homepage-hero-slider {
  --h: 100vh;
}

.homepage-hero-slider * {
  box-sizing: border-box;
}

.homepage-hero-slider body {
  margin: 0;
  font-family: "Helvetica Neue", Arial, sans-serif !important;
  background: #000;
  color: #fff;
}

/* Slider Root */
.homepage-hero-slider .slider {
  position: relative;
  width: 100%;
  height: var(--h);
  overflow: hidden;
  isolation: isolate;
}

/* Slides stack */
.homepage-hero-slider .slides {
  position: relative;
  width: 100%;
  height: 100%;
  pointer-events: none !important;
}

.homepage-hero-slider .slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.homepage-hero-slider .slide.is-active {
  opacity: 1;
  pointer-events: auto;
  z-index: 5;
}

/* Base background image */
.homepage-hero-slider .slide .bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform-origin: center center;
  will-change: transform, filter, opacity;
  -webkit-backface-visibility: hidden;
}

/* Optional depth layer */
.homepage-hero-slider .slide .depth-layer {
  position: absolute;
  width: 60%;
  height: 60%;
  left: 20%;
  top: 20%;
  pointer-events: none;
  will-change: transform, opacity;
  mix-blend-mode: screen;
  opacity: 0.8;
}

/* Overlay content */
.homepage-hero-slider .overlay {
  position: absolute;
  max-width: 540px;
  z-index: 10 !important;
  color: #fff;
  text-shadow: 0 10px 30px rgba(0, 0, 0, 0.7);
  pointer-events: auto !important;
}

.homepage-hero-slider .overlay h2 {
  font-size: clamp(28px, 6vw, 64px);
  margin: 0 0 12px;
  letter-spacing: 1px;
  font-family: "Cinzel", serif !important;
  margin-bottom: 0px;
}

.home-slide-h2 {
  font-weight: 400 !important;
}

.homepage-hero-slider .overlay p {
  margin: 0 0 20px;
  font-size: clamp(14px, 2.2vw, 25px);
  line-height: 1.5;
  font-family: "Montserrat", serif !important;
}

.homepage-hero-slider .overlay a {
  font-family: "Montserrat", serif !important;
}

/* Buttons */
.homepage-hero-slider .btn {
  display: inline-block;
  padding: 12px 26px;
  border-radius: 8px;
  background: var(--accent);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.45);
  margin-left: 0px;
}

/* Overlay position helpers */
.homepage-hero-slider .top-left {
  top: 100px !important;
  left: 100px !important;
  text-align: left;
}

.homepage-hero-slider .top-right {
  top: 100px !important;
  right: 100px !important;
  text-align: right;
}

.homepage-hero-slider .bottom-left {
  bottom: 100px !important;
  left: 100px !important;
  text-align: left;
}

.homepage-hero-slider .bottom-right {
  bottom: 100px !important;
  right: 100px !important;
  text-align: right;
}

/* Controls */
.homepage-hero-slider .controls {
  position: absolute;
  left: 20px;
  bottom: 20px;
  z-index: 30;
  display: flex;
  gap: 12px;
  align-items: center;
}

.homepage-hero-slider .controls .dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.35);
  cursor: pointer;
}

.homepage-hero-slider .controls .dot.is-active {
  background: #fff;
  box-shadow: 0 6px 18px rgba(255, 255, 255, 0.12);
}

/* Arrows */
.homepage-hero-slider .arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 30;
  background: rgba(0, 0, 0, 0.42);
  padding: 14px;
  border-radius: 8px;
  color: #fff;
  cursor: pointer;
  user-select: none;
}

.homepage-hero-slider .arrow.prev {
  left: 20px;
}

.homepage-hero-slider .arrow.next {
  right: 20px;
}

/* Vignette */
.homepage-hero-slider .vignette {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 40;
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 0.35) 100%);
  mix-blend-mode: multiply;
}

/* Screen reader only content */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.homepage-hero-slider .btn:hover {
  background: #e2464d;
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  .homepage-hero-slider .slide .bg,
  .homepage-hero-slider .overlay h2,
  .homepage-hero-slider .overlay p,
  .homepage-hero-slider .overlay .btn {
    transition: none !important;
    animation: none !important;
  }
  .homepage-hero-slider .depth-layer {
    transform: none !important;
  }
}
/* Hardware acceleration for better performance */
.homepage-hero-slider .slide .bg {
  transform: translateZ(0);
  backface-visibility: hidden;
  perspective: 1000px;
}

.homepage-hero-slider .overlay {
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* Loading state */
.homepage-hero-slider.loading .slide .bg {
  filter: blur(4px);
  opacity: 0.7;
}

.homepage-hero-slider.loading .overlay {
  opacity: 0.5;
}

/* Responsive */
@media (max-width: 900px) {
  .homepage-hero-slider .overlay {
    max-width: 320px;
    padding: 8px 12px;
  }
  .homepage-hero-slider .arrow {
    padding: 10px;
  }
  .homepage-hero-slider .slider {
    height: 75vh;
  }
  .homepage-hero-slider .slide .bg {
    background-position: center center;
    width: 100%;
    height: 100%;
  }
}
@media (max-width: 600px) {
  .homepage-hero-slider .overlay h2 {
    font-size: clamp(24px, 8vw, 48px);
    font-weight: 400 !important;
  }
  .homepage-hero-slider .overlay p {
    font-size: clamp(12px, 3vw, 20px);
  }
  .homepage-hero-slider .btn {
    padding: 10px 20px;
    font-size: 14px;
  }
  .homepage-hero-slider .controls {
    bottom: 15px;
    gap: 8px;
  }
  .homepage-hero-slider .controls .dot {
    width: 10px;
    height: 10px;
  }
  .homepage-hero-slider .arrow {
    padding: 8px;
    font-size: 18px;
  }
}
.homepage-hero-slider .overlay .btn {
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3), 0 10px 30px rgba(0, 0, 0, 0.45), 0 20px 60px rgba(0, 0, 0, 0.6);
}

.homepage-hero-slider div#dotsWrap {
  display: none;
}

@media (max-width: 767px) {
  .homepage-hero-slider .overlay {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    /* Align content to top */
    align-items: flex-start !important;
    /* Align items to left */
    top: 5% !important;
    /* Moved higher up (was 10%) */
    left: 5% !important;
    bottom: 5% !important;
    width: auto !important;
    max-width: 65% !important;
    /* Constrain width to avoid center face */
    height: 85% !important;
  }
  .homepage-hero-slider .overlay h2,
  .homepage-hero-slider .overlay p {
    text-align: left !important;
    margin-left: 0 !important;
    /* Ensure specific positioning isn't fighting flex */
    position: relative !important;
    /* transform: none !important;  <-- REMOVED to allow GSAP animations */
    left: auto !important;
    top: auto !important;
    bottom: auto !important;
    right: auto !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8) !important;
    /* Improved readability */
  }
  /* Push button to bottom */
  .homepage-hero-slider .overlay .btn {
    margin-top: auto !important;
    /* Pushes button to bottom of flex container */
    align-self: flex-start !important;
    /* Keep button on left */
    position: relative !important;
    left: auto !important;
    bottom: auto !important;
  }
  /* Overrides for specific slides (index 2, 3, 4, 6, 8, 9, 10, 14, 15, 17) to align RIGHT */
  .homepage-hero-slider .slide[data-index="2"] .overlay,
  .homepage-hero-slider .slide[data-index="3"] .overlay,
  .homepage-hero-slider .slide[data-index="4"] .overlay,
  .homepage-hero-slider .slide[data-index="6"] .overlay,
  .homepage-hero-slider .slide[data-index="8"] .overlay,
  .homepage-hero-slider .slide[data-index="9"] .overlay,
  .homepage-hero-slider .slide[data-index="10"] .overlay,
  .homepage-hero-slider .slide[data-index="14"] .overlay,
  .homepage-hero-slider .slide[data-index="15"] .overlay,
  .homepage-hero-slider .slide[data-index="17"] .overlay {
    left: auto !important;
    right: 5% !important;
    align-items: flex-end !important;
  }
  .homepage-hero-slider .slide[data-index="2"] .overlay h2,
  .homepage-hero-slider .slide[data-index="2"] .overlay p,
  .homepage-hero-slider .slide[data-index="3"] .overlay h2,
  .homepage-hero-slider .slide[data-index="3"] .overlay p,
  .homepage-hero-slider .slide[data-index="4"] .overlay h2,
  .homepage-hero-slider .slide[data-index="4"] .overlay p,
  .homepage-hero-slider .slide[data-index="6"] .overlay h2,
  .homepage-hero-slider .slide[data-index="6"] .overlay p,
  .homepage-hero-slider .slide[data-index="8"] .overlay h2,
  .homepage-hero-slider .slide[data-index="8"] .overlay p,
  .homepage-hero-slider .slide[data-index="9"] .overlay h2,
  .homepage-hero-slider .slide[data-index="9"] .overlay p,
  .homepage-hero-slider .slide[data-index="10"] .overlay h2,
  .homepage-hero-slider .slide[data-index="10"] .overlay p,
  .homepage-hero-slider .slide[data-index="14"] .overlay h2,
  .homepage-hero-slider .slide[data-index="14"] .overlay p,
  .homepage-hero-slider .slide[data-index="15"] .overlay h2,
  .homepage-hero-slider .slide[data-index="15"] .overlay p,
  .homepage-hero-slider .slide[data-index="17"] .overlay h2,
  .homepage-hero-slider .slide[data-index="17"] .overlay p {
    text-align: right !important;
  }
  .homepage-hero-slider .slide[data-index="2"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="3"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="4"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="6"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="8"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="9"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="10"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="14"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="15"] .overlay .btn,
  .homepage-hero-slider .slide[data-index="17"] .overlay .btn {
    align-self: flex-end !important;
  }
}
