 * {
     margin: 0;
     padding: 0;
     box-sizing: border-box;
 }

 body {
     font-family: Roboto, sans-serif, arial !important;
     background-color: #f8f9fa;
     font-size: 16px;
     line-height: 26px;
     /* overflow-y: hidden !important; */
 }

 :root {
     --color-white: #ffffff;
     --color-red: #cc0000;
     --color-gray: #737680;
     --color-red-light: rgba(204, 0, 0, 0.1);
     --color-red-dark: #990000;
     --color-gray-light: rgba(115, 118, 128, 0.1);
     --color-gray-dark: #5a5d66;
     --shadow-soft: rgba(147, 147, 147, .1) 0 1px 15px 1px;
     --shadow-medium: 0 10px 15px -3px rgba(115, 118, 128, 0.1), 0 4px 6px -2px rgba(115, 118, 128, 0.05);
     --shadow-large: 0 20px 25px -5px rgba(115, 118, 128, 0.1), 0 10px 10px -5px rgba(115, 118, 128, 0.04);
 }


 body.no-scroll {
     overflow: hidden;
 }

 #selectAnother,
 #selectAnotherNew {
     display: none;
 }

 .gray-modal {
     color: var(--color-gray) !important;
 }

 .mt-15px {
     margin-top: 15px !important;
 }

 .day-header.today .text-xs.mt-1.bg-white-custom.bg-opacity-20.rounded-full.px-2.py-1 {
     display: none;
 }

 .gray-dark {
     color: var(--color-gray-dark) !important;
 }

 .checkbox-item {
     display: flex;
     align-items: center;
     margin: 10px 0;
 }

 .text-danger {
     color: #cc0000 !important;
 }

 .checkbox-item input[type="checkbox"] {
     width: 65px;
     margin-top: -1px;
     margin-right: 10px;
     height: 23px;
 }

 .hero-section {
     position: relative;
     height: 800px;
     background: url('../image/background-space.jpg') no-repeat center center;
     background-size: cover;
     color: white;
     display: flex;
     align-items: center;
     justify-content: left;
     text-align: center;
 }

 .fw-100 {
     font-weight: 100 !important;
 }

 .text-left {
     text-align: left;
 }

 .position-relative .workshop-content .d-flex.align-items-center.pb-3.pt-2 {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
 }

 /* .hero-overlay {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
     background: rgba(0, 0, 0, 0.3);
     z-index: 1;
 } */

 .hero-content {
     position: relative;
     z-index: 2;
 }

 .hero-content h1 {
     font-size: 2.5rem;
     font-weight: bold;
     margin-bottom: 15px;
     color: #fff;
 }

 .hero-content p {
     font-size: 1.25rem;
     color: #ddd;
 }

 .counter-section {
     background-color: #fff;
     padding: 20px;
     position: relative;
     top: -50px;
     box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
     border-radius: 10px;
     margin: 0 15px;
 }

 .counter-section img {
     width: 80px;
     margin: 0 15px;
 }

 .wall-frames {
     position: absolute;
     top: 50px;
     left: 0;
     right: 0;
     display: flex;
     justify-content: center;
     gap: 10px;
     flex-wrap: wrap;
 }

 .wall-frames img {
     width: 150px;
     height: 150px;
     border: 5px solid #dc3545;
     border-radius: 5px;
 }

 .position-relative {
     position: relative;
 }

 .custom-fixed-social {
     display: table-cell;
     width: 36px;
     height: 36px;
     vertical-align: middle;
     background: #9b9b9b;
     color: #fff;
     text-align: center;
     line-height: 36px;
     margin: auto;
     border-radius: 50%;
 }

 .time {
     font-size: 26px !important;
     color: #353535;
 }

 .social-icons-custom {
     z-index: 2;
     position: fixed;
     top: 41%;
     left: 8%;
     display: flex;
     flex-direction: column;
     gap: 15px;
 }

 .social-icons a {
     color: #6c757d;
     font-size: 24px;
     text-decoration: none;
 }

 .card-title-space {
     margin-bottom: 20px;
     font-size: 24px;
 }

 .custom-middle-body {
     /* height: 120px; */
     /* overflow: hidden; */
 }

 .card-text.mb-0 {
     margin-bottom: 0px !important;
 }

 .card {
     height: 100%;
     border: none;
     border-radius: 15px;
     overflow: hidden;
     box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
     transition: transform 0.3s;
 }

 .fs-16pt {
     font-size: 16px;
 }

 .event-details {
     margin-bottom: 20px;
 }

 .event-details li {
     margin-bottom: 10px;
 }

 .event-wrapper {
     gap: 8px;
     width: 126px;
     display: flex;
     flex-direction: column;
     align-items: center;
     justify-content: center;
     background-color: #f8f9fa;
     border-radius: 10px;
     margin: auto;
 }


 .hotline,
 .email {
     margin-top: 10px;
 }

 .email a {
     color: #dc3545;
     text-decoration: none;
 }

 .email a:hover {
     text-decoration: underline;
 }

 .card-img-top {
     height: 200px;
     object-fit: cover;
 }

 .card-body {
     padding: 20px;
 }

 .card-title {
     font-size: 24px;
     margin-bottom: 10px;
 }

 .card-text {
     color: #6c757d;
     margin-bottom: 20px;
 }

 .btn-custom-canon {
     background-color: #dc3545;
     color: white;
     font-size: 12px;
     border-radius: 25px;
     padding: 10px 20px;
     font-weight: bold;
     transition: background-color 0.3s;
 }

 .btn-custom-canon:hover {
     background-color: #c82333;
     color: #fff;
 }

 .btn-custom:hover {
     background-color: #c82333;
     color: #fff;
 }

 .custom-middle-body a {
     color: #353535;
     text-decoration: none;
 }

 .custom-middle-body a:hover {
     color: #E31837;
 }

 .fas.fa-bars {
     font-size: 20px;
     color: #4a4a4abd;
 }

 /* Navbar Toggler */
 .navbar-toggler {
     position: fixed;
     top: 20px;
     left: 10px;
     z-index: 1200;
     /* background: #E31837; */
     border: none;
     padding: 10px;
     border-radius: 5px;
     color: white;
     display: none;
 }

 /* Mobile Menu */
 .mobile-menu {
     position: fixed;
     top: 0;
     left: 0;
     width: 100vw;
     height: 100vh;
     background: rgba(0, 0, 0, 0.95);
     z-index: 1150;
     display: none;
     flex-direction: column;
     align-items: center;
     justify-content: center;
     color: white;
     text-align: center;
 }

 .mobile-menu.active {
     display: flex;
 }

 .mobile-menu .nav-link {
     color: white !important;
     font-size: 18px;
     padding: 15px;
     text-decoration: none;
     display: block;
 }

 .mobile-menu .nav-link:hover {
     background: #E31837;
 }

 .mobile-menu .language-switcher a {
     color: white;
     font-size: 18px;
     padding: 15px;
     text-decoration: none;
     display: block;
 }

 .mobile-menu .language-switcher a.active {
     color: #E31837;
     font-weight: bold;
 }

 .mobile-menu .search-icon {
     color: white;
     font-size: 18px;
     padding: 15px;
     display: block;
 }

 .mobile-menu .close-btn {
     position: absolute;
     top: 20px;
     right: 20px;
     background: none;
     border: none;
     color: white;
     font-size: 24px;
     cursor: pointer;
 }

 /* Header Styles */
 .top-header {
     background-color: white;
     border-bottom: 1px solid #e0e0e0;
     padding: 20px 0 8px 0;
     z-index: 1100;
 }

 .top-header .container {
     display: flex;
     align-items: center;
     justify-content: space-between;
 }

 .canon-logo {
     color: #E31837;
     font-size: 28px;
     font-weight: bold;
     text-decoration: none;
 }

 .canon-tagline {
     font-size: 12px;
     color: #666;
     margin-top: -5px;
 }

 .header-links {
     font-size: 13px;
 }

 .header-links a {
     font-size: 14px;
     line-height: 14px;
     color: #757575;
     padding-right: 3.5px;
     text-decoration: none;
     margin: 0 7px;
 }

 .language-switcher {
     font-size: 13px;
 }

 .language-switcher a {
     color: #333;
     text-decoration: none;
 }

 .language-switcher .active {
     color: #E31837;
     font-weight: bold;
 }

 /* Navigation Styles */
 .main-nav {
     background-color: #333;
     padding: 0;
     z-index: 9;
 }

 .main-nav .navbar-nav .nav-link {
     display: block;
     color: #fff;
     border-bottom: 3px solid transparent;
     padding: 16px 0 13px 0;
 }

 .text-vietnam {
     margin-left: 12px;
     position: relative;
     top: -6px;
     color: #666363;
 }

 .main-nav .navbar-nav .nav-link:hover {
     background-color: unset;
     color: #cc0000 !important;
 }

 .main-nav .navbar-nav .not-hover:hover {
     background-color: unset;
     color: #ffffff !important;
 }

 .right-nav-items {
     margin-left: auto;
 }

 .navbar-nav .nav-item {
     list-style: none;
     display: inline-block;
     margin: 0;
     padding: 0 20px 0 0;
 }


 .content-join {
     line-height: 15px;
     font-size: 11px;
     font-weight: 600;
     color: #4c4c4c;
 }

 /* Breadcrumb */
 .breadcrumb-section {
     position: relative;
     font-size: 16px;
     width: 100%;
     color: #fff !important;
     background-color: #4a4a4a;
     min-height: 70px;
     padding: 20px 0;
     display: block;
     z-index: 97 !important;
 }


 .breadcrumb-section .breadcrumb {
     margin: 0;
     background: none;
     padding: 0;
 }

 .breadcrumb-section .breadcrumb-item a {
     color: #ccc;
     text-decoration: none;
     font-size: 13px;
 }

 .breadcrumb-section .breadcrumb-item.active {
     color: white;
     font-size: 13px;
 }

 /* Main Content */
 .main-content {
     background-color: #fafafa;
     padding: 40px 0;
 }


 /* Workshop Cards */
 .workshop-card {
     background: white;
     border-radius: 8px;
     overflow: hidden;
     box-shadow: rgba(147, 147, 147, .1) 0 1px 15px 1px;
     /* margin-bottom: 30px; */
     transition: transform 0.3s ease, box-shadow 0.3s ease;
 }

 /* .workshop-card:hover {
     transform: translateY(-5px);
     box-shadow: 0 5px 20px rgba(0, 0, 0, 0.15);
 } */

 .workshop-image {
     max-width: 100%;
     object-fit: cover;
     position: relative;
 }

 .fw-800 {
     font-weight: 800;
 }

 .fw-besimple {
     font-weight: 100;
     color: #bebebe;
 }

 .not-hover:hover {
     background-color: unset !important;
     cursor: unset !important;
     user-select: none;
     -webkit-user-select: none;
     -moz-user-select: none;
     -ms-user-select: none;
 }

 .workshop-tag {
     position: absolute;
     top: 18px;
     left: 40px;
     /* right: 39%; */
     background: rgb(255 255 255);
     color: #4c4c89;
     padding: 2px 15px;
     border-radius: 20px;
     font-size: 12px;
     font-weight: 600;
 }

 .header-links a.active {
     color: #e41920;
     font-weight: bold;
 }

 .workshop-content {
     padding: 25px;
 }

 .workshop-content .workshop-title {
     text-overflow: ellipsis;
     display: -webkit-box;
     -webkit-line-clamp: 3;
     max-height: 96px;
     height: 96px;
     overflow: hidden;
     font-size: 18px;
     font-weight: 600;
     color: #333;
     font-size: 24px !important;
     line-height: 32px !important;
 }

 /* .col-md-4.mb-4 .workshop-card {
     height: 100%;
 } */

 .workshop-title a {
     font-weight: 100;
     text-decoration: none;
     overflow: hidden;
     /* color: #353535 !important; */
     text-overflow: ellipsis;
     display: -webkit-box;
     -webkit-line-clamp: 3;
 }

 .color-footer-text {
     color: #6c757d;
 }

 .workshop-title-all {
     text-overflow: ellipsis;
     display: -webkit-box;
     -webkit-line-clamp: 3;
     max-height: 96px;
     height: 96px;
     overflow: hidden;
     font-size: 18px;
     -webkit-box-orient: vertical;
     /* font-weight: 600; */
     color: #333;
     font-size: 24px !important;
     line-height: 32px !important;
 }

 .workshop-title-all a {
     font-weight: 100;
     text-decoration: none;
     overflow: hidden;
     color: #353535 !important;
     text-overflow: ellipsis;
     display: -webkit-box;
     -webkit-line-clamp: 3;
 }

 .text-gray-event {
     color: #575758 !important;
 }

 .tag-event {
     background: #ffffff;
     color: #e31837;
     line-height: 18px;
     max-width: 6rem;
     /* background: #737680;
     color: #ffffff; */
     padding: 6px 15px;
     border-radius: 15px;
     font-size: 11px;
     font-weight: 700;
 }

 .ml-auto {
     margin-left: auto;
 }

 .tag-event-slot .fa.fa-circle.fs-8pt {
     margin-bottom: 1px;
 }

 .tag-event-slot {
     gap: 2px !important;
     background: #f5f5f5;
     color: #51a21f;
     /* background: #fbfbfb;
     color: #ffffff; */
     padding: 0px 10px;
     border-radius: 8px;
     font-size: 14px;
     font-weight: 600;
 }

 .workshop-card .workshop-content {
     padding-top: 10px;
     /* height: 100%; */
 }

 .fs-8pt {
     font-size: 8px;
 }

 .workshop-content .workshop-date {
     color: #6f6f6f;
 }

 .workshop-title a:hover {
     color: #E31837;
 }

 .workshop-date {
     font-weight: bold;
     color: #ffffff;
     margin-bottom: 10px;
 }

 .event-details {
     list-style: disc !important;
     margin-left: 1.5rem !important;
 }


 .workshop-content .workshop-description {
     margin-bottom: 0.75rem !important;
 }

 .mb-30 {
     margin-bottom: 30px !important;
 }

 .mt-30 {
     margin-top: 30px !important;
 }

 .workshop-description {
     height: 6.2rem;
     overflow: hidden;
     text-overflow: ellipsis;
     -webkit-box-orient: vertical;
     display: -webkit-box;
     -webkit-line-clamp: 4;
     color: #666;
     font-size: 16px;
     line-height: 1.6;
     margin-bottom: 20px;
 }

 .read-more-btn {
     background-color: #E31837;
     color: white;
     padding: 10px 25px;
     border: none;
     border-radius: 25px;
     font-size: 14px;
     font-weight: 600;
     text-decoration: none;
     display: inline-block;
     transition: background-color 0.3s ease;
 }

 .read-more-btn:hover {
     background-color: #c41230;
     color: white;
 }

 /* Featured Workshop Card */
 .featured-workshop {
     background: linear-gradient(135deg, #333 0%, #555 100%);
     color: white;
     position: relative;
     overflow: hidden;
     min-height: 300px;
 }

 .featured-content {
     height: 100%;
     position: relative;
     z-index: 2;
     padding: 40px;
 }

 .featured-workshop .workshop-title {
     color: white;
     font-size: 24px;
     margin-bottom: 20px;
 }

 .featured-workshop .workshop-description {
     color: #ccc;
     font-size: 16px;
 }

 .featured-workshop .read-more-btn {
     margin-top: 20px;
 }

 .speaker-info {
     display: flex;
     align-items: center;
     margin-top: 20px;
 }

 .speaker-avatar {
     width: 50px;
     height: 50px;
     border-radius: 50%;
     margin-right: 15px;
     border: 2px solid white;
 }

 .speaker-details h5 {
     margin: 0;
     font-size: 16px;
     font-weight: 600;
 }

 .speaker-details p {
     margin: 0;
     font-size: 12px;
     opacity: 0.8;
 }

 .qr-code {
     position: absolute;
     bottom: 20px;
     right: 20px;
     width: 80px;
     height: 80px;
     background: white;
     border-radius: 8px;
     display: flex;
     align-items: center;
     justify-content: center;
     font-size: 10px;
     color: #333;
     text-align: center;
 }

 .logo-img {
     width: 150px;
     height: auto;
 }

 /* Section separators */
 .section-separator {
     border-top: 2px solid #E31837;
     margin: 50px 0 30px 0;
     padding-top: 30px;
 }

 .container {
     padding-right: 15px !important;
     padding-left: 15px !important;
     margin-right: auto !important;
     margin-left: auto !important;
 }

 .section-separator h2 {
     font-size: 28px;
     font-weight: 300;
     color: #333;
     margin-bottom: 30px;
 }

 .over-flow-x {
     overflow-x: auto;
 }

 /* button  */
 .text-right {
     text-align: right;
 }

 .read-more {
     display: inline-flex;
     align-items: center;
     gap: 12px;
     padding: 8px 22px;
     font-family: 'Poppins', sans-serif;
     font-size: 12px;
     font-weight: 600;
     text-decoration: none;
     color: #ffffff;
     background: linear-gradient(90deg, #cc0000 0%, #ff4d4d 100%);
     border: none;
     border-radius: 45px;
     box-shadow: 0 5px 15px rgba(204, 0, 0, 0.4);
     position: relative;
     overflow: hidden;
     cursor: pointer;
     transition: all 0.4s ease;
     z-index: 1;
 }

 /* Hiệu ứng ánh kim động */
 .read-more::before {
     content: '';
     position: absolute;
     top: 0;
     left: -150%;
     width: 150%;
     height: 100%;
     background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
     transition: 0.6s ease;
     z-index: -1;
 }

 .read-more:hover::before {
     left: 150%;
 }

 /* Hiệu ứng hover */
 .read-more:hover {
     background: linear-gradient(90deg, #e60000 0%, #cc0000 100%);
     box-shadow: 0 8px 25px rgba(204, 0, 0, 0.6), 0 0 15px rgba(204, 0, 0, 0.4);
     transform: translateY(-4px) scale(1.03);
     color: #ffffff;
 }

 /* Hiệu ứng active */
 .read-more:active {
     transform: scale(0.94);
     box-shadow: 0 3px 10px rgba(204, 0, 0, 0.3);
 }

 /* Hiệu ứng icon */
 .read-more i {
     font-size: 12px;
     transition: transform 0.4s ease, opacity 0.4s ease;
 }

 .read-more:hover i {
     transform: translateX(8px) rotate(90deg);
     opacity: 0.8;
 }

 /* Viền phát sáng neon */
 .read-more::after {
     content: '';
     position: absolute;
     inset: 0;
     border-radius: 45px;
     padding: 2px;
     background: linear-gradient(45deg, #cc0000, #ff8080);
     -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
     mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
     -webkit-mask-composite: xor;
     mask-composite: exclude;
     opacity: 0.6;
     transition: opacity 0.4s ease;
 }

 .read-more:hover::after {
     opacity: 1;
 }


 .particle-canvas {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
     pointer-events: none;
     z-index: 0;
 }

 .footer-bottom {
     border-top: 1px solid #9a9a9a;
     padding: 10px 0 80px 0;
     font-size: 16px;
     color: #757575;
 }

 footer {
     z-index: 10;
     background: #ffffff;
     color: #333;
     padding: 60px 0 30px;
     font-family: 'Roboto', sans-serif;
     font-size: 15px;
     position: relative;
     box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.05);
 }

 footer h5 {
     font-size: 16px;
     color: #757575;
     font-weight: 700;
     margin: 0 0 15px 0;
 }

 footer h5::after {
     content: '';
     position: absolute;
     bottom: 0;
     left: 0;
     width: 40px;
     height: 2px;
     background-color: #cf1212;
 }

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

 footer ul li {
     margin-bottom: 12px;
 }

 .footer-bottom-text {
     border-top: 1px solid #9a9a9a;
     padding: 10px 0 80px 0;
     font-size: 16px;
     color: #757575;
 }

 footer a {
     color: #333;
     text-decoration: none;
     transition: color 0.3s ease;
 }

 footer a:hover {
     color: #cc0000;
 }

 .footer-bottom {
     border-top: 1px solid rgba(0, 0, 0, 0.1);
     padding-top: 25px;
     margin-top: 40px;
     font-size: 13px;
     color: #666;
     text-align: center;
 }

 .fs-10pt {
     font-size: 10px;
 }

 .fw-600 {
     font-weight: 600;
 }

 .pl-0 {
     padding-left: 0 !important;
 }

 .back-to-top {
     z-index: 11;
     position: fixed;
     bottom: 55px;
     right: 30px;
     background-color: #d0d0d1;
     color: #fff;
     border-radius: 50%;
     width: 50px;
     height: 50px;
     display: flex;
     align-items: center;
     justify-content: center;
     text-decoration: none;
     opacity: 0;
     transition: all 0.3s ease;
     box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
 }

 .back-to-top:hover {
     background-color: #2980b9;
     transform: translateY(-3px);
 }

 .back-to-top.show {
     opacity: 1;
 }

 .custom-ml-vie {
     margin-left: 16.5px !important;
 }

 .social-icons a {
     margin-right: 15px;
     font-size: 20px;
     color: #666;
     transition: color 0.3s ease;
 }

 .social-icons a:hover {
     color: #cc0000;
 }

 .col-md-2 {
     margin-bottom: 30px;
 }
.swiper-button-next:after, .swiper-button-prev:after {
    font-weight: 700 !important;
    font-size: 28px;
}
.swiper-button-next {
    right: -50px !important;
    color: #cd0303 !important;
}

.swiper-button-prev {
    left: -50px !important;
    color: #cd0303 !important;
}

 .search-container {
     position: relative;
     max-width: 450px;
     margin: 30px auto;
     font-family: 'Roboto', sans-serif;
 }

 .search-input {
     width: 100%;
     padding: 12px 50px 12px 20px;
     padding-right: 3.5rem !important;
     border: none;
     border-radius: 30px;
     font-size: 16px;
     background: #ffffff;
     box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
     outline: none;
     transition: all 0.3s ease;
     position: relative;
 }

 .search-input::before {
     content: '';
     position: absolute;
     inset: 0;
     border-radius: 30px;
     padding: 2px;
     background: linear-gradient(45deg, #007bff, #00c4b4);
     -webkit-mask:
         linear-gradient(#fff 0 0) content-box,
         linear-gradient(#fff 0 0);
     -webkit-mask-composite: xor;
     mask-composite: exclude;
 }

 .search-input:focus {
     box-shadow: 0 6px 20px rgba(0, 123, 255, 0.2);
     transform: translateY(-2px);
 }

 .search-input::placeholder {
     color: #adb5bd;
     font-style: italic;
 }

 .search-icon {
     position: absolute;
     right: 20px;
     top: 50%;
     transform: translateY(-50%);
     color: #495057;
     font-size: 20px;
     cursor: pointer;
     transition: color 0.3s ease, transform 0.3s ease;
 }

 .space-y-2 .text-center.p-2.bg-gray-100.rounded-lg {
     background-color: #737680 !important;
     color: #fff !important;
     border-radius: 0 !important;
 }

 .search-icon:hover {
     color: #007bff;
     transform: translateY(-50%) scale(1.1);
 }

 .mobile-icon-search {
     color: #495057 !important;
     right: 7px !important;
 }

 .shadow-md {
     box-shadow: rgba(147, 147, 147, .1) 0 1px 15px 1px !important;
 }

 .search-form {
     position: relative;
 }

 .custom-slide {
     height: 100%;
     width: 100%;
     object-fit: cover;
 }

 .time-custom {
     color: #353535;
     font-size: 26px !important;
 }

 .fs-26pt {
     font-size: 26px !important;
 }

 .fs-30pt {
     font-size: 30px !important;
 }

 .glass-morphism {
     background: rgba(255, 255, 255, 0.95);
     backdrop-filter: blur(20px);
     border: 1px solid rgba(115, 118, 128, 0.1);
 }

 .card-premium {
     background: var(--color-white);
     border-radius: 8px;
     box-shadow: var(--shadow-large);
     border: 1px solid rgba(115, 118, 128, 0.1);
     transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
 }

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

 .py-custom-button {
     padding: 0.4rem 0.7rem 0.4rem 0.7rem !important;
 }

 /* .card-premium:hover {
     transform: translateY(-5px);
     box-shadow: 0 25px 50px -12px rgba(115, 118, 128, 0.25);
 } */

 .btn-premium {
     position: relative;
     overflow: hidden;
     border-radius: 16px;
     font-weight: 600;
     letter-spacing: 0.025em;
     transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
     box-shadow: var(--shadow-soft);
     border: none;
     cursor: pointer;
 }

 .btn-premium::before {
     content: '';
     position: absolute;
     top: 0;
     left: -100%;
     width: 100%;
     height: 100%;
     background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
     transition: left 0.5s;
 }

 .btn-premium:hover::before {
     left: 100%;
 }

 .btn-premium:hover {
     transform: translateY(-2px);
     box-shadow: var(--shadow-medium);
 }

 .btn-primary {
     background: var(--color-red);
     color: var(--color-white);
 }

 .btn-primary:hover {
     background: var(--color-red-dark);
 }

 .btn-secondary {
     background: var(--color-gray);
     color: var(--color-white);
 }

 .btn-secondary:hover {
     background: var(--color-gray-dark);
 }

 .btn-outline {
     background: var(--color-white);
     color: var(--color-gray);
     border: 2px solid var(--color-gray);
 }

 .btn-outline:hover {
     background: var(--color-gray);
     color: var(--color-white);
 }

 .time-slot {
     flex-wrap: wrap;
     font-size: 13px !important;
     padding: 5px !important;
     position: relative;
     border-radius: 8px;
     font-weight: 500;
     transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
     box-shadow: var(--shadow-soft);
     min-height: 50px;
     display: flex;
     align-items: center;
     justify-content: center;
     backdrop-filter: blur(10px);
     border: 2px solid transparent;
 }

 .time-slot.available {
     background: var(--color-white);
     color: var(--color-gray);
     border-color: rgba(115, 118, 128, 0.2);
 }

 .time-slot.available:hover {
     transform: translateY(-3px) scale(1.02);
     box-shadow: var(--shadow-medium);
     border-color: var(--color-red);
     background: var(--color-red-light);
 }

 .time-slot.selected {
     background: var(--color-red);
     color: var(--color-white);
     border-color: var(--color-red);
     transform: translateY(-2px);
     box-shadow: var(--shadow-medium);
 }

 .time-slot.booked {
     background: #737680bf;
     color: var(--color-white);
     border-color: #737680bf;
     cursor: not-allowed;
     opacity: 0.7;
 }

 .nowrap-text {
     white-space: nowrap !important;
 }

 .bg-white-custom {
     background-color: rgba(255, 255, 255, var(--tw-bg-opacity)) !important;
 }

 .day-column {
     border-radius: 0px;
     transition: all 0.3s ease;
 }

 .day-header {
     background: var(--color-red);
     color: var(--color-white);
     border-radius: 8px;
     padding: 5px 0 5px 0;
     text-align: center;
     font-weight: 600;
     margin-bottom: 12px;
     box-shadow: var(--shadow-soft);
 }

 .day-header.today {
     background: linear-gradient(135deg, var(--color-red) 0%, var(--color-red-dark) 100%);
 }

 .day-header.past {
     background: var(--color-gray);
 }

 .modal-premium {
     backdrop-filter: blur(20px);
     background: rgba(0, 0, 0, 0.5);
 }

 .modal-content-premium {
     background: var(--color-white);
     backdrop-filter: blur(30px);
     border-radius: 24px;
     box-shadow: var(--shadow-large);
     border: 1px solid rgba(115, 118, 128, 0.1);
     max-height: 90vh;
     overflow-y: auto;
 }

 .form-input {
     border-radius: 12px;
     border: 2px solid rgba(115, 118, 128, 0.3);
     background: var(--color-white);
     transition: all 0.3s ease;
     font-size: 16px;
     padding: 12px 16px;
 }

 .form-input:focus {
     border-color: var(--color-red);
     outline: none;
     transform: translateY(-1px);
     box-shadow: var(--shadow-soft);
 }

 .booking-card {
     background: var(--color-red-light);
     border: 2px solid rgba(204, 0, 0, 0.2);
     border-radius: 16px;
     backdrop-filter: blur(10px);
     transition: all 0.3s ease;
 }

 .booking-card:hover {
     transform: translateY(-2px);
     border-color: var(--color-red);
     box-shadow: var(--shadow-medium);
 }

 .gradient-text {
     background: linear-gradient(135deg, var(--color-red) 0%, var(--color-red-dark) 100%);
     -webkit-background-clip: text;
     -webkit-text-fill-color: transparent;
     background-clip: text;
 }

 .pulse-ring {
     animation: pulse-ring 1.25s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
 }

 @keyframes pulse-ring {
     0% {
         transform: scale(.33);
     }

     80%,
     100% {
         opacity: 0;
     }
 }

 .fade-in {
     animation: fadeIn 0.5s ease-in-out;
 }

 @keyframes fadeIn {
     from {
         opacity: 0;
         transform: translateY(20px);
     }

     to {
         opacity: 1;
         transform: translateY(0);
     }
 }

 .slide-up {
     animation: slideUp 0.4s cubic-bezier(0.4, 0, 0.2, 1);
 }

 @keyframes slideUp {
     from {
         transform: translateY(100px);
         opacity: 0;
     }

     to {
         transform: translateY(0);
         opacity: 1;
     }
 }

 .floating {
     animation: floating 3s ease-in-out infinite;
 }

 @keyframes floating {

     0%,
     100% {
         transform: translateY(0px);
     }

     50% {
         transform: translateY(-10px);
     }
 }

 .loading-spinner {
     border: 3px solid rgba(115, 118, 128, 0.3);
     border-radius: 50%;
     border-top: 3px solid var(--color-red);
     width: 24px;
     height: 24px;
     animation: spin 1s linear infinite;
     display: inline-block;
 }

 @keyframes spin {
     0% {
         transform: rotate(0deg);
     }

     100% {
         transform: rotate(360deg);
     }
 }

 .success-checkmark {
     animation: checkmark 0.6s ease-in-out;
 }

 @keyframes checkmark {
     0% {
         transform: scale(0) rotate(45deg);
     }

     50% {
         transform: scale(1.2) rotate(45deg);
     }

     100% {
         transform: scale(1) rotate(45deg);
     }
 }


 @media (hover: none) and (pointer: coarse) {
     .time-slot:hover {
         transform: none;
     }

     .time-slot:active {
         transform: scale(0.98);
     }

     .btn-premium:hover {
         transform: none;
     }

     .btn-premium:active {
         transform: scale(0.98);
     }
 }

 @media print {

     .custom-fixed-social,
     header,
     footer,
     nav {
         display: none;
     }

     #printable-content {
         font-size: 14px;
         color: black;
     }

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

 /* modal event  */

 .modal-premium {
     backdrop-filter: blur(4px);
     background-color: rgba(0, 0, 0, 0.5);
 }

 .modal-content-premium {
     background-color: #ffffff;
     border-radius: 12px;
     box-shadow: 0 20px 25px -5px rgba(204, 0, 0, 0.1), 0 10px 10px -5px rgba(204, 0, 0, 0.04);
 }

 .form-input-workshop {

     padding: 12px 16px !important;
     border: 1px solid #e5e5e5 !important;
     border-radius: 8px !important;
     background-color: #ffffff !important;
     color: #737680 !important;
     font-size: 16px !important;
     transition: border-color 0.3s ease, box-shadow 0.3s ease;
     width: 100% !important;
     box-sizing: border-box !important;
     -webkit-appearance: none !important;
     -moz-appearance: none !important;
     appearance: none !important;
 }

 .cursor-pointer {
     cursor: pointer;
 }

 .bg-f8 {
     background-color: #f8f8f8 !important;
 }

 .border-custom-info-event {
     background-color: #fff3cd;
     border-left: 4px solid #cc0000;
 }

 .form-why-event {
     background-color: #f8f8f8 !important;
     border: 1px solid #e5e5e5 !important;
 }

 .color-text-modal-event {
     color: #737680 !important;
 }

 .color-text-red-modal-event {
     color: #cc0000 !important;
 }

 .form-input-workshop:focus {
     outline: none;
     border-color: #cc0000;
     box-shadow: 0 0 0 3px rgba(204, 0, 0, 0.1);
 }

 .form-input-workshop::placeholder {
     color: #b0b0b0;
 }

 .radio-workshop {
     width: 20px;
     height: 20px;
     border: 2px solid #e5e5e5;
     border-radius: 50%;
     background-color: #ffffff;
     position: relative;
     cursor: pointer;
     transition: all 0.3s ease;
     appearance: none;
     -webkit-appearance: none;
     -moz-appearance: none;
 }

 .radio-workshop:checked {
     border-color: #cc0000;
     background-color: #ffffff;
 }

 .radio-workshop:checked::before {
     content: '';
     position: absolute;
     top: 50%;
     left: 50%;
     transform: translate(-50%, -50%);
     width: 10px;
     height: 10px;
     border-radius: 50%;
     background-color: #cc0000;
 }

 .radio-label {
     cursor: pointer;
     padding: 8px 12px;
     border-radius: 6px;
     transition: background-color 0.2s ease;
 }

 .radio-label:hover {
     background-color: rgba(204, 0, 0, 0.05);
 }

 .btn-workshop-primary {
     background-color: #cc0000;
     color: #ffffff;
     border: 2px solid #cc0000;
     border-radius: 8px;
     font-weight: 600;
     font-size: 16px;
     transition: all 0.3s ease;
     cursor: pointer;
 }

 .btn-workshop-primary:hover {
     background-color: #aa0000;
     border-color: #aa0000;
     transform: translateY(-1px);
     box-shadow: 0 4px 12px rgba(204, 0, 0, 0.3);
 }

 .btn-workshop-outline {
     background-color: #ffffff;
     color: #737680;
     border: 2px solid #737680;
     border-radius: 8px;
     font-weight: 600;
     font-size: 16px;
     transition: all 0.3s ease;
     cursor: pointer;
 }

 .color-detail {
     color: #6f6f6f !important;
 }

 .btn-workshop-outline:hover {
     background-color: #737680;
     color: #ffffff;
     transform: translateY(-1px);
     box-shadow: 0 4px 12px rgba(115, 118, 128, 0.3);
 }

 .btn-premium {
     padding: 12px 24px;
     border-radius: 8px;
     font-weight: 600;
     display: inline-flex;
     align-items: center;
     justify-content: center;
     transition: all 0.3s ease;
     cursor: pointer;
 }

 .border-red-500 {
     border-color: #cc0000 !important;
     box-shadow: 0 0 0 3px rgba(204, 0, 0, 0.1) !important;
 }

 .loading-spinner {
     width: 40px;
     height: 40px;
     border: 4px solid #f3f3f3;
     border-top: 4px solid #cc0000;
     border-radius: 50%;
     animation: spin 1s linear infinite;
 }

 .z-custom {
     z-index: 9999 !important;
 }

 #termsModal {
     z-index: 99999999 !important;
 }

 .canon-red {
     background-color: #cc0000;
 }

 .canon-red-text {
     color: #cc0000;
 }

 .canon-gray {
     background-color: #737680;
 }

 .canon-gray-text {
     color: #737680;
 }

 .canon-red-border {
     border-color: #cc0000;
 }

 .canon-gray-border {
     border-color: #737680;
 }

 .class-card {
     transition: all 0.3s ease;
     border: 2px solid #e5e7eb;
 }

 .class-card:hover {
     transform: translateY(-4px);
     border-color: #cc0000;
     box-shadow: 0 10px 25px rgba(204, 0, 0, 0.15);
 }

 .time-slot {
     transition: all 0.3s ease;
     border: 1px solid #e5e7eb;
 }

 /* .time-slot:hover {
     border-color: #cc0000;
     background-color: rgba(204, 0, 0, 0.05);
 } */

 .time-slot.selected {
     background-color: #cc0000;
     color: white;
     border-color: #cc0000;
 }

 .date-input:focus {
     border-color: #cc0000;
     ring-color: rgba(204, 0, 0, 0.2);
 }

 /* Modal Styles */
 .modal {
     transition: opacity 0.25s ease;
 }

 .modal-content {
     transition: all 0.25s ease;
     transform: scale(0.9);
     opacity: 0;
 }

 .modal.show .modal-content {
     transform: scale(1);
     opacity: 1;
 }

 /* Form Styles */
 .form-group {
     position: relative;
 }

 .form-input {
     transition: all 0.3s ease;
     border: 1px solid #d1d5db;
 }

 .form-input:focus {
     border-color: #cc0000;
     box-shadow: 0 0 0 2px rgba(204, 0, 0, 0.1);
     outline: none;
 }

 .form-label {
     font-weight: 600;
     color: #374151;
     margin-bottom: 0.5rem;
     display: block;
 }

 /* Phone input styles */
 .phone-container {
     display: flex;
     border: 1px solid #d1d5db;
     border-radius: 0.5rem;
     overflow: hidden;
     transition: all 0.3s ease;
 }

 .phone-container:focus-within {
     border-color: #cc0000;
     box-shadow: 0 0 0 2px rgba(204, 0, 0, 0.1);
 }

 .country-code {
     background-color: #f9fafb;
     border-right: 1px solid #d1d5db;
     padding: 0.75rem;
     display: flex;
     align-items: center;
     font-weight: 500;
     color: #374151;
 }

 .phone-input {
     flex: 1;
     padding: 0.75rem;
     border: none;
     outline: none;
 }

 /* Workshop card styles */
 .workshop-card {
     /* height: 100%; */
     border: 1px solid #e5e7eb;
     transition: all 0.3s ease;
 }

 .workshop-card:hover {
     /* border-color: #cc0000; */
     box-shadow: 0 4px 12px rgba(204, 0, 0, 0.1);
 }

 .custom-modal-calendar {
     overflow-y: auto !important;
     height: 75vh;
 }

 .margin-custom-cb {
     margin-top: 5rem;
 }

 .min-h-75 {
     min-height: 75vh !important;
     margin-bottom: 2rem;
 }

 .workshop-image {
     height: auto;
     object-fit: cover;
     background: linear-gradient(135deg, #cc0000, #dc2626);
     color: white;
     display: flex;
     align-items: center;
     justify-content: center;
     font-size: 2rem;
 }

 .spots-left {
     background-color: #cc0000;
     color: white;
     font-size: 0.75rem;
     padding: 0.25rem 0.5rem;
     border-radius: 0.25rem;
 }

 .canon-red {
     color: var(--canon-red);
 }

 .bg-canon-red {
     background-color: var(--canon-red);
 }

 .canon-gray {
     color: var(--canon-gray);
 }

 .bg-canon-gray {
     background-color: var(--canon-gray);
 }

 .workshop-card-custom {
     border: 1px solid #e5e5e5;
     border-radius: 8px;
     background: white;
     transition: all 0.3s ease;
 }

 .workshop-card-custom:hover {
     box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
 }

 .poster-placeholder {
     width: 200px;
     height: 145px;
     max-width: 200px;
     background: linear-gradient(135deg, var(--canon-red), #ff4444);
     border-radius: 8px;
     display: flex;
     justify-content: center;
     color: white;
     font-weight: bold;
     font-size: 12px;
     text-align: center;
     line-height: 1.3;
 }

 .page-transition {
     transition: all 0.3s ease-in-out;
 }

 .fade-in {
     animation: fadeIn 0.3s ease-in;
 }

 @keyframes fadeIn {
     from {
         opacity: 0;
         transform: translateY(20px);
     }

     to {
         opacity: 1;
         transform: translateY(0);
     }
 }

 /* #selectClassPage {
     height: 84rem !important;
     overflow-y: auto;
 } */

 .btn-book {
     background-color: #dc3545;
     color: white;
     padding: 8px 16px;
     border-radius: 4px;
     border: none;
     font-weight: 600;
     cursor: pointer;
     transition: all 0.2s ease;
 }

 .btn-book:hover {
     background-color: #c82333;
 }

 .btn-primary:hover {
     background-color: #aa0000;
 }

 .form-input {
     border: none;
     border-bottom: 2px solid #ddd;
     padding: 12px 0;
     width: 100%;
     outline: none;
     transition: border-color 0.3s ease;
 }

 .form-input:focus {
     border-bottom-color: var(--canon-red);
 }

 .form-input.error {
     border-bottom-color: #ff0000;
 }

 .imgae-select-book {
     max-width: 200px;
     max-height: 300px;
 }

 .country-selector {
     display: flex;
     align-items: center;
     gap: 8px;
     padding: 12px 0;
     border-bottom: 2px solid #ddd;
 }

 .flag {
     width: 20px;
     height: 15px;
     background: linear-gradient(to bottom, #ff0000 33%, #ffff00 33%, #ffff00 66%, #ff0000 66%);
     border: 1px solid #ddd;
 }

 .hidden {
     display: none;
 }

 @keyframes spin {
     0% {
         transform: rotate(0deg);
     }

     100% {
         transform: rotate(360deg);
     }
 }

 .success-checkmark {
     animation: checkmark 0.6s ease-in-out;
     color: #cc0000;
 }

 @keyframes checkmark {
     0% {
         transform: scale(0);
         opacity: 0;
     }

     50% {
         transform: scale(1.2);
         opacity: 1;
     }

     100% {
         transform: scale(1);
         opacity: 1;
     }
 }


 .workshop {
     font-family: Arial, sans-serif;
     max-width: 400px;
     margin: 20px;
 }

 .content {
     display: -webkit-box;
     -webkit-line-clamp: 2;
     -webkit-box-orient: vertical;
     overflow: hidden;
     line-height: 1.5;
 }


 .content.full {
     -webkit-line-clamp: unset;
     display: block;
 }

 .toggle-btn {
     color: rgb(102 102 102);
 }

 .convention-sanpham {
     border-radius: 3px;
     width: 13px;
     height: 13px;
     background-color: #cc0000;
 }

 .convention-daotao {
     border-radius: 3px;
     width: 13px;
     height: 13px;
     background-color: #1e3a8a;
 }

 .convention-doitac {
     border-radius: 3px;
     width: 13px;
     height: 13px;
     background-color: #059669;
 }

 #prevWeekNew,
 #nextWeekNew,
 #selectContinueNew,
 #todayBtnNew,
 #selectAnotherNew,
 #selectRecurringNew,
 #confirmBookingNew,
 #cancelBookingNew,
 #prevWeekEvent,
 #nextWeekEvent {
     border-radius: 8px;
 }

 .schedule {
     width: 100%;
     border-collapse: collapse;
 }

 .schedule th,
 .schedule td {
     border: 1px solid #e0e0e0;
     padding: 12px;
 }

 .schedule th {
     background-color: #ffffff;
 }

 .img-custom-table {
     height: auto;
     object-fit: cover;
     cursor: pointer;
     transition: transform 0.2s ease, filter 0.2s ease;
 }

 .img-custom-table:hover {
     transform: scale(0.95);
     filter: brightness(1);
 }

 .date-calendar-table {
     font-size: 17px;
     font-weight: 800;
     color: #cc0000;
 }



 .time {
     /* background-color: #e6f3ff; */
     font-weight: bold;
 }

 .class {
     background-color: #fff;
     cursor: pointer;
     text-align: center;
 }

 .class:hover {
     background-color: #f9f9f9;
 }

 .popup {
     position: absolute;
     z-index: 1000;
     display: none;
     background: linear-gradient(135deg, #ffffff, #f8f9fa);
     border: 1px solid #d1d5db;
     box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
     max-width: 450px;
     border-radius: 12px;
     opacity: 0;
     transform: scale(0.8);
     transition: opacity 0.3s ease, transform 0.3s ease;
 }

 .popup.show {
     display: block;
     opacity: 1;
     transform: scale(1);
 }

 .workshop-card-custom {
     padding: 20px;
     font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
 }

 .workshop-card-custom .close-btn {
     position: absolute;
     top: 12px;
     right: 12px;
     width: 32px;
     height: 32px;
     background-color: #f1f3f5;
     border-radius: 50%;
     display: flex;
     align-items: center;
     justify-content: center;
     color: #6b7280;
     transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
 }

 .workshop-card-custom .close-btn:hover {
     background-color: #e5e7eb;
     color: #374151;
     transform: scale(1.1);
 }

 .workshop-card-custom .close-btn:active {
     transform: scale(0.95);
 }

 .poster-placeholder img {
     /* width: 120px; */
     height: auto;
     border-radius: 8px;
     box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
 }

 .workshop-card-custom h4 {
     font-size: 1.25rem;
     font-weight: 700;
     color: #1f2937;
     margin-bottom: 8px;
 }

 .workshop-card-custom p {
     color: #4b5563;
     margin-bottom: 6px;
 }

 .max-w-3xl {
     max-width: 56rem !important;
 }

 .fa.fa-dot-circle {
     font-size: 15px;
     opacity: 0.7;
 }

 span.group1 {
     background-color: #fff;
     height: 25px;
     width: 32px;
     vertical-align: bottom;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #cc0000;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 span.group2 {
     background-color: #fff;
     height: 25px;
     width: 32px;
     vertical-align: bottom;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #059669;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 span.group3 {
     background-color: #fff;
     height: 25px;
     width: 32px;
     vertical-align: bottom;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #1e3a8a;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .event-icon-cover-common-users {
     background-color: #fff;
     height: 25px;
     width: 32px;
     vertical-align: bottom;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #cc0000;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .event-icon-cover-individual {
     background-color: #fff;
     height: 25px;
     width: 32px;
     vertical-align: bottom;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #1e3a8a;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .event-icon-cover-b2b {
     background-color: #fff;
     height: 25px;
     width: 32px;
     vertical-align: bottom;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #059669;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .event-icon-all {
     margin-right: 2px;
     margin-bottom: 4px;
     margin-left: 2px;
     vertical-align: middle;
     text-align: center;
     font-size: 11px;
     border: 2px solid #fff;
     color: #ffffff;
     background-color: #737680;
     width: 27px;
     height: 27px;
     border-radius: 19px;
     line-height: 24px;
     /* box-shadow: 0 4px 12px rgba(115, 118, 128, 0.3); */
 }

 .read-more-btn-custom {
     background-color: #E31837;
     color: white;
     padding: 10px 25px;
     border: none;
     border-radius: 25px;
     font-size: 14px;
     font-weight: 600;
     text-decoration: none;
     display: inline-block;
     transition: background-color 0.3s ease;
 }

 .font-14pt {
     font-size: 14px;
 }

 .workshop-card-custom .description {
     font-size: 0.875rem;
     line-height: 1.5;
     color: #6b7280;
     max-height: 7.7rem;
     overflow: hidden;
     transition: max-height 0.3s ease;
 }

 .workshop-card-custom .description.expanded {
     max-height: none;
 }

 .workshop-card-custom .show-all-btn {
     display: inline-block;
     padding: 8px 16px;
     background-color: #2563eb;
     color: white;
     border-radius: 6px;
     font-size: 0.875rem;
     font-weight: 500;
     text-transform: uppercase;
     transition: background-color 0.2s ease, transform 0.2s ease;
 }

 .workshop-card-custom .show-all-btn:hover {
     background-color: #1d4ed8;
     transform: translateY(-1px);
 }

 .workshop-card-custom .show-all-btn:active {
     transform: translateY(0);
 }


 .ticket {
     padding: 20px;
     text-align: center;
 }

 .ticket h2 {
     margin: 0;
     font-size: 24px;
 }

 .ticket p {
     margin: 5px 0;
     font-size: 16px;
 }

 .flex.gap-4 {
     flex-wrap: wrap;
 }

 .qr-code-details-event {
     width: 150px;
     height: 150px;
     /* background-color: #f0f0f0; */
     margin: 20px auto;
 }

 .bage-tab {
     background: #737680;
     color: #fff;
     padding: 2px 15px;
     border-radius: 20px;
     font-size: 12px;
     font-weight: 600;
 }

 .text-slots {
     color: #65cf24 !important;
 }

 .bg-bage-client {
     background-color: #cc0000;
 }

 .bg-bage-event {
     background-color: #f39c12;
 }

 .bg-bage-slots {
     background-color: #27ae60;
 }

 .form-select-workshop {
     padding: 12px 16px;
     border: 1px solid #e5e5e5;
     border-radius: 8px;
     background-color: #ffffff;
     color: #737680;
     font-size: 16px;
     transition: border-color 0.3s ease, box-shadow 0.3s ease;
     width: 100%;
     box-sizing: border-box;
     -webkit-appearance: none;
     -moz-appearance: none;
     appearance: none;
     background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"><path fill="%23737680" d="M6 9l4-5H2z"/></svg>');
     background-repeat: no-repeat;
     background-position: right 16px center;
     background-size: 12px;
 }

 .form-select-workshop:focus {
     outline: none;
     border-color: #3b82f6;
     box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
 }

 .form-group {
     margin-bottom: 1.5rem;
 }

 .form-group label {
     display: block;
     font-size: 14px;
     font-weight: 500;
     margin-bottom: 8px;
     color: #333;
 }

 .dimmed {
     opacity: 0.5;
     background-color: #f5f5f5;
     cursor: not-allowed;
 }

 .datetime-container {
     position: relative;
     /* max-width: 500px; */
     /* margin: 50px auto; */
 }

 .input-wrapper {
     position: relative;
 }

 .form-input-workshop {
     width: 100%;
     padding: 15px 50px 15px 20px;
     border: 2px solid var(--color-gray);
     border-radius: 10px;
     font-size: 16px;
     transition: all 0.3s ease;
     background-color: var(--color-white);
     color: var(--color-gray);
     outline: none;
 }

 .form-input-workshop:focus {
     border-color: var(--color-red);
     box-shadow: 0 0 0 4px rgba(204, 0, 0, 0.1);
 }

 .calendar-icon {
     position: absolute;
     right: 10px;
     top: 26px;
     transform: translateY(-50%);
     color: var(--color-gray);
     cursor: pointer;
     font-size: 20px;
     transition: all 0.3s ease;
     padding: 8px;
 }

 .calendar-icon:hover {
     color: var(--color-red);
     transform: translateY(-50%) scale(1.1);
 }

 .datetime-picker {
     position: absolute;
     top: calc(100% + 8px);
     left: 0;
     right: 0;
     background: var(--color-white);
     border: 2px solid var(--color-red);
     border-radius: 12px;
     box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
     z-index: 1000;
     padding: 15px;
     display: none;
 }

 .picker-header {
     text-align: center;
     margin-bottom: 20px;
     color: var(--color-red);
     font-weight: 600;
     font-size: 18px;
 }

 .picker-row {
     display: flex;
     gap: 17px;
     margin-bottom: 20px;
 }

 .picker-group {
     flex: 1;
 }

 .picker-label {
     font-size: 14px;
     color: var(--color-gray);
     margin-bottom: 8px;
     font-weight: 600;
 }

 .picker-select {
     width: 100%;
     padding: 12px 16px;
     border: 2px solid var(--color-gray);
     border-radius: 8px;
     background-color: var(--color-white);
     color: var(--color-gray);
     font-size: 16px;
     cursor: pointer;
     transition: all 0.3s ease;
     outline: none;
 }

 .picker-select:focus {
     border-color: var(--color-red);
     box-shadow: 0 0 0 3px rgba(204, 0, 0, 0.1);
 }

 .picker-buttons {
     display: flex;
     gap: 12px;
     justify-content: center;
     margin-top: 20px;
 }

 .btn-cancel,
 .btn-confirm {
     width: 50% !important;
 }

 .btn-custom {
     padding: 12px 20px;
     border: none;
     border-radius: 8px;
     font-size: 16px;
     font-weight: 600;
     cursor: pointer;
     transition: all 0.3s ease;
     min-width: 100px;
 }

 .btn-confirm {
     background-color: var(--color-red);
     color: var(--color-white);
 }

 .btn-confirm:hover {
     background-color: #aa0000;
     transform: translateY(-2px);
     box-shadow: 0 4px 12px rgba(204, 0, 0, 0.3);
 }

 .btn-cancel {
     background-color: var(--color-gray);
     color: var(--color-white);
 }

 .btn-cancel:hover {
     background-color: #5a5a66;
     transform: translateY(-2px);
     box-shadow: 0 4px 12px rgba(115, 118, 128, 0.3);
 }

 .datetime-picker.show {
     display: block;
     animation: slideDown 0.4s cubic-bezier(0.4, 0, 0.2, 1);
 }

 .mr-0 {
     margin-right: 0 !important;
 }

 @keyframes slideDown {
     from {
         opacity: 0;
         transform: translateY(-15px);
     }

     to {
         opacity: 1;
         transform: translateY(0);
     }
 }

 /* chinh sach bao mat modal */
 .modal-premium {
     background-color: rgba(0, 0, 0, 0.7);
     backdrop-filter: blur(3px);
     z-index: 50;
 }

 /* Terms modal - higher z-index */
 .modal-terms {
     background-color: rgba(0, 0, 0, 0.8);
     backdrop-filter: blur(5px);
     z-index: 9999 !important;
 }

 .modal-content-premium {
     background: var(--color-white);
     border-radius: 12px;
     box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
 }

 .modal-content-terms {
     background: var(--color-white);
     border-radius: 12px;
     box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
     max-width: 900px;
     margin: 2rem auto;
     position: relative;
     z-index: 10000;
 }

 .color-text-modal-event {
     color: var(--color-gray);
 }

 .color-text-red-modal-event {
     color: var(--color-red);
 }

 .bg-f8 {
     background-color: var(--light-gray);
 }

 .fw-bold {
     font-weight: bold;
 }

 .font-16pt {
     font-size: 16px;
 }

 .border-custom-info-event {
     border: 1px solid var(--border-color);
 }

 .form-input-workshop:focus,
 .form-select-workshop:focus {
     border-color: var(--color-red);
     outline: none;
     box-shadow: 0 0 0 2px rgba(204, 0, 0, 0.1);
 }

 .modal-terms {
     display: none;
 }

 .modal-terms.flex {
     display: flex;
 }

 .modal-terms.hidden {
     display: none;
 }

 .checkbox-item {
     display: flex;
     align-items: flex-start;
     margin-bottom: 20px;
     gap: 12px;
 }

 .carousel-item {
     height: 80vh;
 }

 .checkbox-item input[type="checkbox"] {
     margin-top: 3px;
     width: 23px;
     height: 23px;
     accent-color: var(--color-red);
 }

 .checkbox-item .text {
     color: var(--color-gray);
     font-size: 16px;
     line-height: 1.5;
 }

 .terms-link {
     color: var(--color-red) !important;
     font-weight: 500;
     cursor: pointer;
     text-decoration: underline;
 }

 .terms-link:hover {
     color: #aa0000 !important;
 }

 .btn-workshop-outline {
     background: transparent;
     border: 2px solid var(--color-gray);
     color: var(--color-gray);
     border-radius: 8px;
     font-weight: 500;
     transition: all 0.3s ease;
 }

 .btn-workshop-outline:hover {
     background: var(--color-gray);
     color: var(--color-white);
 }

 .btn-workshop-primary {
     background: var(--color-red);
     border: 2px solid var(--color-red);
     color: var(--color-white);
     border-radius: 8px;
     font-weight: 500;
     transition: all 0.3s ease;
 }

 .btn-workshop-primary:hover {
     background: #aa0000;
     border-color: #aa0000;
 }

 /* Terms modal specific styles */
 .terms-header {
     background: linear-gradient(135deg, var(--color-red), #aa0000);
     color: var(--color-white);
     padding: 1.5rem 2rem;
     border-radius: 12px 12px 0 0;
     position: relative;
 }

 .terms-header h2 {
     margin: 0;
     font-size: 1.5rem;
     font-weight: 600;
 }

 .terms-close-btn {
     position: absolute;
     top: 1.5rem;
     right: 2rem;
     background: none;
     border: none;
     color: var(--color-white);
     font-size: 1.5rem;
     cursor: pointer;
     transition: opacity 0.3s ease;
 }

 .terms-close-btn:hover {
     opacity: 0.7;
 }

 .terms-body {
     padding: 2rem;
     max-height: 70vh;
     overflow-y: auto;
 }

 .terms-body::-webkit-scrollbar {
     width: 8px;
 }

 .terms-body::-webkit-scrollbar-track {
     background: var(--light-gray);
     border-radius: 4px;
 }

 .terms-body::-webkit-scrollbar-thumb {
     background: var(--color-gray);
     border-radius: 4px;
 }

 .terms-body::-webkit-scrollbar-thumb:hover {
     background: var(--color-red);
 }

 .terms-section {
     margin-bottom: 2rem;
 }

 .terms-section h3 {
     color: var(--color-red);
     font-size: 1.2rem;
     font-weight: 600;
     margin-bottom: 1rem;
     border-bottom: 2px solid var(--color-red);
     padding-bottom: 0.5rem;
 }

 .terms-section h4 {
     color: var(--color-gray);
     font-size: 1.1rem;
     font-weight: 600;
     margin: 1.5rem 0 0.8rem 0;
 }

 .terms-section p {
     color: var(--color-gray);
     line-height: 1.6;
     margin-bottom: 1rem;
     text-align: justify;
 }

 .terms-section ul {
     margin: 1rem 0;
     padding-left: 1.5rem;
 }

 .terms-section li {
     color: var(--color-gray);
     line-height: 1.6;
     margin-bottom: 0.5rem;
 }

 .highlight-box {
     background: var(--light-gray);
     border-left: 4px solid var(--color-red);
     padding: 1rem 1.5rem;
     margin: 1.5rem 0;
     border-radius: 0 8px 8px 0;
 }

 .highlight-box p {
     margin: 0;
     font-weight: 500;
 }

 .terms-footer {
     background: var(--light-gray);
     padding: 1.5rem 2rem;
     border-radius: 0 0 12px 12px;
     text-align: center;
 }

 .btn-terms-close {
     background: var(--color-red);
     border: none;
     color: var(--color-white);
     padding: 0.75rem 2rem;
     border-radius: 8px;
     font-weight: 500;
     transition: all 0.3s ease;
     cursor: pointer;
 }

 .btn-terms-close:hover {
     background: #aa0000;
     transform: translateY(-1px);
 }

 /* Demo button styles */
 .demo-section {
     background: linear-gradient(135deg, #f0f9ff, #e0f2fe);
     min-height: 100vh;
     display: flex;
     align-items: center;
     justify-content: center;
     flex-direction: column;
     gap: 2rem;
     padding: 2rem;
 }

 .demo-card {
     background: white;
     padding: 3rem;
     border-radius: 16px;
     box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
     text-align: center;
     max-width: 600px;
 }

 .demo-btn {
     background: linear-gradient(135deg, var(--color-red), #aa0000);
     color: white;
     padding: 1rem 2rem;
     border: none;
     border-radius: 12px;
     font-size: 1.1rem;
     font-weight: 600;
     cursor: pointer;
     transition: all 0.3s ease;
     box-shadow: 0 4px 15px rgba(204, 0, 0, 0.3);
 }

 .demo-btn:hover {
     transform: translateY(-2px);
     box-shadow: 0 6px 20px rgba(204, 0, 0, 0.4);
 }

 /* Responsive */

 .feedback-message {
     margin-top: 10px;
     font-size: 15px;
 }

 .input-group.serial-input {
     position: relative;
 }

 .form-input-workshop {
     font-size: 16px;
     padding-right: 50px;
     /* Space for icon */
 }

 .search-icon {
     position: absolute;
     right: 10px;
     top: 50%;
     transform: translateY(-50%);
     cursor: pointer;
     font-size: 20px;
     color: #6c757d;
     z-index: 10;
 }

 .search-icon:hover {
     color: #cc0000;
 }

 .color-text-modal-event {
     color: #333;
     font-weight: 500;
 }

 .font-16pt {
     font-size: 16px;
 }

 .feedback-message {
     margin-top: 10px;
     font-size: 14px;
 }

 .icon-event-users {
     height: 1.8rem;
     display: flex;
     align-items: center;
     gap: 3px;
     margin-bottom: 3px;
     padding: 1px 13px;
     background: #cc0000;
     border-radius: 40px;
     color: #ffffff;
     text-align: center;
     font-size: 12px;
 }

 .icon-event-individual {
     height: 1.8rem;
     display: flex;
     align-items: center;
     gap: 3px;
     padding: 1px 13px;
     background: #1e3a8a;
     border-radius: 40px;
     color: #ffffff;
     text-align: center;
     font-size: 12px;
 }

 .icon-event-business {
     height: 1.8rem;
     display: flex;
     align-items: center;
     gap: 3px;
     margin-bottom: 3px;
     padding: 1px 13px;
     background: #059669;
     border-radius: 40px;
     color: #ffffff;
     text-align: center;
     font-size: 12px;
 }

 .bg-bage-user {
     background: #1e3a8a !important;
 }

 .bg-bage-b2b {
     background: #059669 !important;
 }

 .card-cb {
     border: none;
     border-radius: 8px;
     background: #ffffff;
     box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08);
     overflow: hidden;
     transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
     height: 100%;
     position: relative;
 }

 .card-cb::before {
     content: '';
     position: absolute;
     top: 0;
     left: 0;
     right: 0;
     height: 4px;
     transition: all 0.3s ease;
 }

 .card-img-top {
     height: 240px;
     object-fit: fill;
     transition: transform 0.4s ease;
 }

 .card-body {
     padding: 25px;
     display: flex;
     flex-direction: column;
     height: calc(100% - 240px);
 }

 .custom-middle-body {
     flex-grow: 1;
     margin-bottom: 20px;
 }

 .card-title-space {
     transition: color 0.3s ease;
 }

 .card-title-space a {
     text-decoration: none;
     color: inherit;
 }

 .card-text {
     color: #6c757d;
     font-size: 0.95rem;
     margin-bottom: 0;
 }

 .row.g-4 .card-body .d-flex a:hover {
     color: #ffffff !important;
 }

 /* Card 1 - Trải nghiệm LIVESTREAM - Màu đỏ năng động */
 /* .card-livestream::before {
     background: linear-gradient(90deg, #cc0000, #ff4444);
 } */
 .card-livestream {
     border-left: 6px solid #cc0000;
     /* background: linear-gradient(90deg, #cc0000, #ff4444); */
 }

 .card-cb.group1 {
     border-left: 6px solid #cc0000;
 }

 .card-cb.group1:hover {
     transform: translateY(-8px);
     box-shadow: 0 20px 40px rgba(204, 0, 0, 0.2);
 }

 .card-livestream {
     border-left: 6px solid #cc0000;
     /* background: linear-gradient(90deg, #cc0000, #ff4444); */
 }

 .card-livestream a:hover {
     color: #cc0000 !important;
 }

 .card-livestream:hover {
     transform: translateY(-8px);
     box-shadow: 0 20px 40px rgba(204, 0, 0, 0.2);
 }

 .card-livestream:hover::before {
     height: 6px;
     background: linear-gradient(90deg, #cc0000, #ff6600);
 }

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

 .card-livestream .card-title-space i.fa {
     color: #cc0000;
 }

 .card-livestream:hover .card-title-space i.fa {
     color: #ff4444;
 }


 /* Card 2 - Studio chuyên nghiệp - Màu xanh dương chuyên nghiệp */
 /* .card-studio::before {
     background: linear-gradient(90deg, #1e3a8a, #3b82f6);
 } */
 .card-studio {
     border-left: 6px solid #1e3a8a;
 }

 .card-cb.group3 {
     border-left: 6px solid #1e3a8a;
 }

 .card-cb.group3:hover {
     transform: translateY(-8px);
     box-shadow: 0 20px 40px rgba(30, 58, 138, 0.2);
 }

 .card-studio:hover {
     transform: translateY(-8px);
     box-shadow: 0 20px 40px rgba(30, 58, 138, 0.2);
 }

 .card-studio:hover::before {
     height: 6px;
     background: linear-gradient(90deg, #1e3a8a, #60a5fa);
 }

 .card-studio a:hover {
     color: #cc0000 !important;
 }

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

 .card-studio .card-title-space i.fa {
     color: #1e3a8a;
 }

 .card-studio:hover .card-title-space i.fa {
     color: #3b82f6;
 }

 /* Card 3 - Workshop chuyên đề - Màu xanh lá kết nối */
 /* .card-workshop::before {
     background: linear-gradient(90deg, #059669, #10b981);
 } */
 .card-workshop {
     border-left: 6px solid #059669;
 }

 .card-cb.group2 {
     border-left: 6px solid #059669;
 }

 .card-cb.group2:hover {
     transform: translateY(-8px);
     box-shadow: 0 20px 40px rgba(5, 150, 105, 0.2);
 }

 .card-workshop:hover {
     transform: translateY(-8px);
     box-shadow: 0 20px 40px rgba(5, 150, 105, 0.2);
 }

 .card-workshop a:hover {
     color: #cc0000 !important;
 }

 .card-title-space i.fa {
     font-size: 13px;
 }

 .card-workshop:hover::before {
     height: 6px;
     background: linear-gradient(90deg, #059669, #34d399);
 }

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

 .card-workshop .card-title-space i.fa {
     color: #059669;
 }

 .card-workshop:hover .card-title-space i.fa {
     color: #10b981;
 }

 /* Responsive */

 /* Loading animation */
 @keyframes fadeInUp {
     from {
         opacity: 0;
         transform: translateY(30px);
     }

     to {
         opacity: 1;
         transform: translateY(0);
     }
 }

 .card {
     animation: fadeInUp 0.6s ease-out;
 }

 .card:nth-child(1) {
     animation-delay: 0.1s;
 }

 .card:nth-child(2) {
     animation-delay: 0.2s;
 }

 .card:nth-child(3) {
     animation-delay: 0.3s;
 }

 .w-serial {
     width: 230px;
 }

 .select2-selection__rendered {
     padding: 10px 16px !important;
 }

 .select2-container .select2-selection--single {
     height: unset !important;
 }

 .select2-container--default .select2-selection--single {
     border: 2px solid #e5e5e5 !important;
     border-radius: 8px !important;
 }

 .select2-container .select2-selection--single:after {
     content: "\f078";
     display: inline-block;
     opacity: 0.5;
     font: normal normal normal 14px / 1 FontAwesome;
     font-size: inherit;
     text-rendering: auto;
     -webkit-font-smoothing: antialiased;
     -moz-osx-font-smoothing: grayscale;
     position: absolute;
     top: 16px;
     right: 13px;
 }

 .select2-dropdown {
     border: 2px solid #e5e5e5 !important;
 }

 .select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
     background-color: #cc0000d5 !important;
 }

 .select2-selection__arrow {
     display: none;
 }

 .select2-results__option {
     padding: 6px 7px 10px 14px !important;
 }

 .select2-container--default .select2-selection--single .select2-selection__rendered {
     color: #737680 !important;
 }

 .max-w-2xl {
     max-width: 51rem !important;
 }

 .left-all-show {
     background: #fff;
     border-radius: 8px;
     margin-bottom: 20px;
     border: solid 1px #efefef;
     padding: 15px 20px;
     font-size: 14px;
     box-shadow: rgba(147, 147, 147, .1) 0 1px 15px 1px
 }

 .custom-checkbox {
     display: flex;
     padding: 10px;
     border-radius: 5px;
     transition: all 0.3s ease;
 }

 .custom-checkbox input[type="checkbox"] {
     display: none;
 }

 .custom-checkbox label {
     position: relative;
     padding-left: 30px;
     cursor: pointer;
     font-size: 16px;
     font-weight: 600;
     color: #333;
 }

 .custom-checkbox label:before {
     content: '';
     position: absolute;
     left: 0;
     top: 50%;
     transform: translateY(-50%);
     width: 20px;
     height: 20px;
     border: 2px solid #cc0000;
     border-radius: 4px;
     background-color: #fff;
 }

 .custom-checkbox input[type="checkbox"]:checked+label:after {
     content: '\2713';
     position: absolute;
     left: 6px;
     top: 50%;
     transform: translateY(-50%);
     font-size: 14px;
     color: #fff;
 }

 .checkbox-content {
     display: inline-block;
     border-radius: 3px;
     font-size: 16px;
     transition: all 0.3s ease;
 }

 .custom-checkbox input[type="checkbox"]:checked+label:before {
     background-color: #cc0000;
 }

 .d-none {
     display: none !important;
 }

 .schedule td.class {
     vertical-align: middle;
 }

 .schedule td {
     background-color: #fff !important;
 }

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

 .product-icon {
     color: #cc0000;
     animation: pulse-dot 2s infinite;
 }


 .event-card {
     transition: all 0.3s ease;
 }

 .event-card:hover {
     transform: translateY(-2px);
     box-shadow: 0 10px 25px rgba(204, 0, 0, 0.1);
 }

 .event-card:hover .product-icon {
     transform: scale(1.1);
 }

 .event-card:hover .work-shop-icon {
     transform: scale(1.1);
 }

 .gradient-border {
     background: linear-gradient(135deg, #cc0000 0%, #ff4444 100%);
     padding: 1px;
     border-radius: 12px;
 }

 .gradient-border-inner {
     background: white;
     border-radius: 11px;
 }

 .status-indicator {
     width: 8px;
     height: 8px;
     background: #cc0000;
     border-radius: 50%;
     animation: blink 1.5s infinite;
 }

 @keyframes blink {

     0%,
     50% {
         opacity: 1;
     }

     51%,
     100% {
         opacity: 0.3;
     }
 }

 .form-event {
     width: 12rem;
     box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
     border-radius: 10px;
     padding: 9px;
     background: #ffffff;
 }

 .time-slot.selected i {
     color: #fff !important;
 }

 .view-over-all {
     display: flex;
     justify-content: flex-end;
     margin-top: 5px;
     padding: 10px 0;
 }

 .view-detail {
     margin-left: auto;
     opacity: 0.8;
     display: flex;
     align-items: center;
     text-decoration: none;
     background: linear-gradient(90deg, #cc0000, #ff3333);
     -webkit-background-clip: text;
     -webkit-text-fill-color: transparent;
     font-size: 14px;
     font-weight: 600;
     position: relative;
     transition: transform 0.4s ease, opacity 0.4s ease;
 }

 .view-detail i {
     margin-top: 0px;
     margin-left: 10px;
     font-size: 15px;
     color: #cc0000;
     transition: transform 0.4s ease;
 }

 .view-detail:hover {
     transform: translateX(8px);
     opacity: 0.9;
 }

 .view-detail:hover i {
     transform: scale(1.2);
 }

 .view-detail::after {
     content: '';
     position: absolute;
     width: 0;
     height: 2px;
     bottom: -4px;
     left: 0;
     background: linear-gradient(90deg, #cc0000, #ff3333);
     transition: width 0.4s ease;
 }

 .view-detail:hover::after {
     width: 100%;
 }

 .form-input-workshop:valid {
     border-color: #28a745;
 }

 .form-input-workshop:invalid {
     border-color: #dc3545;
 }

 .form-input-workshop:invalid:focus {
     box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
 }

 .error-message {
     margin-top: 5px;
     font-size: 12px;
     color: #dc3545;
 }

 .time-slot.w-full.p-3.text-sm img {
     height: 18px;
     width: 50px !important;
     object-fit: cover;
 }

 /* .booked {
    padding: 1.5px !important;
}
.booked img {
    filter: invert(1);
} */
 .card-title-space {
     display: -webkit-box;
     -webkit-line-clamp: 2;
     -webkit-box-orient: vertical;
     overflow: hidden;
     height: 56px;
 }

 .border-radius-8px {
     border-radius: 8px !important;
 }

 .container.px-0 {
     padding-left: 0 !important;
     padding-right: 0 !important;
 }

 .select2-results__option {
     white-space: normal !important;
     word-wrap: break-word;
     max-width: 100%;
 }

 #su-kien .workshop-image {
     height: 13rem;
 }

 /* Sự kiện cb space  */
 .header {
     background: linear-gradient(135deg, #2c3e50 0%, #34495e 100%);
     color: white;
     padding: 20px;
     text-align: center;
 }

 .header h1 {
     margin: 0;
     font-size: 2rem;
     font-weight: 300;
     letter-spacing: 1px;
 }

 .schedule-wrapper {
     padding-top: 30px;
     overflow-x: auto;
 }

 .icon-main {
     width: 2.7rem;
     height: 2.7rem;
 }

 /* Desktop Layout */
 .desktop-schedule {
     /* display: block; */
     width: 100%;
 }

 .mobile-schedule {
     display: none;
 }

 .schedule-table {
     width: 100%;
     border-collapse: collapse;
     margin: 0 auto;
     border-radius: 10px;
     overflow: hidden;
     box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
 }

 .schedule-container-title h1 {
     height: 100;
     line-height: 4.5rem !important;
     margin-top: 10px;
 }

 .schedule-table th {
     /* background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); */
     color: rgb(0, 0, 0);
     padding: 15px 10px;
     text-align: center;
     font-weight: 600;
     font-size: 14px;
     text-transform: uppercase;
     letter-spacing: 0.5px;
     border: 1px solid rgb(231 231 231);
     position: relative;
 }

 .schedule-table th:first-child {
     /* background: linear-gradient(135deg, #4a90e2 0%, #357abd 100%); */
     width: 80px;
 }

 .schedule-table td {
     padding: 8px;
     text-align: center;
     max-width: 150px;
     border: 1px solid #e0e0e0;
     height: 96px;
     vertical-align: top;
     position: relative;
     background: #fafafa;
 }

 .event {
     background: #fff;
     border-radius: 8px;
     padding: 8px;
     margin: 2px 0;
     font-size: 11px;
     line-height: 1.3;
     cursor: pointer;
     transition: all 0.3s ease;
     border-left: 8px solid;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .event-mobile {
     background: #fff;
     border-radius: 8px;
     padding: 8px;
     margin: 2px 0;
     font-size: 11px;
     line-height: 1.3;
     cursor: pointer;
     transition: all 0.3s ease;
     border-left: 8px solid;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .event:hover {
     transform: translateY(-2px);
     box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
     z-index: 2;
 }

 .event-mobile:hover {
     transform: translateY(-2px);
     box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
     z-index: 2;
 }

 .event-mobile.group1 {
     width: 8rem;
     border-left-color: #cc0000;
     background: linear-gradient(135deg, #fff 0%, #ffe6e6 100%);
 }

 .event-mobile.group2 {
     width: 8rem;
     border-left-color: #1e3a8a;
     background: linear-gradient(135deg, #fff 0%, #e6f2ff 100%);
 }

 .event-mobile.group3 {
     width: 8rem;
     border-left-color: rgb(5, 150, 105);
     background: linear-gradient(135deg, #fff 0%, #e6f7f3 100%);
 }

 .event.group1 {
     width: 8rem;
     border-left-color: #cc0000;
     background: linear-gradient(135deg, #fff 0%, #ffe6e6 100%);
 }

 .event.group2 {
     width: 8rem;
     border-left-color: #1e3a8a;
     background: linear-gradient(135deg, #fff 0%, #e6f2ff 100%);
 }

 .event.group3 {
     width: 8rem;
     border-left-color: rgb(5, 150, 105);
     background: linear-gradient(135deg, #fff 0%, #e6f7f3 100%);
 }

 .event-title {
     font-weight: 600;
     margin-bottom: 4px;
     color: #333;
 }

 .event-time {
     font-size: 10px;
     color: #666;
     margin-bottom: 4px;
 }

 .event-icon {
     font-size: 8px;
     margin-right: 4px;
 }

 .group1 .event-icon {
     border: 2px solid #fff;
     color: #ffffff;
     background-color: #737680;
     width: 20px;
     height: 20px;
     border-radius: 12px;
     line-height: 17px;
     justify-content: center;
     box-shadow: 0 4px 12px rgba(115, 118, 128, 0.3);
     /* color: #cc0000; */
 }

 .group2 .event-icon {
     border: 2px solid #fff;
     color: #ffffff;
     background-color: #737680;
     width: 20px;
     height: 20px;
     border-radius: 12px;
     line-height: 17px;
     justify-content: center;
     box-shadow: 0 4px 12px rgba(115, 118, 128, 0.3);
     /* color: #1e3a8a; */
 }

 .group3 .event-icon {
     border: 2px solid #fff;
     color: #ffffff;
     background-color: #737680;
     width: 20px;
     height: 20px;
     border-radius: 12px;
     line-height: 17px;
     justify-content: center;
     box-shadow: 0 4px 12px rgba(115, 118, 128, 0.3);
     /* color: rgb(5, 150, 105); */
 }

 /* Popup Styles */
 .popup {
     position: fixed;
     background: white;
     border-radius: 12px;
     padding: 20px;
     box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
     z-index: 9999;
     max-width: 300px;
     min-width: 250px;
     opacity: 0;
     pointer-events: none;
     transform: scale(0.8);
     transition: all 0.3s ease;
     border: 1px solid #e0e0e0;
 }

 .popup.show {
     opacity: 1;
     pointer-events: auto;
     transform: scale(1);
 }

 .popup-image {
     width: 100%;
     height: 120px;
     object-fit: cover;
     border-radius: 8px;
     margin-bottom: 15px;
 }

 .popup-title {
     font-size: 16px;
     font-weight: 600;
     margin-bottom: 10px;
     color: #333;
 }

 .popup-time {
     font-size: 14px;
     color: #666;
     margin-bottom: 10px;
     display: flex;
     align-items: center;
 }

 .popup-time i {
     margin-right: 8px;
 }

 .popup-description {
     font-size: 13px;
     color: #555;
     line-height: 1.5;
 }

 /* Mobile Layout */

 /* .booked img {
     margin-right: 4px !important;
 } */

 #home .workshop-image {
     height: 15.5rem;
 }

 .card-premium {
     background: #fff;
     border-radius: 12px;
     box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
 }

 .btn-advanced {
     border-radius: 8px;
     transition: all 0.3s ease;
 }

 .btn-outline {
     border: 1px solid #e2e8f0;
     background: transparent;
     color: #4a5568;
 }

 /* .btn-outline:hover {
     background: #f7fafc;
     border-color: #cbd5e0;
 } */

 .py-custom-button {
     padding-top: 0.5rem;
     padding-bottom: 0.5rem;
 }

 .font-14pt {
     font-size: 14px;
 }

 .font-15pt {
     font-size: 15px;
 }

 .schedule-wrapper {
     background: #fff;
     border-radius: 12px;
     box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
     overflow: hidden;
 }


/* 
 .desktop-schedule {
     display: block;
 } */

 .mobile-schedule {
     display: none;
 }

 .schedule-container {
     display: none;
 }

 .schedule-container.active {
     display: block;
 }


 .customer-type-section {
     /* background: #f8f9fa; */
     padding: 25px;
     border-radius: 10px;
     margin: 25px 0;
 }

 .section-title {
     color: #333;
     font-weight: 600;
     margin-bottom: 20px;
     border-bottom: 2px solid #f0f0f0;
     padding-bottom: 10px;
     font-size: 1.5rem !important;
 }

 #type-guest {
     border: 1px solid #e7e7e74f;
     width: 13rem;
     /* border-left-color: #1e3a8a; */
     background: linear-gradient(135deg, #fff 0%, #e6f2ff 100%);
     border-radius: 8px;
     padding: 10px;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     /* border-left: 8px solid #1e3a8a; */
 }

 #type-guest i {
     /* border-left-color: #1e3a8a; */
     margin-bottom: 10px;
     border: 2px solid #fff;
     color: #ffffff;
     background-color: #737680;
     width: 35px;
     height: 35px;
     border-radius: 18px;
     line-height: 32px;
     justify-content: center;
     box-shadow: 0 4px 12px rgba(115, 118, 128, 0.3);
 }

 #type-b2b {
     border: 1px solid #e7e7e74f;
     width: 13rem;
     background: linear-gradient(135deg, #fff 0%, #e6f7f3 100%);
     border-radius: 8px;
     padding: 10px;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     /* border-left: 8px solid rgb(5, 150, 105); */
 }

 #type-b2b i {
     margin-bottom: 10px;
     border: 2px solid #fff;
     color: #ffffff;
     background-color: #737680;
     width: 35px;
     height: 35px;
     border-radius: 18px;
     line-height: 32px;
     justify-content: center;
     box-shadow: 0 4px 12px rgba(115, 118, 128, 0.3);
 }

 .form-submit-cbs-modal:hover {
     background: var(--color-red-light) !important;
     border: 2px solid rgba(204, 0, 0, 0.2) !important;
     box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px !important;
 }

 .title-cbs-submit {
     color: var(--color-gray-dark) !important;
     font-weight: 600;
 }

 .form-submit-cbs-modal.active {
     background: var(--color-red-light) !important;
     border: 2px solid rgba(204, 0, 0, 0.2) !important;
     box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px !important;
 }

 .color-contact {
     color: #6c757d;
 }

 .info-icon {
     width: 60px;
     height: 60px;
     background: linear-gradient(135deg, var(--primary-red) 0%, #d63031 100%);
     border-radius: 50%;
     display: flex;
     align-items: center;
     justify-content: center;
     margin-right: 20px;
     font-size: 1.5rem;
     color: var(--white);
     flex-shrink: 0;
     box-shadow: 0 5px 15px rgba(204, 0, 0, 0.3);
 }

 .info-row {
     padding: 25px 30px;
     border-bottom: 1px solid #f1f3f4;
     display: flex;
     align-items: center;
     transition: all 0.3s ease;
     position: relative;
 }

 .info-text {
     font-size: 1.2rem;
     color: #2d3748;
     font-weight: 500;
     line-height: 1.4;
 }

 #clearAllNew {
     display: none !important;
 }

 .select2-error-msg {
     color: #ef4444;
     font-size: 14px;
     margin-top: 4px;
     margin-bottom: 8px;
     display: block;
     width: 100%;
 }

 .cc-link {
     display: none !important;
 }

 .cc-link-custom {
     opacity: .8;
     display: inline-block;
     padding: .2em;
     text-decoration: underline;
     color: rgb(255, 255, 255);
 }

 .cc-link-custom a {
     text-decoration: inherit !important;
 }

 .cc-message {
     text-align: justify;
 }


 .cc-type-opt-in.cc-theme-classic {
     padding: 32px !important;
     border-radius: 8px !important;
     background-color: #252627 !important;
     max-height: 90% !important;
     overflow-x: hidden !important;
     overflow-y: auto;
     flex-direction: column !important;
     width: 32.41rem !important;
     box-shadow: 0 0 18px rgba(0, 0, 0, .2) !important;
     left: 10px !important;
     bottom: 10px !important;
 }

 .cc-banner .cc-message {
     margin-right: 0 !important;
     text-align: left;
     line-height: 20px;
 }

 .cc-compliance.cc-highlight {
     position: relative;
 }

 .cc-window {
     left: 10px;
 }

 .cc-compliance.cc-highlight a {
     text-decoration: unset !important;
 }

 .cc-btn {
     font-weight: 500 !important;
 }

 .cc-theme-classic .cc-btn:last-child {
     min-width: 49% !important;
 }

 .cc-theme-classic .cc-btn:last-child:hover {
     background-color: rgb(144, 196, 249) !important;
 }

 .cc-highlight {
     /* display: unset !important; */
     margin-top: 1.5rem;
     width: 100% !important;
 }

 .cc-highlight .cc-btn:first-child {
     min-width: 49% !important;
     color: rgb(37, 38, 39) !important;
     border-color: transparent;
     background-color: rgb(144, 196, 249) !important;
 }

 .cc-btn.cc-deny {
     width: 50% !important;
     color: rgb(37, 38, 39);
     border-color: transparent;
     background-color: rgb(144, 196, 249) !important;
 }

 /* .cc-allow {
     width: 50% !important;
     display: none !important;
 } */

 /* .cc-deny {
     right: -20px;
     position: absolute;
     font-weight: 900;
     color: #7e7e7e !important;
     top: -27px;
     line-height: 16px;
     height: 20px;
     width: 20px !important;
     border-color: transparent !important;
     background-color: rgb(255 255 255) !important;
 } */
 .cc-banner.cc-bottom {
     /* background-color: #fff !important; */
     box-shadow: 0 10px 24px 7px rgba(0, 0, 0, .11);
     flex-direction: column !important;
     left: 16px !important;
     bottom: 16px !important;
 }

 .color-privacy {
     color: #bbafaf !important;
 }

 .cc-animate {
     display: none !important;
 }

 .date-icon {
     position: absolute;
     top: 24px;
     right: 7px;
     opacity: 0.8;
     color: #cc0000;
     font-size: 18px;
 }

 #nhom-su-kien .workshop-card img {
     height: 16.4rem;
 }

 .w-mobile {
     width: 50%;
 }

 .event-group1 {
     align-items: center;
     background-color: #fff;
     height: 37px;
     justify-content: center;
     width: 48px;
     display: flex;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #cc0000;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .event-group2 {
     align-items: center;
     background-color: #fff;
     height: 37px;
     justify-content: center;
     width: 48px;
     display: flex;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #059669;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .event-group3 {
     align-items: center;
     background-color: #fff;
     height: 37px;
     justify-content: center;
     width: 48px;
     display: flex;
     border-radius: 8px;
     padding: 2px;
     margin: 2px 0;
     border-left: 6px solid #1e3a8a;
     box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
     position: relative;
     z-index: 1;
 }

 .mt-1-custom {
     margin-top: 0.1rem;
 }

 .cc-message a {
     text-decoration: unset !important;
 }

 .cc-window.cc-banner {
     width: 32.41rem !important;
     border-radius: 8px;
 }