/* ==========================================================================
   Tsalanang Tours Child Theme – Mobile-First Custom Styles
   ========================================================================== */

:root {
    --tst-green: #4CAF50;
    --tst-green-dark: #388E3C;
    --tst-orange: #E8A030;
    --tst-orange-dark: #C7882A;
    --tst-dark: #1a1a2e;
    --tst-gray-900: #212121;
    --tst-gray-700: #616161;
    --tst-gray-500: #9e9e9e;
    --tst-gray-300: #e0e0e0;
    --tst-gray-100: #f5f5f5;
    --tst-white: #ffffff;
    --tst-radius: 12px;
    --tst-radius-sm: 8px;
    --tst-shadow: 0 2px 12px rgba(0,0,0,0.08);
    --tst-shadow-lg: 0 8px 32px rgba(0,0,0,0.12);
    --tst-transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Typography */
body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--tst-gray-700);
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Poppins', sans-serif;
    color: var(--tst-gray-900);
    font-weight: 700;
}

.tst-container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1rem;
}

@media (min-width: 768px) {
    .tst-container { padding: 0 2rem; }
}

/* ==========================================================================
   BRANDED HEADER (Custom — replaces GP default header)
   ========================================================================== */

/* Hide GP's default header content (we replace it fully) */
.site-header .inside-header > .site-branding,
.site-header .inside-header > .header-widget,
.site-header .inside-header > .site-logo,
#site-navigation,
nav.main-navigation,
.navigation-search {
    display: none !important;
}

/* Force dark background on ALL header elements GP generates */
.site-header,
.site-header[style],
header.site-header,
header.site-header[style],
header#masthead,
header#masthead[style],
.site-header .inside-header,
.site-header .inside-header[style] {
    background: var(--tst-dark) !important;
    background-color: var(--tst-dark) !important;
    background-image: none !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
    box-shadow: none !important;
    transition: background 0.3s ease !important;
    padding: 0 !important;
    border: none !important;
    border-bottom: none !important;
}

/* Double-enforce on single tour pages */
.single-tst_tour .site-header,
.single-tst_tour .site-header[style],
.single-tst_tour header.site-header,
.single-tst_tour .site-header .inside-header,
.single-tst_tour .site-header .inside-header[style] {
    background: var(--tst-dark) !important;
    background-color: var(--tst-dark) !important;
    background-image: none !important;
}

/* Front page: transparent header over hero, dark on scroll */
.tst-front-page .site-header,
.tst-front-page header.site-header {
    position: fixed !important;
    width: 100% !important;
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
}

.tst-front-page .site-header.tst-header-scrolled,
.tst-front-page header.site-header.tst-header-scrolled {
    background: #2b2a2f !important;
    background-color: #2b2a2f !important;
    box-shadow: 0 1px 0 rgba(255,255,255,0.06) !important;
}

.site-header.tst-header-scrolled {
    box-shadow: 0 1px 0 rgba(255,255,255,0.06) !important;
}

/* Strip all GP inner container styles */
.site-header .inside-header,
.site-header .inside-header[style],
header.site-header .inside-header,
header.site-header .inside-header[style] {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    display: block !important;
}

/* Our custom header container */
.tst-header {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 1rem;
}

/* Force white text on ALL header links — beats GP Customizer overrides */
.site-header a,
.site-header .inside-header a,
header.site-header a,
.tst-header a,
.tst-header a:link,
.tst-header a:visited {
    color: rgba(255,255,255,0.85) !important;
    text-decoration: none !important;
}

.site-header a:hover,
.tst-header a:hover {
    color: #fff !important;
}

/* Ensure all SVG icons in header are white */
.tst-header svg,
.tst-header__cart-btn svg {
    color: #fff !important;
    stroke: currentColor;
}

.tst-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0;
    min-height: 70px;
    gap: 2rem;
}

/* Brand / Logo */
.tst-header__brand {
    flex-shrink: 0;
}

.tst-header__logo-link {
    display: flex;
    align-items: center;
    text-decoration: none;
}

.tst-header__logo-img {
    max-height: 42px;
    width: auto;
    filter: brightness(0) invert(1);
}

.tst-header__site-name {
    color: #fff !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 800 !important;
    font-size: 1.3rem !important;
    letter-spacing: -0.02em;
    white-space: nowrap;
}

.tst-header__logo-link,
.tst-header__logo-link:link,
.tst-header__logo-link:visited,
.tst-header__logo-link:hover {
    color: #fff !important;
    text-decoration: none !important;
}

/* Desktop Navigation */
.tst-header__nav {
    flex: 1;
    display: flex;
    justify-content: center;
}

.tst-header__menu {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 0.25rem;
}

.tst-header__menu > li > a,
.tst-header__menu > li > a:link,
.tst-header__menu > li > a:visited {
    display: block;
    color: rgba(255,255,255,0.85) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 500;
    font-size: 0.85rem;
    padding: 0.5rem 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-decoration: none !important;
    transition: color 0.25s ease, background 0.25s ease;
    border-radius: 6px;
    white-space: nowrap;
}

.tst-header__menu > li > a:hover,
.tst-header__menu > li.current-menu-item > a,
.tst-header__menu > li.current_page_item > a {
    color: #fff !important;
    background: rgba(76,175,80,0.3) !important;
}

/* Submenu dropdown */
.tst-header__menu > li {
    position: relative;
}

.tst-header__menu > li > .sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.12);
    border: 1px solid rgba(0,0,0,0.06);
    min-width: 200px;
    padding: 0.5rem 0;
    z-index: 100;
    list-style: none;
    margin: 0;
}

.tst-header__menu > li:hover > .sub-menu {
    display: block;
}

.tst-header__menu > li > .sub-menu a {
    display: block;
    color: var(--tst-gray-900);
    font-size: 0.85rem;
    padding: 0.6rem 1.25rem;
    text-decoration: none;
    transition: color 0.2s, background 0.2s;
}

.tst-header__menu > li > .sub-menu a:hover {
    color: var(--tst-green);
    background: rgba(76,175,80,0.06);
}

/* Header right actions (cart + hamburger) */
.tst-header__actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 0;
}

/* Cart icon button */
.tst-header__cart-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: none;
    background: rgba(255,255,255,0.08);
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    transition: background 0.25s ease, transform 0.25s ease;
}

.tst-header__cart-btn:hover {
    background: rgba(255,255,255,0.15);
    transform: scale(1.05);
}

.tst-header__cart-count {
    position: absolute;
    top: -2px;
    right: -2px;
    min-width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--tst-green);
    color: #fff;
    border-radius: 10px;
    font-size: 0.7rem;
    font-weight: 700;
    padding: 0 5px;
    line-height: 1;
    animation: tst-badge-pop 0.3s ease;
}

@keyframes tst-badge-pop {
    0% { transform: scale(0); }
    60% { transform: scale(1.2); }
    100% { transform: scale(1); }
}

/* Hamburger button (mobile only) */
.tst-header__hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 38px;
    height: 38px;
    padding: 9px;
    border: none;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    cursor: pointer;
    transition: background 0.25s ease;
}

.tst-header__hamburger:hover {
    background: rgba(255,255,255,0.18);
}

.tst-header__hamburger span {
    display: block;
    height: 2px;
    background: #fff;
    border-radius: 2px;
    transition: all 0.3s ease;
    width: 100%;
}

.tst-header__hamburger.is-active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.tst-header__hamburger.is-active span:nth-child(2) {
    opacity: 0;
}

.tst-header__hamburger.is-active span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* Mobile menu panel */
.tst-header__mobile-menu {
    display: none;
    background: var(--tst-dark);
    padding: 0.5rem 1.25rem 1.5rem;
    border-top: 1px solid rgba(255,255,255,0.06);
}

.tst-header__mobile-menu.is-open {
    display: block;
    animation: tst-slide-down 0.25s ease;
}

@keyframes tst-slide-down {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

.tst-header__mobile-list {
    list-style: none;
    margin: 0;
    padding: 0.25rem 0;
}

.tst-header__mobile-list li a {
    display: flex;
    align-items: center;
    color: rgba(255,255,255,0.85);
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 0.92rem;
    padding: 0.85rem 0.5rem;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    border-radius: 8px;
    transition: color 0.2s, background 0.2s;
}

.tst-header__mobile-list li:last-child a {
    border-bottom: none;
}

.tst-header__mobile-list li a:hover,
.tst-header__mobile-list li.current-menu-item a {
    color: var(--tst-green);
    background: rgba(148, 186, 35, 0.08);
}

.tst-header__mobile-list .sub-menu {
    list-style: none;
    padding: 0 0 0 1rem;
    margin: 0;
}

.tst-header__mobile-list .sub-menu a {
    font-size: 0.84rem;
    font-weight: 500;
    color: rgba(255,255,255,0.6);
    padding: 0.65rem 0.5rem;
}

/* Responsive: show hamburger on tablet/mobile, hide desktop nav
   (primary breakpoint is 1024px, defined later in final corrections) */

/* ==========================================================================
   CART DRAWER (Slide-in from right)
   ========================================================================== */

.tst-drawer-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.35s ease, visibility 0.35s ease;
    backdrop-filter: blur(2px);
}

.tst-drawer-overlay.is-open {
    opacity: 1;
    visibility: visible;
}

.tst-drawer {
    position: fixed;
    top: 0;
    right: 0;
    width: 420px;
    max-width: 90vw;
    height: 100vh;
    height: 100dvh;
    background: #fff;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: -8px 0 40px rgba(0,0,0,0.15);
}

.tst-drawer.is-open {
    transform: translateX(0);
}

.tst-drawer__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--tst-gray-100);
    flex-shrink: 0;
}

.tst-drawer__title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: 'Poppins', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--tst-gray-900);
    margin: 0;
}

.tst-drawer__item-count {
    font-weight: 400;
    color: var(--tst-gray-500);
    font-size: 0.9rem;
}

.tst-drawer__close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid #d0d0d0;
    background: #f0f0f0;
    border-radius: 50%;
    color: #333;
    cursor: pointer;
    transition: all 0.25s ease;
    flex-shrink: 0;
    padding: 0;
    font: inherit;
    line-height: 1;
}

.tst-drawer__close-icon {
    display: block;
    font-size: 1.7rem;
    font-weight: 500;
    color: #333;
    line-height: 1;
    transform: translateY(-1px);
}

.tst-drawer__close:hover {
    background: #FFEBEE;
    color: #C62828;
    border-color: #FFCDD2;
}

.tst-drawer__close:hover .tst-drawer__close-icon {
    color: #C62828;
}

/* Drawer body (scrollable) */
.tst-drawer__body {
    flex: 1;
    overflow-y: auto;
    padding: 1rem 1.5rem;
}

/* Empty cart state */
.tst-drawer__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 3rem 1rem;
    gap: 1rem;
    min-height: 200px;
}

.tst-drawer__empty p {
    font-size: 1rem;
    color: var(--tst-gray-500);
    margin: 0;
}

.tst-drawer__browse-btn {
    display: inline-flex;
    padding: 0.65rem 1.5rem;
    background: var(--tst-green);
    color: #fff;
    border-radius: 50px;
    font-weight: 600;
    font-size: 0.85rem;
    text-decoration: none;
    transition: all 0.25s ease;
}

.tst-drawer__browse-btn:hover {
    background: var(--tst-green-dark);
    color: #fff;
    transform: translateY(-1px);
}

/* Cart items in drawer */
.tst-drawer__item {
    display: flex;
    gap: 0.75rem;
    padding: 1rem 0;
    border-bottom: 1px solid var(--tst-gray-100);
    animation: tst-fade-in 0.3s ease;
}

@keyframes tst-fade-in {
    from { opacity: 0; transform: translateX(10px); }
    to { opacity: 1; transform: translateX(0); }
}

.tst-drawer__item:last-child {
    border-bottom: none;
}

.tst-drawer__item-image {
    width: 70px;
    height: 70px;
    flex-shrink: 0;
    border-radius: var(--tst-radius-sm);
    overflow: hidden;
    background: var(--tst-gray-100);
}

.tst-drawer__item-image img,
.tst-drawer__item-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: var(--tst-radius-sm) !important;
}

.tst-drawer__item-details {
    flex: 1;
    min-width: 0;
}

.tst-drawer__item-name {
    font-family: 'Poppins', sans-serif;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--tst-gray-900);
    margin: 0 0 0.25rem;
    line-height: 1.3;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.tst-drawer__item-meta {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.75rem;
    color: var(--tst-gray-500);
    margin-bottom: 0.2rem;
}

.tst-drawer__item-meta svg {
    color: var(--tst-green);
}

.tst-drawer__item-price {
    font-weight: 700;
    color: var(--tst-green-dark);
    font-size: 0.95rem;
    margin-top: 0.25rem;
}

.tst-drawer__item-remove {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: none;
    background: transparent;
    color: var(--tst-gray-500);
    border-radius: 50%;
    cursor: pointer;
    transition: all 0.25s ease;
    align-self: flex-start;
}

.tst-drawer__item-remove:hover {
    background: #FFEBEE;
    color: #C62828;
}

/* Drawer footer */
.tst-drawer__footer {
    flex-shrink: 0;
    padding: 1.25rem 1.5rem;
    border-top: 2px solid var(--tst-gray-100);
    background: var(--tst-gray-100);
}

.tst-drawer__total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.tst-drawer__total-label {
    font-weight: 600;
    color: var(--tst-gray-700);
    font-size: 0.95rem;
}

.tst-drawer__total-amount {
    font-weight: 800;
    color: var(--tst-green-dark);
    font-size: 1.25rem;
    font-family: 'Poppins', sans-serif;
}

.tst-drawer__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.85rem;
    border-radius: var(--tst-radius-sm);
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 0.9rem;
    text-decoration: none;
    transition: all 0.25s ease;
    margin-bottom: 0.5rem;
    text-align: center;
}

.tst-drawer__btn--secondary {
    background: #fff;
    color: var(--tst-gray-900);
    border: 2px solid var(--tst-gray-300);
}

.tst-drawer__btn--secondary:hover {
    border-color: var(--tst-gray-900);
    color: var(--tst-gray-900);
}

.tst-drawer__btn--primary {
    background: var(--tst-green);
    color: #fff;
}

.tst-drawer__btn--primary:hover {
    background: var(--tst-green-dark);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(76,175,80,0.3);
}

.tst-drawer__btn:last-child {
    margin-bottom: 0;
}

/* Drawer: WooCommerce widget_shopping_cart overrides (AJAX fragments) */
.tst-drawer .widget_shopping_cart_content {
    padding: 0 !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item {
    display: flex !important;
    align-items: flex-start !important;
    gap: 0.75rem !important;
    padding: 0.85rem 0 !important;
    border-bottom: 1px solid var(--tst-gray-100) !important;
    list-style: none !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item:last-child {
    border-bottom: none !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item img {
    width: 64px !important;
    height: 64px !important;
    object-fit: cover !important;
    border-radius: var(--tst-radius-sm) !important;
    flex-shrink: 0 !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item a:not(.remove) {
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    color: var(--tst-gray-900) !important;
    text-decoration: none !important;
    line-height: 1.3 !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item a:not(.remove):hover {
    color: var(--tst-green) !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item .remove {
    order: 3 !important;
    margin-left: auto !important;
    font-size: 1.2rem !important;
    color: var(--tst-gray-500) !important;
    text-decoration: none !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item .remove:hover {
    color: #C62828 !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item .quantity {
    display: block !important;
    font-size: 0.8rem !important;
    color: var(--tst-gray-500) !important;
    margin-top: 0.15rem !important;
}

.tst-drawer .widget_shopping_cart_content .woocommerce-mini-cart-item .quantity .amount {
    font-weight: 700 !important;
    color: var(--tst-green-dark) !important;
}

.tst-drawer .widget_shopping_cart_content .total {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 0.75rem 0 !important;
    border-top: 2px solid var(--tst-gray-100) !important;
    font-weight: 600 !important;
    margin: 0 !important;
}

.tst-drawer .widget_shopping_cart_content .total .amount {
    font-weight: 800 !important;
    color: var(--tst-green-dark) !important;
    font-size: 1.15rem !important;
}

.tst-drawer .widget_shopping_cart_content .buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
    margin: 0 !important;
    padding: 0 !important;
}

.tst-drawer .widget_shopping_cart_content .buttons a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    padding: 0.85rem !important;
    border-radius: var(--tst-radius-sm) !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    text-decoration: none !important;
    transition: all 0.25s ease !important;
    text-align: center !important;
}

.tst-drawer .widget_shopping_cart_content .buttons a:first-child {
    background: #fff !important;
    color: var(--tst-gray-900) !important;
    border: 2px solid var(--tst-gray-300) !important;
}

.tst-drawer .widget_shopping_cart_content .buttons a:first-child:hover {
    border-color: var(--tst-gray-900) !important;
}

.tst-drawer .widget_shopping_cart_content .buttons a.checkout {
    background: var(--tst-green) !important;
    color: #fff !important;
    border: none !important;
}

.tst-drawer .widget_shopping_cart_content .buttons a.checkout:hover {
    background: var(--tst-green-dark) !important;
}

/* Cart drawer mobile refinements */
@media (max-width: 480px) {
    .tst-drawer {
        width: 100vw !important;
        max-width: 100vw !important;
    }

    .tst-drawer__header {
        padding: 1rem 1.15rem !important;
    }

    .tst-drawer__body {
        padding: 0.75rem 1.15rem !important;
    }

    .tst-drawer__footer {
        padding: 1rem 1.15rem !important;
    }

    .tst-drawer__item-image {
        width: 60px !important;
        height: 60px !important;
    }

    .tst-drawer__item-name {
        font-size: 0.85rem !important;
    }

    .tst-drawer__btn {
        padding: 0.75rem !important;
        font-size: 0.85rem !important;
    }
}

/* ==========================================================================
   CRITICAL: GeneratePress Full-Width Overrides
   GP nests: body > .site > .site-content > .grid-container > #primary
             > .inside-article > .entry-content
   We must strip ALL width constraints on our custom pages.
   ========================================================================== */

/* Universal GP reset for all our page types */
.tst-front-page .site-content,
.tst-front-page .content-area,
.tst-front-page .inside-article,
.tst-front-page .entry-content,
.tst-front-page #primary,
.tst-front-page .site-content > .grid-container,
.tst-custom-page .site-content,
.tst-custom-page .content-area,
.tst-custom-page .inside-article,
.tst-custom-page .entry-content,
.tst-custom-page #primary,
.tst-custom-page .site-content > .grid-container,
.tst-tour-page .site-content,
.tst-tour-page .content-area,
.tst-tour-page .inside-article,
.tst-tour-page .entry-content,
.tst-tour-page #primary,
.tst-tour-page .site-content > .grid-container,
.single-tst_tour .site-content,
.single-tst_tour .content-area,
.single-tst_tour .inside-article,
.single-tst_tour .entry-content,
.single-tst_tour #primary,
.single-tst_tour .site-content > .grid-container,
.post-type-archive-tst_tour .site-content,
.post-type-archive-tst_tour .content-area,
.post-type-archive-tst_tour .inside-article,
.post-type-archive-tst_tour .entry-content,
.post-type-archive-tst_tour #primary,
.post-type-archive-tst_tour .site-content > .grid-container,
.tax-tst_tour_cat .site-content,
.tax-tst_tour_cat .content-area,
.tax-tst_tour_cat .inside-article,
.tax-tst_tour_cat .entry-content,
.tax-tst_tour_cat #primary,
.tax-tst_tour_cat .site-content > .grid-container,
.tax-tst_tour_location .site-content,
.tax-tst_tour_location .content-area,
.tax-tst_tour_location .inside-article,
.tax-tst_tour_location .entry-content,
.tax-tst_tour_location #primary,
.tax-tst_tour_location .site-content > .grid-container,
.tax-tst_tour_activity .site-content,
.tax-tst_tour_activity .content-area,
.tax-tst_tour_activity .inside-article,
.tax-tst_tour_activity .entry-content,
.tax-tst_tour_activity #primary,
.tax-tst_tour_activity .site-content > .grid-container {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
}

.tst-front-page .inside-article,
.tst-custom-page .inside-article,
.tst-tour-page .inside-article,
.single-tst_tour .inside-article,
.post-type-archive-tst_tour .inside-article,
.tax-tst_tour_cat .inside-article,
.tax-tst_tour_location .inside-article,
.tax-tst_tour_activity .inside-article {
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

.tst-front-page .entry-content,
.tst-custom-page .entry-content,
.tst-tour-page .entry-content,
.single-tst_tour .entry-content,
.post-type-archive-tst_tour .entry-content {
    overflow: visible !important;
}

/* GP also sets max-width on .grid-container — remove it */
.tst-front-page .grid-container,
.tst-custom-page .grid-container,
.tst-tour-page .grid-container,
.single-tst_tour .grid-container,
.post-type-archive-tst_tour .grid-container,
.tax-tst_tour_cat .grid-container,
.tax-tst_tour_location .grid-container,
.tax-tst_tour_activity .grid-container {
    max-width: 100% !important;
    width: 100% !important;
}

/* Remove default GP page title/header on custom pages */
.tst-front-page .page-header,
.tst-custom-page .page-header,
.tst-tour-page .page-header,
.single-tst_tour .page-header,
.post-type-archive-tst_tour .page-header {
    display: none !important;
}

/* GP's #right-sidebar should never appear on our pages */
.tst-front-page #right-sidebar,
.tst-custom-page #right-sidebar,
.tst-tour-page #right-sidebar,
.single-tst_tour #right-sidebar,
.post-type-archive-tst_tour #right-sidebar {
    display: none !important;
}

/* ==========================================================================
   Full-Bleed Sections (break out of any remaining GP wrapper)
   ========================================================================== */

.tst-homepage {
    width: 100%;
    overflow-x: clip;
}

.tst-homepage-section {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
}

/* ==========================================================================
   Hero Video Section
   ========================================================================== */

.tst-hero {
    position: relative;
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    color: var(--tst-white);
}

.tst-hero__video-wrap {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.tst-hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tst-hero__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        180deg,
        rgba(0, 0, 0, 0.3) 0%,
        rgba(0, 0, 0, 0.55) 50%,
        rgba(26, 26, 46, 0.8) 100%
    );
}

.tst-hero__content {
    position: relative;
    z-index: 2;
    text-align: center;
    padding: 6rem 1rem 4rem;
    width: 100%;
}

.tst-hero__heading {
    font-size: clamp(2rem, 6vw, 4rem);
    font-weight: 900;
    line-height: 1.1;
    margin: 0 0 1rem;
    color: var(--tst-white);
    letter-spacing: -0.02em;
}

.tst-hero__subheading {
    font-size: clamp(1rem, 2.5vw, 1.3rem);
    max-width: 640px;
    margin: 0 auto 2.5rem;
    opacity: 0.9;
    line-height: 1.6;
    font-weight: 400;
}

.tst-hero__actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    justify-content: center;
    margin-bottom: 3rem;
}

@media (min-width: 480px) {
    .tst-hero__actions {
        flex-direction: row;
    }
}

.tst-hero__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 2rem;
    border-radius: 50px;
    font-size: 1rem;
    font-weight: 700;
    font-family: 'Poppins', sans-serif;
    text-decoration: none;
    transition: all var(--tst-transition);
    white-space: nowrap;
}

.tst-hero__btn--primary {
    background: var(--tst-green);
    color: var(--tst-white);
    box-shadow: 0 4px 20px rgba(76, 175, 80, 0.4);
}

.tst-hero__btn--primary:hover {
    background: var(--tst-green-dark);
    color: var(--tst-white);
    transform: translateY(-2px);
    box-shadow: 0 6px 28px rgba(76, 175, 80, 0.5);
}

.tst-hero__btn--outline {
    background: transparent;
    color: var(--tst-white);
    border: 2px solid rgba(255,255,255,0.5);
}

.tst-hero__btn--outline:hover {
    border-color: var(--tst-white);
    background: rgba(255,255,255,0.1);
    color: var(--tst-white);
}

/* Trust badges */
.tst-hero__badges {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    max-width: 800px;
    margin: 0 auto;
}

@media (min-width: 768px) {
    .tst-hero__badges {
        flex-direction: row;
        justify-content: center;
        gap: 2.5rem;
    }
}

.tst-hero__badge {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-align: left;
    opacity: 0.85;
}

.tst-hero__badge strong {
    display: block;
    font-size: 0.9rem;
    font-weight: 700;
}

.tst-hero__badge small {
    display: block;
    font-size: 0.75rem;
    opacity: 0.7;
}

/* Scroll indicator */
.tst-hero__scroll {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
}

.tst-hero__scroll-line {
    width: 2px;
    height: 40px;
    background: rgba(255,255,255,0.4);
    position: relative;
    overflow: hidden;
}

.tst-hero__scroll-line::after {
    content: '';
    position: absolute;
    top: -100%;
    width: 100%;
    height: 50%;
    background: var(--tst-white);
    animation: tst-scroll 2s ease-in-out infinite;
}

@keyframes tst-scroll {
    0% { top: -50%; }
    100% { top: 100%; }
}

/* ==========================================================================
   Sections (homepage blocks)
   ========================================================================== */

.tst-section-block {
    padding: 4rem 0;
}

@media (min-width: 768px) {
    .tst-section-block { padding: 6rem 0; }
}

.tst-section-block--dark {
    background: var(--tst-dark);
    color: var(--tst-white);
}

.tst-section-block--gray {
    background: var(--tst-gray-100);
}

.tst-section-heading {
    text-align: center;
    margin-bottom: 3rem;
}

.tst-section-heading h2 {
    font-size: clamp(1.5rem, 4vw, 2.5rem);
    font-weight: 800;
    margin: 0 0 0.75rem;
    letter-spacing: -0.02em;
}

.tst-section-heading p {
    font-size: 1.05rem;
    color: var(--tst-gray-500);
    max-width: 600px;
    margin: 0 auto;
}

/* ==========================================================================
   CTA Banner
   ========================================================================== */

.tst-cta-banner {
    position: relative;
    padding: 6rem 0;
    overflow: hidden;
    text-align: center;
    color: var(--tst-white);
}

.tst-cta-banner__bg-video {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.tst-cta-banner__bg-video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tst-cta-banner__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(135deg, rgba(26,26,46,0.85), rgba(76,175,80,0.6));
}

.tst-cta-banner__content {
    position: relative;
    z-index: 2;
    max-width: 700px;
    margin: 0 auto;
    padding: 0 1rem;
}

.tst-cta-banner__content h2 {
    font-size: clamp(1.75rem, 5vw, 3rem);
    font-weight: 900;
    margin: 0 0 1rem;
    color: var(--tst-white);
    line-height: 1.15;
}

.tst-cta-banner__content p {
    font-size: 1.1rem;
    opacity: 0.9;
    margin: 0 0 2rem;
    line-height: 1.6;
}

.tst-cta-banner__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1.1rem 2.5rem;
    background: var(--tst-orange);
    color: var(--tst-white);
    border-radius: 50px;
    font-size: 1.05rem;
    font-weight: 700;
    font-family: 'Poppins', sans-serif;
    text-decoration: none;
    transition: all var(--tst-transition);
    box-shadow: 0 4px 20px rgba(232, 160, 48, 0.4);
}

.tst-cta-banner__btn:hover {
    background: var(--tst-orange-dark);
    color: var(--tst-white);
    transform: translateY(-2px);
    box-shadow: 0 6px 28px rgba(232, 160, 48, 0.5);
}

/* ==========================================================================
   Stats
   ========================================================================== */

.tst-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    padding: 2rem 0;
}

@media (min-width: 768px) {
    .tst-stats { grid-template-columns: repeat(4, 1fr); }
}

.tst-stat {
    text-align: center;
}

.tst-stat__number {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 900;
    color: var(--tst-green);
    font-family: 'Poppins', sans-serif;
}

.tst-stat__label {
    font-size: 0.9rem;
    color: var(--tst-gray-500);
    margin-top: 0.25rem;
}

/* ==========================================================================
   Testimonials
   ========================================================================== */

.tst-testimonials {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .tst-testimonials { grid-template-columns: repeat(3, 1fr); }
}

.tst-testimonial {
    background: var(--tst-white);
    border-radius: var(--tst-radius);
    padding: 2rem;
    box-shadow: var(--tst-shadow);
    display: flex;
    flex-direction: column;
}

.tst-testimonial__stars {
    color: var(--tst-orange);
    font-size: 1.2rem;
    margin-bottom: 1rem;
    letter-spacing: 0.15em;
}

.tst-testimonial__text {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--tst-gray-700);
    flex: 1;
    margin: 0 0 1.5rem;
}

.tst-testimonial__author {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.tst-testimonial__avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    background: var(--tst-gray-300);
}

.tst-testimonial__name {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--tst-gray-900);
}

.tst-testimonial__role {
    font-size: 0.8rem;
    color: var(--tst-gray-500);
}

/* ==========================================================================
   Footer
   ========================================================================== */

.tst-footer-top {
    background: var(--tst-dark);
    color: rgba(255,255,255,0.8);
    padding: 4rem 0 3rem;
}

.tst-footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 768px) {
    .tst-footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; }
}

.tst-footer-col h4,
.tst-footer-col .widget-title {
    color: var(--tst-white);
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 1rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.tst-footer-col a {
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    transition: color var(--tst-transition);
}

.tst-footer-col a:hover {
    color: var(--tst-green);
}

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

.tst-footer-col ul li {
    padding: 0.3rem 0;
}

.tst-footer-brand {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--tst-white);
    margin: 0 0 1rem;
}

.tst-footer-address {
    font-size: 0.9rem;
    line-height: 1.6;
    margin: 0 0 0.5rem;
}

.tst-footer-bottom {
    background: rgba(0,0,0,0.3);
    padding: 1.5rem 0;
}

.tst-footer-bottom-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    text-align: center;
}

@media (min-width: 768px) {
    .tst-footer-bottom-inner {
        flex-direction: row;
        justify-content: space-between;
    }
}

.tst-footer-bottom p {
    margin: 0;
    font-size: 0.85rem;
    color: rgba(255,255,255,0.5);
}

.tst-social-links {
    display: flex;
    gap: 1rem;
}

.tst-social-links a {
    color: rgba(255,255,255,0.6);
    transition: color var(--tst-transition), transform var(--tst-transition);
}

.tst-social-links a:hover {
    color: var(--tst-green);
    transform: translateY(-2px);
}

/* ==========================================================================
   Mobile Navigation Enhancements
   ========================================================================== */

@media (max-width: 767px) {
    .site-header {
        position: sticky;
        top: 0;
        z-index: 1000;
        background: var(--tst-dark) !important;
        box-shadow: none;
    }
}

/* ==========================================================================
   WhatsApp Floating Button
   ========================================================================== */

.tst-whatsapp-float {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 999;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: #25D366;
    color: var(--tst-white);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 16px rgba(37, 211, 102, 0.4);
    transition: all var(--tst-transition);
    text-decoration: none;
}

.tst-whatsapp-float:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 24px rgba(37, 211, 102, 0.5);
}

/* ==========================================================================
   SINGLE TOUR PAGE – Hero + Layout Fixes
   ========================================================================== */

/* The .tst-single wraps the entire single tour page output */
.tst-single {
    width: 100%;
}

/* Hero must go full-width and be tall with image */
.tst-single__hero {
    position: relative;
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    min-height: 45vh;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    background: var(--tst-dark);
}

@media (min-width: 768px) {
    .tst-single__hero {
        min-height: 55vh;
    }
}

.tst-single__hero-img {
    position: absolute !important;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    max-width: none !important;
}

.tst-single__hero-overlay {
    position: relative;
    z-index: 1;
    width: 100%;
    padding: 4rem 0 2.5rem;
    background: linear-gradient(to top, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.3) 60%, transparent 100%);
    color: var(--tst-white);
}

.tst-single__title {
    font-size: 1.75rem;
    font-weight: 800;
    margin: 0.75rem 0;
    line-height: 1.2;
    color: var(--tst-white) !important;
}

@media (min-width: 768px) {
    .tst-single__title { font-size: 2.5rem; }
}

/* The layout below hero should be properly contained */
.tst-single > .tst-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1rem;
}

@media (min-width: 768px) {
    .tst-single > .tst-container {
        padding: 0 2rem;
    }
}

.tst-single__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 2rem 0 4rem;
}

@media (min-width: 960px) {
    .tst-single__layout {
        grid-template-columns: 1fr 380px;
    }
}

/* Breadcrumb in hero */
.tst-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
}

.tst-breadcrumb a {
    color: rgba(255,255,255,0.8);
    text-decoration: none;
}

.tst-breadcrumb a:hover {
    color: var(--tst-white);
    text-decoration: underline;
}

.tst-breadcrumb span {
    color: rgba(255,255,255,0.6);
}

/* Meta items in hero */
.tst-single__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 0.75rem;
}

.tst-meta-item {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.9rem;
    color: rgba(255,255,255,0.9);
}

.tst-meta-item svg {
    color: rgba(255,255,255,0.8);
}

.tst-meta-item--easy { color: var(--tst-green); }
.tst-meta-item--moderate { color: var(--tst-orange); }
.tst-meta-item--challenging { color: #F44336; }

/* ==========================================================================
   ARCHIVE PAGE – Full-Width Header + Grid
   ========================================================================== */

.tst-archive {
    width: 100%;
}

.tst-archive__header {
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    background: var(--tst-dark) !important;
    color: var(--tst-white) !important;
    padding: 3rem 0 2rem;
}

.tst-archive__title {
    font-size: 2rem;
    font-weight: 800;
    margin: 0 0 0.5rem;
    color: var(--tst-white) !important;
}

@media (min-width: 768px) {
    .tst-archive__title { font-size: 2.5rem; }
}

.tst-archive__header .tst-search {
    margin-top: 1.5rem;
}

.tst-archive__description {
    font-size: 1rem;
    opacity: 0.8;
    max-width: 600px;
}

/* Archive body sections */
.tst-archive__body {
    max-width: 100%;
}

/* Breadcrumb on taxonomy archives */
.tst-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    margin-bottom: 0.75rem;
    opacity: 0.85;
}

.tst-breadcrumb a {
    color: var(--tst-white);
    text-decoration: none;
    transition: opacity 0.15s;
}

.tst-breadcrumb a:hover {
    opacity: 1;
    text-decoration: underline;
}

.tst-breadcrumb span {
    color: var(--tst-white);
}

/* ==========================================================================
   Page Templates (About, Contact, FAQ, Destinations, Gallery)
   ========================================================================== */

/* Page heroes go full-width */
.tst-page__hero {
    width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
    background: var(--tst-dark);
    color: var(--tst-white);
    padding: 4rem 0 3rem;
    text-align: center;
}

.tst-page__hero-overlay {
    position: relative;
    z-index: 1;
}

.tst-page__title {
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 900;
    margin: 0 0 0.75rem;
    color: var(--tst-white);
}

.tst-page__subtitle {
    font-size: 1.1rem;
    opacity: 0.8;
    max-width: 600px;
    margin: 0 auto;
}

/* Full-width page content */
.tst-page {
    width: 100%;
}

.tst-page .tst-container {
    max-width: 1280px;
    margin: 0 auto;
}

/* About page */
.tst-about-intro {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    align-items: center;
}

@media (min-width: 768px) {
    .tst-about-intro { grid-template-columns: 1fr 1fr; }
}

.tst-about-intro__text h2 {
    font-size: 1.75rem;
    margin-bottom: 1rem;
}

.tst-about-intro__text p {
    font-size: 1rem;
    line-height: 1.7;
    margin-bottom: 1rem;
}

.tst-about-intro__image img {
    width: 100%;
    border-radius: var(--tst-radius);
}

.tst-services-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 600px) {
    .tst-services-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
    .tst-services-grid { grid-template-columns: repeat(3, 1fr); }
}

.tst-service-card {
    background: var(--tst-white);
    padding: 2rem;
    border-radius: var(--tst-radius);
    box-shadow: var(--tst-shadow);
    text-align: center;
    transition: transform var(--tst-transition);
}

.tst-service-card:hover {
    transform: translateY(-4px);
}

.tst-service-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(76,175,80,0.1);
    color: var(--tst-green);
    margin-bottom: 1rem;
}

.tst-service-card h3 {
    font-size: 1.1rem;
    margin: 0 0 0.5rem;
}

.tst-service-card p {
    font-size: 0.9rem;
    color: var(--tst-gray-700);
    margin: 0;
}

.tst-values-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    text-align: center;
}

@media (min-width: 768px) {
    .tst-values-grid { grid-template-columns: repeat(3, 1fr); }
}

.tst-value h3 {
    font-size: 1.5rem;
    color: var(--tst-green);
    margin-bottom: 0.5rem;
}

.tst-value p {
    font-size: 0.95rem;
    color: var(--tst-gray-700);
}

.tst-page__hero--about {
    background:
        linear-gradient(135deg, rgba(26, 26, 46, 0.92), rgba(56, 142, 60, 0.84)),
        radial-gradient(circle at top, rgba(232, 160, 48, 0.35), transparent 38%);
}

.tst-page-about .tst-kicker {
    background: rgba(76, 175, 80, 0.12);
    color: var(--tst-green-dark);
}

.tst-about-story {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 3rem;
    align-items: center;
}

.tst-about-story__copy {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.tst-about-story__copy h2 {
    margin: 0;
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: var(--tst-gray-900);
}

.tst-about-story__lead {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.7;
    font-weight: 600;
    color: var(--tst-gray-900);
}

.tst-about-story__copy p {
    margin: 0;
    color: var(--tst-gray-700);
    line-height: 1.8;
}

.tst-about-pill-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    padding-top: 0.5rem;
}

.tst-about-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.7rem 1rem;
    border-radius: 999px;
    background: var(--tst-gray-100);
    color: var(--tst-gray-900);
    font-size: 0.86rem;
    font-weight: 600;
}

.tst-about-story__media {
    position: relative;
}

.tst-about-gallery {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: 1rem;
    align-items: stretch;
}

.tst-about-gallery__primary,
.tst-about-gallery__secondary {
    overflow: hidden;
    border-radius: 26px;
    box-shadow: var(--tst-shadow-lg);
    min-height: 420px;
}

.tst-about-gallery__secondary {
    margin-top: 3rem;
}

.tst-about-gallery__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.tst-about-gallery__card {
    position: absolute;
    left: 1rem;
    bottom: 1rem;
    width: min(18rem, calc(100% - 2rem));
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    padding: 1.15rem 1.2rem;
    border-radius: 20px;
    background: rgba(26, 26, 46, 0.92);
    color: var(--tst-white);
    box-shadow: 0 20px 40px rgba(26, 26, 46, 0.22);
}

.tst-about-gallery__card-label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.72);
}

.tst-about-feature-grid,
.tst-about-values-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
}

.tst-about-feature-card,
.tst-about-values-card {
    padding: 1.75rem;
    border-radius: 20px;
    background: var(--tst-white);
    box-shadow: var(--tst-shadow);
}

.tst-about-feature-card__icon,
.tst-about-values-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.5rem;
    height: 3.5rem;
    margin-bottom: 1rem;
    border-radius: 16px;
    background: rgba(76, 175, 80, 0.12);
    color: var(--tst-green-dark);
}

.tst-about-feature-card h3,
.tst-about-values-card h3 {
    margin: 0 0 0.6rem;
    color: var(--tst-gray-900);
    font-size: 1.15rem;
}

.tst-about-feature-card p,
.tst-about-values-card p {
    margin: 0;
    color: var(--tst-gray-700);
    line-height: 1.7;
}

.tst-about-founder {
    display: grid;
    grid-template-columns: minmax(19rem, 0.8fr) minmax(0, 1.2fr);
    gap: 2.5rem;
    align-items: center;
    padding: clamp(1.5rem, 3vw, 2.75rem);
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(232, 160, 48, 0.18), transparent 35%),
        linear-gradient(135deg, #fffdf9 0%, #f3efe4 100%);
    box-shadow: 0 18px 45px rgba(43, 42, 47, 0.08);
}

.tst-about-founder__image {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100%;
    padding: 1rem;
    border-radius: 24px;
    background:
        radial-gradient(circle at center, rgba(76, 175, 80, 0.14), transparent 58%),
        linear-gradient(180deg, #f8f6ee 0%, #efe7d3 100%);
}

.tst-about-founder__portrait {
    max-width: min(100%, 24rem);
    height: auto;
    display: block;
}

.tst-about-founder__content {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.tst-about-founder__content h2 {
    margin: 0;
    font-size: clamp(2rem, 4vw, 2.8rem);
    color: var(--tst-gray-900);
}

.tst-about-founder__role {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--tst-green-dark);
}

.tst-about-founder__content p {
    margin: 0;
    line-height: 1.8;
    color: var(--tst-gray-700);
}

.tst-about-founder__quote {
    margin: 0.5rem 0 0;
    padding-left: 1rem;
    border-left: 3px solid rgba(76, 175, 80, 0.35);
    font-size: 1.05rem;
    font-style: italic;
    color: var(--tst-gray-900);
}

.tst-about-platforms {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

.tst-about-platform {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    padding: 1.5rem;
    border: 1px solid var(--tst-gray-300);
    border-radius: 18px;
    background: var(--tst-white);
    color: inherit;
    text-decoration: none;
    transition: transform var(--tst-transition), box-shadow var(--tst-transition), border-color var(--tst-transition);
}

.tst-about-platform:hover {
    transform: translateY(-3px);
    box-shadow: var(--tst-shadow-lg);
    border-color: rgba(76, 175, 80, 0.35);
}

.tst-about-platform strong {
    font-size: 1.05rem;
    color: var(--tst-gray-900);
}

.tst-about-platform span {
    color: var(--tst-gray-700);
    line-height: 1.7;
}

.tst-about-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: clamp(1.5rem, 3vw, 2.25rem);
    border-radius: 24px;
    background: linear-gradient(135deg, rgba(76, 175, 80, 0.12), rgba(232, 160, 48, 0.14));
}

.tst-about-cta h2 {
    margin: 0.5rem 0 0;
    font-size: clamp(1.6rem, 3vw, 2.5rem);
    color: var(--tst-gray-900);
}

.tst-about-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

@media (max-width: 959px) {
    .tst-about-story,
    .tst-about-founder {
        grid-template-columns: 1fr;
    }

    .tst-about-gallery__secondary {
        margin-top: 0;
    }
}

@media (max-width: 767px) {
    .tst-about-feature-grid,
    .tst-about-values-grid,
    .tst-about-platforms {
        grid-template-columns: 1fr;
    }

    .tst-about-gallery {
        grid-template-columns: 1fr;
    }

    .tst-about-gallery__primary,
    .tst-about-gallery__secondary {
        min-height: 300px;
    }

    .tst-about-gallery__card {
        position: static;
        width: 100%;
    }

    .tst-about-cta {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* Contact page */
.tst-contact-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
}

@media (min-width: 768px) {
    .tst-contact-layout { grid-template-columns: 380px 1fr; }
}

.tst-contact-info {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.tst-contact-card {
    background: var(--tst-gray-100);
    border-radius: var(--tst-radius);
    padding: 1.5rem;
}

.tst-contact-card__icon {
    margin-bottom: 0.75rem;
}

.tst-contact-card h3 {
    font-size: 1rem;
    margin: 0 0 0.5rem;
}

.tst-contact-card p {
    font-size: 0.9rem;
    margin: 0.25rem 0;
}

.tst-contact-card a {
    color: var(--tst-green);
    text-decoration: none;
}

.tst-contact-card a:hover {
    text-decoration: underline;
}

.tst-whatsapp-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 1.5rem;
    background: #25D366;
    color: var(--tst-white);
    border-radius: var(--tst-radius-sm);
    font-weight: 600;
    text-decoration: none;
    transition: background var(--tst-transition);
}

.tst-whatsapp-btn:hover {
    background: #1da851;
}

.tst-contact-form-area h2 {
    margin-bottom: 1.5rem;
}

/* FAQ accordion (re-uses plugin styles) */
.tst-faq-list .tst-accordion__item {
    border: 1px solid var(--tst-gray-300);
    border-radius: var(--tst-radius-sm);
    margin-bottom: 0.75rem;
    overflow: hidden;
}

.tst-faq-list .tst-accordion__question {
    padding: 1.25rem 1.5rem;
    font-weight: 600;
    cursor: pointer;
    font-size: 1rem;
    color: var(--tst-gray-900);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--tst-white);
}

.tst-faq-list .tst-accordion__question::-webkit-details-marker { display: none; }

.tst-faq-list .tst-accordion__question::after {
    content: '+';
    font-size: 1.5rem;
    font-weight: 300;
    color: var(--tst-gray-500);
    transition: transform var(--tst-transition);
}

.tst-faq-list .tst-accordion__item[open] .tst-accordion__question::after {
    transform: rotate(45deg);
}

.tst-faq-list .tst-accordion__answer {
    padding: 0 1.5rem 1.25rem;
    font-size: 0.95rem;
    color: var(--tst-gray-700);
    line-height: 1.7;
}

/* ==========================================================================
   Scroll Reveal Animations
   ========================================================================== */

.tst-animate {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.tst-animate.tst-visible {
    opacity: 1;
    transform: translateY(0);
}

.tst-page-gallery .tst-section-block,
.tst-page-gallery .tst-gallery,
.tst-page-gallery .tst-gallery__item {
    opacity: 1 !important;
    transform: none !important;
}

/* Stagger cards in grid */
.tst-tour-grid .tst-animate:nth-child(2) { transition-delay: 0.08s; }
.tst-tour-grid .tst-animate:nth-child(3) { transition-delay: 0.16s; }
.tst-tour-grid .tst-animate:nth-child(4) { transition-delay: 0.24s; }
.tst-tour-grid .tst-animate:nth-child(5) { transition-delay: 0.32s; }
.tst-tour-grid .tst-animate:nth-child(6) { transition-delay: 0.40s; }

/* ==========================================================================
   Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
    .tst-animate {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .tst-hero__scroll-line::after {
        animation: none;
    }

    .tst-hero__video {
        display: none;
    }
}

/* ==========================================================================
   BRANDED FOOTER (Togo-inspired)
   ========================================================================== */

.tst-footer {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* CTA Strip above footer */
.tst-footer__cta {
    background: linear-gradient(135deg, var(--tst-green) 0%, var(--tst-green-dark) 100%);
    padding: 3rem 0;
}

.tst-footer__cta-inner {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    align-items: center;
    text-align: center;
}

@media (min-width: 768px) {
    .tst-footer__cta-inner {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
    }
}

.tst-footer__cta-text h3 {
    color: #fff;
    font-size: 1.5rem;
    font-weight: 800;
    margin: 0 0 0.35rem;
}

.tst-footer__cta-text p {
    color: rgba(255,255,255,0.85);
    margin: 0;
    font-size: 1rem;
}

.tst-footer__cta-actions {
    display: flex;
    gap: 0.75rem;
    flex-shrink: 0;
    flex-wrap: wrap;
    justify-content: center;
}

.tst-footer__cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 1.75rem;
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.9rem;
    text-decoration: none;
    transition: all var(--tst-transition);
    white-space: nowrap;
}

.tst-footer__cta-btn--primary {
    background: #fff;
    color: var(--tst-green-dark);
}

.tst-footer__cta-btn--primary:hover {
    background: var(--tst-gray-100);
    color: var(--tst-green-dark);
    transform: translateY(-2px);
}

.tst-footer__cta-btn--wa {
    background: rgba(255,255,255,0.15);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.3);
}

.tst-footer__cta-btn--wa:hover {
    background: rgba(255,255,255,0.25);
    color: #fff;
}

/* Main footer area */
.tst-footer__main {
    background: var(--tst-dark);
    color: rgba(255,255,255,0.75);
    padding: 4rem 0 3rem;
}

.tst-footer__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    align-items: start;
}

/* Brand (left) | menus + SATIB/payment (right) — avoids huge gap under short nav columns */
@media (min-width: 768px) {
    .tst-footer__grid {
        grid-template-columns: minmax(0, 2fr) minmax(0, 3.25fr);
        gap: 2.5rem 3rem;
    }
}

.tst-footer__nav-cluster {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-width: 0;
}

.tst-footer__nav-cluster-cols {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
}

@media (min-width: 768px) {
    .tst-footer__nav-cluster-cols {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1.25fr);
        gap: 2rem 2.5rem;
        align-items: start;
    }
}

@media (max-width: 599px) {
    .tst-footer__nav-cluster-cols {
        grid-template-columns: 1fr;
    }

    .tst-footer__nav-cluster-cols .tst-footer__col:nth-child(3) {
        grid-column: auto;
    }
}

.tst-footer__col--brand {
    max-width: 420px;
}

.tst-footer__logo img,
.tst-footer__logo .custom-logo {
    max-height: 45px !important;
    width: auto !important;
    margin-bottom: 1rem;
    filter: brightness(0) invert(1);
}

.tst-footer__brand-name {
    color: #fff;
    font-size: 1.4rem;
    font-weight: 800;
    margin: 0 0 1rem;
    font-family: 'Poppins', sans-serif;
}

.tst-footer__tagline {
    font-size: 0.9rem;
    line-height: 1.65;
    margin: 0 0 1.25rem;
    color: rgba(255,255,255,0.6);
}

.tst-footer__social {
    display: flex;
    gap: 0.75rem;
}

.tst-footer__social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.7);
    transition: all var(--tst-transition);
    text-decoration: none;
}

.tst-footer__social a:hover {
    background: var(--tst-green);
    color: #fff;
    transform: translateY(-2px);
}

.tst-footer__col h4 {
    color: #fff;
    font-family: 'Poppins', sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0 0 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--tst-green);
    display: inline-block;
}

.tst-footer__col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.tst-footer__col ul li {
    margin-bottom: 0.6rem;
}

.tst-footer__col ul li a {
    color: rgba(255,255,255,0.65);
    text-decoration: none;
    font-size: 0.9rem;
    transition: color var(--tst-transition), padding-left var(--tst-transition);
    display: inline-block;
}

.tst-footer__col ul li a:hover {
    color: var(--tst-green);
    padding-left: 4px;
}

.tst-footer__contact-item {
    display: flex;
    gap: 0.65rem;
    align-items: flex-start;
    margin-bottom: 1rem;
    font-size: 0.9rem;
    line-height: 1.5;
}

.tst-footer__contact-item svg {
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--tst-green);
}

.tst-footer__contact-item a {
    color: rgba(255,255,255,0.75);
    text-decoration: none;
    transition: color var(--tst-transition);
}

.tst-footer__contact-item a:hover {
    color: var(--tst-green);
}

/* Bottom bar: one row — copyright | SATIB (fallback) | PayFast */
.tst-footer__bottom {
    background: rgba(0, 0, 0, 0.32);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 1.1rem 0 1.25rem;
}

.tst-footer__bottom-inner {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.85rem;
    text-align: center;
}

@media (min-width: 768px) {
    .tst-footer__bottom-inner {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        text-align: left;
        gap: 1rem 1.5rem;
    }
}

.tst-footer__copyright {
    margin: 0;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.45);
    flex: 1 1 auto;
    min-width: min(100%, 14rem);
}

.tst-footer__bottom-satib {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.65);
}

.tst-footer__bottom-satib svg {
    flex-shrink: 0;
    stroke: var(--tst-green);
}

@media (min-width: 768px) {
    .tst-footer__bottom-payfast {
        margin-left: auto;
    }
}

.tst-footer__bottom-payfast .tst-payfast-trust__line--intro {
    color: rgba(255, 255, 255, 0.55) !important;
}

.tst-footer__bottom-payfast .tst-payfast-trust__line--brand {
    color: rgba(255, 255, 255, 0.92) !important;
}

.tst-footer__bottom-payfast .tst-payfast-trust__logo {
    filter: brightness(0) invert(1);
    opacity: 0.95;
}

.tst-footer__bottom p:not(.tst-footer__copyright) {
    margin: 0;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.4);
}

.tst-footer__payment-icons {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.5rem;
}

@media (min-width: 768px) {
    .tst-footer__payment-icons {
        justify-content: flex-end;
        margin-left: auto;
    }
}

.tst-footer__payment-icons strong {
    color: rgba(255, 255, 255, 0.65);
}

/* Hide GeneratePress default footer (avoids duplicate copyright / extra bar) */
footer.site-footer {
    display: none !important;
}

.site-footer .site-info,
.site-info {
    display: none !important;
}

/* ==========================================================================
   WooCommerce – GeneratePress Overrides for Cart / Checkout / Account
   Boxed layout: content is centered at 1140px max-width
   ========================================================================== */

/* Strip GP containers so we can control layout ourselves */
.tst-wc-page .site-content > .grid-container {
    max-width: 1140px !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding: 0 1.5rem !important;
    box-sizing: border-box !important;
}

.tst-wc-page .content-area,
.tst-wc-page #primary {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

.tst-wc-page .inside-article {
    max-width: 100% !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

.tst-wc-page .entry-content {
    overflow: visible !important;
    max-width: 100% !important;
}

.tst-wc-page #right-sidebar {
    display: none !important;
}

/* Subtle background for boxed card contrast */
.tst-wc-page .site-content {
    background: #f8f9fa !important;
    padding-bottom: 3rem !important;
}

/* Page header / breadcrumb area */
.tst-wc-page .page-header {
    display: none !important;
}

/* Page titles — centered within the 1140px container */
.tst-wc-page .entry-header {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.tst-wc-page .entry-title {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 800 !important;
    font-size: 2rem !important;
    color: var(--tst-gray-900) !important;
    margin: 2rem 0 1.5rem !important;
    padding-bottom: 1rem !important;
    border-bottom: 2px solid var(--tst-gray-200, #e0e0e0) !important;
}

/* ==========================================================================
   WooCommerce – COMPREHENSIVE CART & CHECKOUT STYLING
   ========================================================================== */

/* --- Traditional (shortcode-based) checkout two-column layout --- */
.woocommerce-checkout .entry-content > .woocommerce {
    display: grid !important;
    grid-template-columns: 1fr 380px !important;
    gap: 2rem !important;
    align-items: start !important;
}

.woocommerce-checkout .entry-content > .woocommerce > .woocommerce-form-login-toggle,
.woocommerce-checkout .entry-content > .woocommerce > .woocommerce-form-coupon-toggle,
.woocommerce-checkout .entry-content > .woocommerce > .woocommerce-notices-wrapper {
    grid-column: 1 / -1 !important;
}

.woocommerce-checkout .entry-content > .woocommerce > #customer_details {
    grid-column: 1 !important;
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    border: 1px solid var(--tst-gray-300) !important;
    padding: 1.5rem 2rem !important;
}

.woocommerce-checkout .entry-content > .woocommerce > #order_review_heading,
.woocommerce-checkout .entry-content > .woocommerce > #order_review {
    grid-column: 2 !important;
}

.woocommerce-checkout #order_review_heading {
    margin-top: 0 !important;
}

.woocommerce-checkout #order_review {
    position: sticky !important;
    top: 6rem !important;
}

/* Traditional cart — two-column grid layout */
.woocommerce-cart .entry-content > .woocommerce {
    display: grid !important;
    grid-template-columns: 1fr 340px !important;
    gap: 2rem !important;
    align-items: start !important;
}

.woocommerce-cart .entry-content > .woocommerce > .woocommerce-notices-wrapper {
    grid-column: 1 / -1 !important;
}

.woocommerce-cart .woocommerce-cart-form {
    grid-column: 1 !important;
}

.woocommerce-cart .cart-collaterals {
    grid-column: 2 !important;
    grid-row: 2 / span 2 !important;
    margin-top: 0 !important;
    position: sticky !important;
    top: 6rem !important;
}

.woocommerce-cart .cart-collaterals .cart_totals {
    max-width: 100% !important;
    margin-left: 0 !important;
}

/* Account page layout */
.woocommerce-account .site-content {
    padding-top: 0 !important;
}

.woocommerce-account .entry-header {
    background: var(--tst-gray-100) !important;
    padding: 2rem 0 1.5rem !important;
    margin-bottom: 2rem !important;
}

.woocommerce-account .entry-title,
.woocommerce-account .wp-block-post-title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 1.75rem !important;
    font-weight: 800 !important;
}

.woocommerce-account .entry-content > .woocommerce {
    display: grid !important;
    grid-template-columns: 240px 1fr !important;
    gap: 2rem !important;
    align-items: start !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .u-column1,
.woocommerce-account .u-column2 {
    min-width: 0 !important;
}

.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register,
.woocommerce-account .u-column1,
.woocommerce-account .u-column2 {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    padding: 1.5rem !important;
}

.woocommerce-account .woocommerce-MyAccount-content {
    display: block !important;
    min-height: 260px !important;
    color: var(--tst-gray-700) !important;
}

.woocommerce-account .woocommerce-MyAccount-content p,
.woocommerce-account .woocommerce-MyAccount-content li,
.woocommerce-account .woocommerce-MyAccount-content strong,
.woocommerce-account .woocommerce-MyAccount-content span,
.woocommerce-account .woocommerce-MyAccount-content div {
    color: inherit;
}

.woocommerce-account .u-columns {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2rem !important;
}

.woocommerce-account .u-column1,
.woocommerce-account .u-column2 {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

@media (max-width: 991px) {
    .woocommerce-cart .entry-content > .woocommerce {
        grid-template-columns: 1fr !important;
    }

    .woocommerce-cart .woocommerce-cart-form,
    .woocommerce-cart .cart-collaterals {
        grid-column: 1 !important;
    }

    .woocommerce-cart .cart-collaterals {
        grid-row: auto !important;
        position: static !important;
    }

    .woocommerce-checkout .entry-content > .woocommerce {
        grid-template-columns: 1fr !important;
    }

    .woocommerce-checkout .entry-content > .woocommerce > #customer_details,
    .woocommerce-checkout .entry-content > .woocommerce > #order_review_heading,
    .woocommerce-checkout .entry-content > .woocommerce > #order_review {
        grid-column: 1 !important;
    }

    .woocommerce-checkout #order_review {
        position: static !important;
    }

    .woocommerce-account .entry-content > .woocommerce {
        grid-template-columns: 1fr !important;
    }

    .woocommerce-account .u-columns {
        grid-template-columns: 1fr !important;
    }
}

/* --- CART PAGE --- */

/* Cart table wrapper */
.woocommerce table.shop_table {
    border: none !important;
    border-radius: var(--tst-radius) !important;
    overflow: hidden !important;
    box-shadow: var(--tst-shadow) !important;
    background: #fff !important;
}

.woocommerce table.shop_table thead {
    background: var(--tst-gray-100) !important;
}

.woocommerce table.shop_table thead th {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    font-size: 0.8rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    color: var(--tst-gray-700) !important;
    padding: 1rem 1.25rem !important;
    border: none !important;
}

.woocommerce table.shop_table td {
    padding: 1.25rem !important;
    border-top: 1px solid var(--tst-gray-100) !important;
    border-left: none !important;
    border-right: none !important;
    border-bottom: none !important;
    vertical-align: middle !important;
    font-size: 0.95rem !important;
}

.woocommerce table.shop_table .product-name {
    font-weight: 600 !important;
    color: var(--tst-gray-900) !important;
}

.woocommerce table.shop_table .product-name a {
    color: var(--tst-gray-900) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
}

.woocommerce table.shop_table .product-name a:hover {
    color: var(--tst-green) !important;
}

/* Cart product thumbnails */
.woocommerce table.shop_table .product-thumbnail img {
    border-radius: var(--tst-radius-sm) !important;
    width: 80px !important;
    height: 80px !important;
    object-fit: cover !important;
}

/* Cart item meta (tour date, adults etc) */
.woocommerce table.shop_table dl.variation {
    margin: 0.5rem 0 0 !important;
    font-size: 0.85rem !important;
}

.woocommerce table.shop_table dl.variation dt {
    font-weight: 600 !important;
    color: var(--tst-gray-700) !important;
    margin-right: 0.25rem !important;
    float: left !important;
    clear: left !important;
}

.woocommerce table.shop_table dl.variation dd {
    margin: 0 0 0.35rem !important;
    color: var(--tst-gray-900) !important;
}

.woocommerce table.shop_table dl.variation dd p {
    margin: 0 !important;
}

/* Cart price */
.woocommerce table.shop_table .product-price .amount,
.woocommerce table.shop_table .product-subtotal .amount {
    font-weight: 700 !important;
    color: var(--tst-green-dark) !important;
    font-size: 1.05rem !important;
}

/* Quantity controls in cart */
.woocommerce .quantity {
    display: inline-flex !important;
    align-items: center !important;
    border: 2px solid var(--tst-gray-300) !important;
    border-radius: var(--tst-radius-sm) !important;
    overflow: hidden !important;
}

.woocommerce .quantity .qty {
    width: 3rem !important;
    text-align: center !important;
    border: none !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    padding: 0.4rem !important;
    appearance: textfield !important;
    -moz-appearance: textfield !important;
}

.woocommerce .quantity .qty::-webkit-outer-spin-button,
.woocommerce .quantity .qty::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
}

/* Remove item link */
.woocommerce table.shop_table .product-remove a.remove {
    color: var(--tst-gray-500) !important;
    font-size: 1.25rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: var(--tst-gray-100) !important;
    transition: all var(--tst-transition) !important;
}

.woocommerce table.shop_table .product-remove a.remove:hover {
    background: #FFEBEE !important;
    color: #C62828 !important;
}

/* Cart totals sidebar */
.woocommerce .cart-collaterals .cart_totals,
.cart_totals {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    padding: 1.5rem !important;
    border: 1px solid var(--tst-gray-100) !important;
}

.woocommerce .cart-collaterals .cart_totals h2,
.cart_totals h2 {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.15rem !important;
    margin: 0 0 1rem !important;
    padding-bottom: 0.75rem !important;
    border-bottom: 2px solid var(--tst-gray-100) !important;
    color: var(--tst-gray-900) !important;
}

.woocommerce .cart-collaterals .cart_totals table {
    border: none !important;
    box-shadow: none !important;
}

.woocommerce .cart-collaterals .cart_totals table th,
.woocommerce .cart-collaterals .cart_totals table td {
    border: none !important;
    padding: 0.75rem 0 !important;
    border-bottom: 1px solid var(--tst-gray-100) !important;
}

.woocommerce .cart-collaterals .cart_totals table th {
    font-weight: 600 !important;
    color: var(--tst-gray-700) !important;
    font-size: 0.9rem !important;
}

.woocommerce .cart-collaterals .cart_totals .order-total th,
.woocommerce .cart-collaterals .cart_totals .order-total td {
    font-size: 1.15rem !important;
    font-weight: 800 !important;
    color: var(--tst-gray-900) !important;
    border-bottom: none !important;
    padding-top: 1rem !important;
}

.woocommerce .cart-collaterals .cart_totals .order-total .amount {
    color: var(--tst-green-dark) !important;
    font-size: 1.35rem !important;
}

/* Proceed to checkout button */
.woocommerce .wc-proceed-to-checkout a.checkout-button,
.woocommerce a.checkout-button {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    padding: 1rem 2rem !important;
    background: var(--tst-green) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    text-decoration: none !important;
    transition: all var(--tst-transition) !important;
    margin-top: 1rem !important;
}

.woocommerce .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce a.checkout-button:hover {
    background: var(--tst-green-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(76,175,80,0.3) !important;
}

/* Coupon form */
.woocommerce .cart .coupon {
    display: flex !important;
    gap: 0.5rem !important;
    align-items: center !important;
    flex-wrap: wrap !important;
}

.woocommerce .cart .coupon input.input-text {
    border: 2px solid var(--tst-gray-300) !important;
    border-radius: var(--tst-radius-sm) !important;
    padding: 0.6rem 1rem !important;
    font-size: 0.9rem !important;
    transition: border-color var(--tst-transition) !important;
}

.woocommerce .cart .coupon input.input-text:focus {
    border-color: var(--tst-green) !important;
    outline: none !important;
}

.woocommerce .cart .coupon .button {
    background: var(--tst-gray-900) !important;
    color: #fff !important;
    font-weight: 600 !important;
    padding: 0.6rem 1.25rem !important;
}

/* Update cart button */
.woocommerce .cart button[name="update_cart"] {
    background: var(--tst-gray-100) !important;
    color: var(--tst-gray-700) !important;
    border: 2px solid var(--tst-gray-300) !important;
    font-weight: 600 !important;
    padding: 0.6rem 1.25rem !important;
}

.woocommerce .cart button[name="update_cart"]:hover {
    background: var(--tst-gray-900) !important;
    color: #fff !important;
    border-color: var(--tst-gray-900) !important;
}

/* --- CHECKOUT PAGE --- */

/* Checkout layout */
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
    background: var(--tst-gray-100) !important;
    border-top: 3px solid var(--tst-green) !important;
    padding: 1rem 1.5rem !important;
    border-radius: var(--tst-radius-sm) !important;
    margin-bottom: 1.5rem !important;
    font-size: 0.9rem !important;
}

.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info a,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a {
    color: var(--tst-green) !important;
    font-weight: 600 !important;
}

/* Billing / Shipping two-column inside #customer_details */
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
    width: 100% !important;
    float: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.woocommerce-checkout #customer_details .col-2 {
    margin-top: 1.5rem !important;
}

/* Checkout form sections */
.woocommerce-checkout #customer_details h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3,
.woocommerce-checkout #order_review_heading {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.25rem !important;
    color: var(--tst-gray-900) !important;
    margin: 2rem 0 1rem !important;
    padding-bottom: 0.75rem !important;
    border-bottom: 2px solid var(--tst-gray-100) !important;
}

/* Form fields */
.woocommerce form .form-row label {
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    color: var(--tst-gray-700) !important;
    margin-bottom: 0.35rem !important;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout .select2-container--default .select2-selection--single {
    border: 2px solid var(--tst-gray-300) !important;
    border-radius: var(--tst-radius-sm) !important;
    padding: 0.75rem 1rem !important;
    font-size: 0.95rem !important;
    transition: border-color var(--tst-transition) !important;
    background: #fff !important;
    font-family: 'Inter', sans-serif !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
    border-color: var(--tst-green) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(76,175,80,0.1) !important;
}

/* Order review table */
.woocommerce-checkout #order_review {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    padding: 1.5rem !important;
    border: 1px solid var(--tst-gray-100) !important;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table {
    border: none !important;
    box-shadow: none !important;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table thead th {
    background: transparent !important;
    border-bottom: 2px solid var(--tst-gray-100) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    font-size: 0.8rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    padding: 0.75rem 0 !important;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table td {
    padding: 1rem 0 !important;
    border-bottom: 1px solid var(--tst-gray-100) !important;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total td {
    font-size: 1.15rem !important;
    font-weight: 800 !important;
    border-top: 2px solid var(--tst-gray-900) !important;
    padding-top: 1.25rem !important;
}

.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total .amount {
    color: var(--tst-green-dark) !important;
    font-size: 1.4rem !important;
}

/* Payment methods */
.woocommerce-checkout #payment {
    background: var(--tst-gray-100) !important;
    border-radius: var(--tst-radius) !important;
    padding: 1.5rem !important;
    margin-top: 1.5rem !important;
}

.woocommerce-checkout #payment ul.payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 1rem !important;
    border: none !important;
}

.woocommerce-checkout #payment ul.payment_methods li {
    background: #fff !important;
    border-radius: var(--tst-radius-sm) !important;
    padding: 1rem 1.25rem !important;
    margin-bottom: 0.75rem !important;
    border: 2px solid var(--tst-gray-300) !important;
    transition: border-color var(--tst-transition) !important;
}

.woocommerce-checkout #payment ul.payment_methods li:has(input:checked) {
    border-color: var(--tst-green) !important;
    box-shadow: 0 0 0 3px rgba(76,175,80,0.1) !important;
}

.woocommerce-checkout #payment .payment_method_payfast label {
    font-weight: 600 !important;
    font-size: 0.95rem !important;
    cursor: pointer !important;
}

.woocommerce-checkout #payment div.payment_box {
    background: transparent !important;
    padding: 0.75rem 0 0 1.75rem !important;
    color: var(--tst-gray-700) !important;
    font-size: 0.9rem !important;
}

.woocommerce-checkout #payment div.payment_box::before {
    display: none !important;
}

/* Place order button */
.woocommerce-checkout #payment #place_order,
.woocommerce .button.alt,
.woocommerce a.button.alt,
.wc-block-components-button.wc-block-components-checkout-place-order-button,
.wp-element-button.wc-block-components-checkout-place-order-button {
    display: block !important;
    width: 100% !important;
    padding: 1.1rem 2rem !important;
    background: var(--tst-green) !important;
    border: none !important;
    border-color: var(--tst-green) !important;
    color: #fff !important;
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.05rem !important;
    text-align: center !important;
    cursor: pointer !important;
    transition: all var(--tst-transition) !important;
    text-decoration: none !important;
}

.woocommerce-checkout #payment #place_order:hover,
.woocommerce .button.alt:hover,
.woocommerce a.button.alt:hover,
.wc-block-components-button.wc-block-components-checkout-place-order-button:hover,
.wp-element-button.wc-block-components-checkout-place-order-button:hover {
    background: var(--tst-green-dark) !important;
    border-color: var(--tst-green-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(76,175,80,0.3) !important;
}

/* General WC buttons */
.woocommerce .button,
.woocommerce a.button {
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    transition: all var(--tst-transition) !important;
}

/* Notices */
.woocommerce-message {
    border-top-color: var(--tst-green) !important;
    background: #E8F5E9 !important;
    border-radius: var(--tst-radius-sm) !important;
    padding: 1rem 1.5rem !important;
    font-size: 0.9rem !important;
}

.woocommerce-message::before {
    color: var(--tst-green) !important;
}

.woocommerce-error {
    border-top-color: #C62828 !important;
    background: #FFEBEE !important;
    border-radius: var(--tst-radius-sm) !important;
}

.woocommerce-info {
    border-top-color: var(--tst-green) !important;
    border-radius: var(--tst-radius-sm) !important;
}

/* --- BLOCK-BASED CART & CHECKOUT (WooCommerce Blocks) --- */

/* 
   WC Blocks use their own internal grid (main + sidebar).
   We only need to: constrain the outer wrapper, style the cards, and
   NOT override the grid display property that WC sets.
*/

/* Block Cart — let WC handle its own layout, just style the cards */
.wc-block-cart .wc-block-cart__main {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    border: 1px solid var(--tst-gray-300) !important;
    padding: 1.5rem !important;
}

.wc-block-cart .wc-block-cart__sidebar {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    border: 1px solid var(--tst-gray-300) !important;
    padding: 1.5rem !important;
    position: sticky !important;
    top: 6rem !important;
}

.wc-block-cart .wc-block-components-product-name {
    font-weight: 600 !important;
    color: var(--tst-gray-900) !important;
    text-decoration: none !important;
    font-size: 0.95rem !important;
}

.wc-block-cart .wc-block-components-product-name:hover {
    color: var(--tst-green) !important;
}

.wc-block-cart .wc-block-components-product-price .wc-block-components-formatted-money-amount {
    font-weight: 700 !important;
    color: var(--tst-green-dark) !important;
}

.wc-block-cart .wc-block-components-product-metadata {
    font-size: 0.8rem !important;
    color: var(--tst-gray-500) !important;
    line-height: 1.5 !important;
}

.wc-block-cart .wc-block-cart__submit-button {
    background: var(--tst-green) !important;
    border-color: var(--tst-green) !important;
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    padding: 1rem 2rem !important;
    transition: all var(--tst-transition) !important;
}

.wc-block-cart .wc-block-cart__submit-button:hover {
    background: var(--tst-green-dark) !important;
    border-color: var(--tst-green-dark) !important;
}

.wc-block-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-weight: 800 !important;
    font-size: 1.25rem !important;
    color: var(--tst-green-dark) !important;
}

.wc-block-cart .wc-block-components-totals-item__label {
    font-weight: 600 !important;
}

/* Block Checkout — let WC Blocks handle its own layout, just style the cards */
.wc-block-checkout .wc-block-checkout__main {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    border: 1px solid var(--tst-gray-300) !important;
    padding: 2rem !important;
}

.wc-block-checkout .wc-block-checkout__sidebar {
    position: sticky !important;
    top: 6rem !important;
}

.wc-block-checkout .wc-block-components-checkout-step__heading {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.1rem !important;
    color: var(--tst-gray-900) !important;
}

.wc-block-checkout .wc-block-components-checkout-step {
    padding-bottom: 1.5rem !important;
    margin-bottom: 1.5rem !important;
    border-bottom: 1px solid var(--tst-gray-100) !important;
}

.wc-block-checkout .wc-block-components-checkout-step:last-child {
    border-bottom: none !important;
    margin-bottom: 0 !important;
}

.wc-block-checkout .wc-block-components-text-input input,
.wc-block-checkout .wc-block-components-text-input textarea,
.wc-block-checkout .wc-block-components-combobox input,
.wc-block-checkout select {
    border: 1.5px solid var(--tst-gray-300) !important;
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Inter', sans-serif !important;
}

.wc-block-checkout .wc-block-components-text-input input:focus,
.wc-block-checkout .wc-block-components-combobox input:focus,
.wc-block-checkout select:focus {
    border-color: var(--tst-green) !important;
    box-shadow: 0 0 0 3px rgba(76,175,80,0.1) !important;
    outline: none !important;
}

/* Order summary in sidebar */
.wc-block-checkout .wc-block-components-order-summary {
    border-radius: var(--tst-radius) !important;
    background: #fff !important;
    border: 1px solid var(--tst-gray-300) !important;
    overflow: hidden !important;
}

.wc-block-checkout .wc-block-components-order-summary .wc-block-components-panel__button {
    padding: 1rem 1.25rem !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
}

.wc-block-components-order-summary-item {
    padding: 0.75rem 0 !important;
}

.wc-block-components-order-summary-item__image {
    border-radius: var(--tst-radius-sm) !important;
    overflow: hidden !important;
}

.wc-block-components-order-summary-item__description {
    font-size: 0.85rem !important;
}

/* Totals in checkout sidebar */
.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-size: 1.35rem !important;
    font-weight: 800 !important;
    color: var(--tst-green-dark) !important;
    font-family: 'Poppins', sans-serif !important;
}

.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
    font-weight: 700 !important;
    font-size: 1rem !important;
}

/* Place order button */
.wc-block-checkout .wc-block-components-checkout-place-order-button,
.wc-block-checkout .wp-element-button.wc-block-components-checkout-place-order-button {
    background: var(--tst-green) !important;
    border-color: var(--tst-green) !important;
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    padding: 1rem 2rem !important;
    transition: all var(--tst-transition) !important;
    width: 100% !important;
}

.wc-block-checkout .wc-block-components-checkout-place-order-button:hover,
.wc-block-checkout .wp-element-button.wc-block-components-checkout-place-order-button:hover {
    background: var(--tst-green-dark) !important;
    border-color: var(--tst-green-dark) !important;
    box-shadow: 0 4px 16px rgba(76,175,80,0.3) !important;
}

/* Payment methods */
.wc-block-checkout .wc-block-components-radio-control__option {
    padding: 1rem !important;
    border: 1.5px solid var(--tst-gray-300) !important;
    border-radius: var(--tst-radius-sm) !important;
    margin-bottom: 0.5rem !important;
}

.wc-block-checkout .wc-block-components-radio-control__option--checked {
    border-color: var(--tst-green) !important;
    background: rgba(76,175,80,0.04) !important;
}

.wc-block-checkout .wc-block-components-payment-method-label {
    font-weight: 600 !important;
}

/* Coupon */
.wc-block-components-totals-coupon__button {
    background: var(--tst-green) !important;
    border-color: var(--tst-green) !important;
    border-radius: var(--tst-radius-sm) !important;
    font-weight: 600 !important;
}

.wc-block-components-totals-coupon__button:hover {
    background: var(--tst-green-dark) !important;
}

/* Booking details in cart/checkout */
.woocommerce-cart-form__cart-item .tst-cart-pax {
    display: inline-block;
    background: var(--tst-green);
    color: #fff;
    padding: 0.2rem 0.6rem;
    border-radius: var(--tst-radius-sm);
    font-size: 0.75rem;
    font-weight: 600;
}

/* Order summary tour details in checkout blocks */
.wc-block-components-order-summary-item__description dl {
    margin: 0.25rem 0 0 !important;
    font-size: 0.8rem !important;
    line-height: 1.6 !important;
}

.wc-block-components-order-summary-item__description dt {
    font-weight: 600 !important;
    color: var(--tst-gray-700) !important;
}

.wc-block-components-order-summary-item__description dd {
    margin: 0 0 0.15rem 0 !important;
    color: var(--tst-gray-900) !important;
}

/* WC Notices in block pages */
.wc-block-components-notice-banner {
    border-radius: var(--tst-radius-sm) !important;
    padding: 1rem 1.25rem !important;
    margin-bottom: 1.5rem !important;
}

.wc-block-components-notice-banner.is-error {
    border-left: 4px solid #d32f2f !important;
    background: #fff5f5 !important;
}

.wc-block-components-notice-banner.is-success {
    border-left: 4px solid var(--tst-green) !important;
    background: #f0faf0 !important;
}

.wc-block-components-notice-banner.is-info {
    border-left: 4px solid #1976d2 !important;
    background: #f0f7ff !important;
}

/* Thank-you page: booking details */
.tst-booking-header {
    font-family: 'Poppins', sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
    margin: 2rem 0 1rem;
    color: var(--tst-gray-900);
    border-bottom: 2px solid var(--tst-green);
    padding-bottom: 0.5rem;
}

.tst-order-booking {
    background: var(--tst-gray-100);
    border-radius: var(--tst-radius);
    padding: 1.25rem;
    margin-bottom: 1rem;
}

.tst-order-booking h3 {
    font-size: 1.05rem;
    margin: 0 0 0.75rem;
    color: var(--tst-green-dark);
}

.tst-order-booking table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.tst-order-booking th {
    text-align: left;
    padding: 0.4rem 0.75rem;
    color: var(--tst-gray-500);
    font-weight: 600;
    width: 35%;
    border-bottom: 1px solid var(--tst-gray-300);
}

.tst-order-booking td {
    padding: 0.4rem 0.75rem;
    color: var(--tst-gray-900);
    border-bottom: 1px solid var(--tst-gray-300);
}

/* My Account page */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    overflow: hidden !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    border-bottom: 1px solid var(--tst-gray-100) !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child {
    border-bottom: none !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block !important;
    padding: 0.85rem 1.25rem !important;
    color: var(--tst-gray-700) !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: all var(--tst-transition) !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
    background: rgba(76,175,80,0.06) !important;
    color: var(--tst-green) !important;
    padding-left: 1.5rem !important;
}

.woocommerce-account .woocommerce-MyAccount-content > :first-child,
.woocommerce-account .woocommerce-form-login > :first-child,
.woocommerce-account .woocommerce-form-register > :first-child {
    margin-top: 0 !important;
}

.woocommerce-account .woocommerce-MyAccount-content a,
.woocommerce-account .lost_password a {
    color: var(--tst-green-dark) !important;
}

.tst-account-dashboard {
    display: grid;
    gap: 1rem;
}

.tst-account-dashboard h2 {
    margin: 0;
    font-size: 1.4rem;
}

.tst-account-dashboard p {
    margin: 0;
}

.tst-account-dashboard__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.tst-account-dashboard__card {
    display: grid;
    gap: 0.35rem;
    padding: 1rem 1.1rem;
    border: 1px solid var(--tst-gray-300);
    border-radius: var(--tst-radius-sm);
    background: var(--tst-gray-100);
    text-decoration: none !important;
    transition: transform var(--tst-transition), box-shadow var(--tst-transition), border-color var(--tst-transition);
}

.tst-account-dashboard__card:hover {
    transform: translateY(-2px);
    border-color: rgba(76, 175, 80, 0.35);
    box-shadow: var(--tst-shadow);
}

.tst-account-dashboard__card strong {
    color: var(--tst-gray-900) !important;
}

.tst-account-dashboard__card span {
    color: var(--tst-gray-700) !important;
    font-size: 0.92rem;
}

@media (max-width: 767px) {
    .tst-account-dashboard__grid {
        grid-template-columns: 1fr;
    }
}

/* Empty cart message */
.woocommerce .cart-empty,
.wc-block-cart__empty-cart__title {
    text-align: center !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.35rem !important;
    color: var(--tst-gray-900) !important;
    padding: 3rem 0 1rem !important;
}

.woocommerce .return-to-shop a,
.wc-block-cart__empty-cart__button {
    display: inline-flex !important;
    padding: 0.85rem 2rem !important;
    background: var(--tst-green) !important;
    color: #fff !important;
    border-radius: var(--tst-radius-sm) !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    transition: all var(--tst-transition) !important;
}

.woocommerce .return-to-shop a:hover,
.wc-block-cart__empty-cart__button:hover {
    background: var(--tst-green-dark) !important;
}

/* Responsive WC */
@media (max-width: 991px) {
    .tst-wc-page .site-content > .grid-container {
        padding: 0 1rem !important;
    }

    .wc-block-checkout .wc-block-checkout__main {
        padding: 1.25rem !important;
    }
}

@media (max-width: 767px) {
    .tst-wc-page .site-content > .grid-container {
        padding: 0 0.75rem !important;
    }

    .tst-wc-page .entry-title {
        font-size: 1.5rem !important;
        margin: 1.25rem 0 1rem !important;
    }

    .wc-block-checkout .wc-block-checkout__main {
        padding: 1rem !important;
        border-radius: var(--tst-radius-sm) !important;
    }

    .wc-block-cart .wc-block-cart__main,
    .wc-block-cart .wc-block-cart__sidebar {
        padding: 1rem !important;
    }

    .wc-block-checkout .wc-block-components-checkout-step {
        padding-bottom: 1rem !important;
        margin-bottom: 1rem !important;
    }

    .woocommerce table.shop_table td {
        padding: 0.75rem !important;
    }

    /* Cart table: vertical card layout on mobile */
    .woocommerce-cart table.shop_table,
    .woocommerce-cart table.shop_table thead,
    .woocommerce-cart table.shop_table tbody,
    .woocommerce-cart table.shop_table tr,
    .woocommerce-cart table.shop_table td,
    .woocommerce-cart table.shop_table th {
        display: block !important;
        width: 100% !important;
    }

    .woocommerce-cart table.shop_table thead {
        display: none !important;
    }

    .woocommerce-cart table.shop_table tbody tr {
        border: 1px solid var(--tst-gray-200, #e5e5e5) !important;
        border-radius: var(--tst-radius) !important;
        padding: 1rem !important;
        margin-bottom: 1rem !important;
        background: #fff !important;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04) !important;
    }

    .woocommerce-cart table.shop_table td {
        border: none !important;
        padding: 0.4rem 0 !important;
        text-align: left !important;
    }

    .woocommerce-cart table.shop_table td.product-thumbnail {
        text-align: center !important;
        padding-bottom: 0.75rem !important;
    }

    .woocommerce-cart table.shop_table td.product-thumbnail img {
        width: 100px !important;
        height: 100px !important;
    }

    .woocommerce-cart table.shop_table td.product-name {
        font-size: 1rem !important;
    }

    .woocommerce-cart table.shop_table td.product-price::before {
        content: 'Price: ';
        font-weight: 600;
        color: var(--tst-gray-500);
        font-size: 0.8rem;
    }

    .woocommerce-cart table.shop_table td.product-subtotal::before {
        content: 'Subtotal: ';
        font-weight: 600;
        color: var(--tst-gray-500);
        font-size: 0.8rem;
    }

    .woocommerce-cart table.shop_table td.product-remove {
        text-align: right !important;
        padding-top: 0.75rem !important;
        border-top: 1px solid var(--tst-gray-100) !important;
    }

    .woocommerce-cart table.shop_table td.actions {
        padding: 1rem 0 !important;
    }

    .woocommerce-cart table.shop_table .coupon {
        flex-direction: column !important;
    }

    .woocommerce-cart table.shop_table .coupon input.input-text {
        width: 100% !important;
    }
}

/* ==========================================================================
   GLOBAL: Links & interactive elements
   ========================================================================== */

a {
    color: var(--tst-green);
    transition: color var(--tst-transition);
}

a:hover {
    color: var(--tst-green-dark);
}

/* GP generates a "Built with GP" link in the footer — nuke it */
footer.site-footer .inside-site-info,
.site-footer .site-info,
.site-info {
    display: none !important;
}

/* ==========================================================================
   Mobile-First App Shell Overrides
   ========================================================================== */

:root {
    --tst-green: #94ba23;
    --tst-green-dark: #718f18;
    --tst-orange: #e2a900;
    --tst-orange-dark: #c89200;
    --tst-dark: #2b2a2f;
    --tst-app-bg: #f2eee2;
    --tst-surface: rgba(255, 255, 255, 0.94);
    --tst-surface-strong: #fbfaf6;
    --tst-border-soft: rgba(43, 42, 47, 0.08);
    --tst-text-soft: #66625d;
    --tst-radius: 10px;
    --tst-radius-sm: 6px;
}

html {
    scroll-padding-top: 76px;
}

body {
    background: var(--tst-app-bg);
    color: var(--tst-gray-900);
}

.site-content {
    background: transparent;
}

.tst-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.2);
    color: inherit;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.tst-section-heading {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.tst-section-heading h2 {
    margin: 0;
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    line-height: 1.05;
}

.tst-section-heading p {
    max-width: 38rem;
    margin: 0;
    color: var(--tst-text-soft);
    font-size: 0.98rem;
}

.tst-header__inner {
    margin-top: 0;
    padding: 0;
    min-height: 70px;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.tst-header__primary-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0.6rem 1.2rem;
    border-radius: 8px;
    background: var(--tst-orange);
    color: #1a1a2e !important;
    font-family: 'Poppins', sans-serif;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    box-shadow: none;
    transition: background 0.2s ease, transform 0.2s ease;
}

.tst-header__primary-cta:hover {
    color: #1a1a2e !important;
    background: var(--tst-orange-dark);
    transform: translateY(-1px);
}

.tst-header__mobile-quickbar {
    display: none !important;
}

.tst-header__logo-img,
.tst-footer__logo img,
.tst-footer__logo .custom-logo {
    filter: none !important;
}

.tst-header__logo-img {
    max-height: 46px;
    width: auto;
}

.tst-header__logo-img--fallback {
    max-width: min(220px, 58vw);
    object-fit: contain;
}

.tst-header__mobile-menu {
    margin-top: 0;
    border-radius: 0;
    background: var(--tst-dark);
}

.tst-app-page {
    position: relative;
}

.tst-section-block {
    padding: 3.75rem 0;
}

.tst-section-block--gray {
    background: #f7f3e8;
}

.tst-section-block--intro {
    padding-top: 0;
    margin-top: -3rem;
    z-index: 3;
}

.tst-hero {
    min-height: 100svh;
    align-items: flex-end;
}

.tst-hero__content {
    padding: 8rem 1rem 2.5rem;
}

.tst-hero__content .tst-container {
    max-width: 1120px;
}

.tst-hero__heading,
.tst-hero__subheading,
.tst-hero__actions,
.tst-hero__badges {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.65s ease, transform 0.65s ease;
}

.tst-page-ready .tst-hero__heading,
.tst-page-ready .tst-hero__subheading,
.tst-page-ready .tst-hero__actions,
.tst-page-ready .tst-hero__badges {
    opacity: 1;
    transform: translateY(0);
}

.tst-page-ready .tst-hero__subheading {
    transition-delay: 0.08s;
}

.tst-page-ready .tst-hero__actions {
    transition-delay: 0.14s;
}

.tst-page-ready .tst-hero__badges {
    transition-delay: 0.2s;
}

.tst-hero__heading {
    max-width: 12ch;
    margin-left: auto;
    margin-right: auto;
}

.tst-hero__subheading {
    max-width: 36rem;
}

.tst-hero__actions {
    justify-content: center;
}

.tst-hero__btn {
    min-height: 54px;
    border-radius: 14px;
    font-size: 0.96rem;
    font-weight: 700;
}

.tst-hero__btn--primary {
    box-shadow: none;
}

.tst-hero__badges {
    gap: 0.9rem;
}

.tst-hero__badge {
    min-width: 220px;
    text-align: left;
    padding: 0.9rem 1rem;
    border-radius: 14px;
    background: rgba(43, 42, 47, 0.54);
}

.tst-app-overview {
    display: grid;
    gap: 1.1rem;
    padding: 1rem;
    border-radius: 18px;
    background: #f8f4e9;
    box-shadow: 0 14px 30px rgba(43, 42, 47, 0.08);
}

.tst-app-overview__intro h2 {
    margin: 0.65rem 0 0.8rem;
    font-size: clamp(1.65rem, 5vw, 2.8rem);
    line-height: 1.04;
}

.tst-app-overview__intro p {
    margin: 0;
    max-width: 46rem;
    color: var(--tst-text-soft);
}

.tst-app-overview__actions {
    display: grid;
    gap: 0.9rem;
}

.tst-app-action-card {
    display: grid;
    gap: 0.75rem;
    min-width: 100%;
    padding: 1.15rem;
    border-radius: 16px;
    background: #fffdf8;
    color: var(--tst-gray-900) !important;
    border: 0;
    box-shadow: 0 10px 24px rgba(43, 42, 47, 0.06);
    transition: transform var(--tst-transition), box-shadow var(--tst-transition);
    text-decoration: none !important;
}

.tst-app-action-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 22px 48px rgba(26, 26, 46, 0.11);
}

.tst-app-action-card strong {
    font-family: 'Poppins', sans-serif;
    font-size: 1rem;
}

.tst-app-action-card small {
    color: var(--tst-text-soft);
    font-size: 0.88rem;
    line-height: 1.5;
    text-decoration: none;
}

.tst-app-action-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 12px;
    background: rgba(148, 186, 35, 0.12);
    color: var(--tst-green-dark);
}

.tst-app-action-card__icon svg {
    color: currentColor;
    stroke: currentColor;
}

.is-scrollable {
    cursor: grab;
}

.is-dragging {
    cursor: grabbing;
    user-select: none;
}

.tst-homepage-section:has(.tst-search) {
    position: relative;
    z-index: 10;
    overflow: visible;
}

.tst-search {
    position: relative;
    z-index: 10;
    border-radius: 18px;
    background: #fffdf8;
    border: 0;
    box-shadow: 0 12px 26px rgba(43, 42, 47, 0.06);
}

.tst-search__field input,
.tst-search__field select {
    min-height: 52px;
    border-radius: 16px;
    border-color: rgba(26, 26, 46, 0.1);
    background: rgba(255, 255, 255, 0.9);
}

.tst-search__submit .tst-btn {
    min-height: 52px;
    border-radius: 16px;
    width: 100%;
    justify-content: center;
}

/* Autocomplete suggestions override */
.tst-suggest {
    z-index: 9999;
    border-radius: 16px;
    border-color: rgba(26, 26, 46, 0.08);
    box-shadow: 0 16px 48px rgba(43, 42, 47, 0.14), 0 2px 8px rgba(43, 42, 47, 0.06);
    background: #fffdf8;
}

.tst-suggest__item:hover,
.tst-suggest__item--active {
    background: rgba(76, 175, 80, 0.06);
}

.tst-suggest__thumb {
    border-radius: 10px;
}

.tst-suggest__group-label {
    color: #7a7a7a;
}

.tst-suggest__item--tour .tst-suggest__thumb {
    width: 52px;
    height: 52px;
    border-radius: 12px;
}

/* Date input styling enhancements */
.tst-search__field--date input[type="date"] {
    cursor: pointer;
    color-scheme: light;
}

.tst-search__field--date input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0.5;
    cursor: pointer;
}

.tst-search__field--date input[type="date"]::-webkit-calendar-picker-indicator:hover {
    opacity: 0.8;
}

.tst-page__hero {
    padding: 6rem 0 2.5rem;
    background:
        radial-gradient(circle at top right, rgba(226, 169, 0, 0.18), transparent 28%),
        linear-gradient(180deg, #2b2a2f 0%, #353239 60%, #55661c 100%);
    border-radius: 0;
    overflow: hidden;
}

.tst-page__subtitle {
    color: rgba(255, 255, 255, 0.78);
}

.tst-value {
    padding: 1.5rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: 0 10px 20px rgba(43, 42, 47, 0.05);
}

.tst-mobile-dock {
    display: none;
}

.tst-header__primary-cta,
.tst-hero__btn,
.tst-cta-banner__btn,
.tst-app-action-card,
.tst-tour-card__link,
.tst-term-card,
.tst-footer__cta-btn,
.tst-footer__col a,
.tst-footer__contact-item a,
.tst-contact-card a,
.tst-mobile-dock__item,
.tst-whatsapp-btn,
.tst-drawer__browse-btn,
.tst-drawer__btn {
    text-decoration: none !important;
}

.tst-footer__cta {
    background: linear-gradient(135deg, var(--tst-green) 0%, var(--tst-green-dark) 100%);
}

.tst-footer__main {
    background: #26252b;
}

.tst-footer__cta-btn,
.tst-footer__social a {
    border-radius: 12px;
}

.tst-footer__logo img,
.tst-footer__logo .custom-logo {
    max-height: 58px !important;
}

@media (max-width: 899px) {
    body {
        padding-bottom: calc(62px + env(safe-area-inset-bottom));
    }

    .tst-front-page .site-header,
    .tst-front-page header.site-header {
        background: transparent !important;
    }

    .tst-header__inner {
        min-height: 56px;
        gap: 0.75rem;
    }

    .tst-header__logo-img {
        max-height: 34px;
    }

    .tst-header__site-name {
        font-size: 1rem !important;
    }

    .tst-header__primary-cta {
        display: none;
    }

    .tst-header__actions {
        gap: 0.5rem;
    }

    .tst-header__cart-btn,
    .tst-header__hamburger {
        width: 36px;
        height: 36px;
        border-radius: 50%;
        border: 1px solid rgba(255, 255, 255, 0.25);
        background: rgba(255, 255, 255, 0.15);
    }

    .tst-hero__content {
        padding: 5rem 1rem 1.75rem;
        text-align: left;
    }

    .tst-hero__heading,
    .tst-hero__subheading {
        margin-left: 0;
        margin-right: 0;
    }

    .tst-hero__heading {
        max-width: 10ch;
        font-size: clamp(2.6rem, 12vw, 4rem);
    }

    .tst-hero__subheading {
        font-size: 1rem;
    }

    .tst-hero__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .tst-hero__btn {
        width: 100%;
        justify-content: center;
    }

    .tst-hero__badges {
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: minmax(15.75rem, 86%);
        overflow-x: auto;
        padding-bottom: 0.35rem;
        scrollbar-width: none;
        -ms-overflow-style: none;
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth;
        scroll-padding-inline: 1rem;
        -webkit-overflow-scrolling: touch;
        touch-action: pan-x pinch-zoom;
    }

    .tst-hero__badges::-webkit-scrollbar {
        display: none;
    }

    .tst-hero__badge {
        scroll-snap-align: start;
        min-width: auto;
    }

    .tst-section-block {
        padding: 3rem 0;
    }

    .tst-section-block--intro {
        margin-top: -2rem;
    }

    .tst-app-overview {
        padding: 0.9rem;
        border-radius: 18px;
    }

    .tst-app-overview__actions {
        grid-auto-flow: column;
        grid-auto-columns: minmax(16rem, 84%);
        overflow-x: auto;
        padding-bottom: 0.35rem;
        scrollbar-width: none;
        -ms-overflow-style: none;
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth;
        scroll-padding-inline: 0.9rem;
        -webkit-overflow-scrolling: touch;
        touch-action: pan-x pinch-zoom;
    }

    .tst-app-overview__actions::-webkit-scrollbar {
        display: none;
    }

    .tst-app-action-card {
        scroll-snap-align: start;
    }

    .tst-homepage .tst-tour-grid,
    .tst-homepage .tst-term-grid,
    .tst-homepage .tst-stats,
    .tst-page-destinations .tst-tour-grid,
    .tst-page-destinations .tst-term-grid,
    .tst-page-about .tst-services-grid,
    .tst-page-about .tst-values-grid,
    .tst-page-contact .tst-contact-info {
        display: grid !important;
        grid-template-columns: none !important;
        grid-auto-flow: column;
        grid-auto-columns: minmax(15.75rem, 84%);
        gap: 1rem;
        overflow-x: auto;
        padding-bottom: 0.5rem;
        scrollbar-width: none;
        -ms-overflow-style: none;
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth;
        scroll-padding-inline: 1rem;
        -webkit-overflow-scrolling: touch;
        touch-action: pan-x pinch-zoom;
        overscroll-behavior-x: contain;
    }

    .tst-homepage .tst-tour-grid::-webkit-scrollbar,
    .tst-homepage .tst-term-grid::-webkit-scrollbar,
    .tst-homepage .tst-stats::-webkit-scrollbar,
    .tst-page-destinations .tst-tour-grid::-webkit-scrollbar,
    .tst-page-destinations .tst-term-grid::-webkit-scrollbar,
    .tst-page-about .tst-services-grid::-webkit-scrollbar,
    .tst-page-about .tst-values-grid::-webkit-scrollbar,
    .tst-page-contact .tst-contact-info::-webkit-scrollbar {
        display: none;
    }

    .tst-homepage .tst-tour-card,
    .tst-homepage .tst-term-card,
    .tst-homepage .tst-stat,
    .tst-page-destinations .tst-tour-card,
    .tst-page-destinations .tst-term-card,
    .tst-page-about .tst-service-card,
    .tst-page-about .tst-value,
    .tst-page-contact .tst-contact-card {
        scroll-snap-align: start;
    }

    .tst-homepage .tst-stats {
        margin-top: 0.5rem;
    }

    .tst-stat {
        min-width: 100%;
        padding: 1.35rem 1.15rem;
        border-radius: 16px;
        background: var(--tst-surface-strong);
        box-shadow: 0 10px 22px rgba(43, 42, 47, 0.06);
    }

    .tst-tour-card,
    .tst-term-card,
    .tst-service-card,
    .tst-contact-card,
    .tst-value {
        border-radius: 16px !important;
        box-shadow: 0 10px 24px rgba(43, 42, 47, 0.06);
    }

    .tst-page__hero {
        padding: 5rem 0 2rem;
        text-align: left;
        border-radius: 0;
    }

    .tst-page__subtitle {
        margin-left: 0;
    }

    .tst-footer__cta {
        padding-bottom: 1rem;
    }

    .tst-footer__cta-inner,
    .tst-footer__bottom-inner {
        gap: 1rem;
        text-align: left;
    }

    .tst-footer__cta-actions {
        width: 100%;
    }

    .tst-footer__cta-btn {
        flex: 1 1 calc(50% - 0.5rem);
        justify-content: center;
    }

    .tst-footer__grid {
        grid-template-columns: 1fr;
        gap: 1.75rem;
    }

    .tst-footer__nav-cluster-cols {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.5rem;
    }

    .tst-footer__nav-cluster-cols .tst-footer__col:nth-child(3) {
        grid-column: 1 / -1;
    }

    .tst-whatsapp-float {
        bottom: calc(72px + env(safe-area-inset-bottom));
    }

    .tst-mobile-dock {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 10002;
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 0;
        padding: 0.35rem 0.5rem calc(0.35rem + env(safe-area-inset-bottom));
        border-radius: 0;
        background: var(--tst-dark);
        border-top: 1px solid rgba(255, 255, 255, 0.06);
        box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.12);
    }

    .tst-mobile-dock__item {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0.25rem;
        min-height: 52px;
        border-radius: 0;
        color: rgba(255, 255, 255, 0.6) !important;
        font-size: 0.65rem;
        font-weight: 600;
        text-align: center;
        letter-spacing: 0.02em;
        transition: color 0.2s ease;
    }

    .tst-mobile-dock__item svg {
        color: currentColor;
        stroke: currentColor;
    }

    .tst-mobile-dock__item.is-active,
    .tst-mobile-dock__item--accent {
        background: transparent;
        color: var(--tst-green) !important;
    }
}

@media (min-width: 900px) {
    .tst-app-overview__actions {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .tst-page__hero {
        text-align: center;
    }
}

@media (prefers-reduced-motion: reduce) {
    .tst-hero__heading,
    .tst-hero__subheading,
    .tst-hero__actions,
    .tst-hero__badges {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* ==========================================================================
   Flat Header — Responsive Corrections
   ========================================================================== */

.site-header,
header.site-header {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.tst-header {
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 1rem;
}

.tst-header__inner {
    margin-top: 0;
    min-height: 70px;
    padding: 0;
    gap: 1.5rem;
    border-radius: 0;
    background: transparent;
    border: none;
    box-shadow: none;
    position: relative;
}

.tst-header__inner::before {
    display: none;
}

.tst-header__brand {
    min-width: 0;
}

.tst-header__logo-link {
    gap: 0.8rem;
}

.tst-header__site-name {
    font-size: 1.2rem !important;
    font-weight: 800 !important;
    line-height: 1;
}

.tst-header__nav {
    min-width: 0;
}

.tst-header__menu {
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.15rem;
}

.tst-header__menu > li > a,
.tst-header__menu > li > a:link,
.tst-header__menu > li > a:visited {
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: #e2a901 !important;
}

.tst-header__menu > li > a:hover,
.tst-header__menu > li.current-menu-item > a,
.tst-header__menu > li.current_page_item > a {
    background:rgb(148 186 35) !important;
    color: #ffffff !important;
}

.tst-header__actions {
    gap: 0.65rem;
}

.tst-header__primary-cta {
    min-height: 40px;
    padding: 0.65rem 1.25rem;
    border-radius: 8px;
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    box-shadow: none;
}

.tst-header__cart-btn {
    position: relative;
    overflow: visible;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    box-shadow: none;
}

.tst-header__cart-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.tst-header__cart-icon svg,
.tst-header__cart-btn svg {
    width: 20px;
    height: 20px;
    color: rgb(226 169 1) !important;
    stroke: currentColor;
    flex-shrink: 0;
}

.tst-header__cart-count {
    top: -4px;
    right: -4px;
    min-width: 20px;
    height: 20px;
    box-shadow: none;
}

.tst-front-page .site-header .tst-header__inner,
.tst-front-page header.site-header .tst-header__inner {
    background: transparent;
    border: none;
}

.tst-front-page .site-header.tst-header-scrolled .tst-header__inner,
.tst-front-page header.site-header.tst-header-scrolled .tst-header__inner {
    background: transparent;
}

@media (max-width: 1180px) {
    .tst-header__inner {
        min-height: 64px;
        gap: 1rem;
    }

    .tst-header__site-name {
        font-size: 1.05rem !important;
    }

    .tst-header__menu > li > a,
    .tst-header__menu > li > a:link,
    .tst-header__menu > li > a:visited {
        padding: 0.45rem 0.55rem;
        font-size: 0.76rem;
    }

    .tst-header__primary-cta {
        padding: 0.6rem 1rem;
        font-size: 0.76rem;
    }
}

@media (max-width: 1024px) {
    .tst-header__nav {
        display: none !important;
    }

    .tst-header__hamburger {
        display: flex !important;
    }

    .tst-header__primary-cta {
        display: none !important;
    }

    .tst-header__mobile-quickbar {
        display: block;
        padding: 0.75rem 0 0;
    }
}

@media (min-width: 1025px) {
    .tst-header__mobile-quickbar,
    .tst-header__mobile-menu,
    .tst-mobile-dock,
    .tst-section-block--intro {
        display: none !important;
    }

    .tst-header__nav {
        display: block !important;
    }

    .tst-header__hamburger {
        display: none !important;
    }
}

@media (max-width: 1024px) {
    body {
        padding-bottom: calc(62px + env(safe-area-inset-bottom));
    }

    .tst-header__inner {
        min-height: 58px;
        gap: 0.75rem;
    }

    .tst-header__logo-img {
        max-height: 36px;
    }

    .tst-header__site-name {
        font-size: 1rem !important;
        max-width: 11.5rem;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .tst-header__actions {
        margin-left: auto;
        gap: 0.5rem;
    }

    .tst-header__cart-btn,
    .tst-header__hamburger {
        width: 38px;
        height: 38px;
        border-radius: 50%;
    }
}

@media (max-width: 899px) {
    .tst-section-block--intro {
        display: block !important;
    }

    .tst-mobile-dock {
        display: grid !important;
    }
}

/* ==========================================================================
   Hero Slider Final Overrides
   ========================================================================== */

.tst-hero {
    min-height: 100svh;
    min-height: 100dvh;
    align-items: flex-end;
    background: #1d2436;
}

.tst-hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.tst-hero__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    visibility: hidden;
    transform: scale(1.035);
    transition:
        opacity 0.85s ease,
        transform 6s ease,
        visibility 0s linear 0.85s;
    will-change: opacity, transform;
}

.tst-hero__slide.is-active {
    opacity: 1;
    visibility: visible;
    transform: scale(1);
    transition:
        opacity 0.85s ease,
        transform 6s ease,
        visibility 0s linear 0s;
}

.tst-hero__image,
.tst-hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tst-hero__slide--image::after,
.tst-hero__slide--video::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top right, rgba(226, 169, 0, 0.22), transparent 30%),
        linear-gradient(115deg, rgba(12, 18, 32, 0.8) 12%, rgba(15, 28, 48, 0.48) 46%, rgba(26, 77, 45, 0.22) 100%);
}

.tst-hero__overlay {
    z-index: 1;
    background:
        linear-gradient(180deg, rgba(9, 14, 24, 0.14) 0%, rgba(9, 14, 24, 0.36) 40%, rgba(15, 20, 32, 0.76) 100%);
}

.tst-hero__content {
    position: relative;
    z-index: 2;
    padding: 8.75rem 1rem 3rem;
    text-align: left;
}

.tst-hero__content .tst-container {
    max-width: 1120px;
}

.tst-hero__heading {
    max-width: 11ch;
    margin: 0 0 1rem;
    font-size: clamp(3rem, 7vw, 5.5rem);
    line-height: 0.96;
    text-wrap: balance;
}

.tst-hero__subheading {
    max-width: 41rem;
    margin: 0 0 2rem;
    color: rgba(255, 255, 255, 0.86);
    font-size: clamp(1rem, 1.8vw, 1.2rem);
}

.tst-hero__actions {
    justify-content: flex-start;
    margin-bottom: 2.2rem;
}

.tst-hero__btn--primary {
    background: linear-gradient(135deg, #e5a93e 0%, #f0b84f 100%);
    color: #20222b;
}

.tst-hero__btn--primary:hover {
    background: linear-gradient(135deg, #f0b84f 0%, #f6c96e 100%);
    color: #171a20;
}

.tst-hero__btn--outline {
    border-color: rgba(255, 255, 255, 0.42);
    background: rgba(18, 26, 39, 0.16);
    backdrop-filter: blur(10px);
}

.tst-hero__badges {
    justify-content: flex-start;
    margin: 0;
}

.tst-hero__badge {
    background: rgba(19, 28, 43, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(12px);
}

.tst-hero__controls {
    position: absolute;
    right: clamp(1rem, 3vw, 2.5rem);
    bottom: clamp(1.2rem, 3vw, 2.5rem);
    z-index: 3;
    display: inline-flex;
    gap: 0.7rem;
    align-items: center;
    padding: 0.65rem 0.8rem;
    border-radius: 999px;
    background: rgba(16, 22, 34, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(12px);
}

.tst-hero__dot {
    width: 0.78rem;
    height: 0.78rem;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.34);
    transition: transform var(--tst-transition), background var(--tst-transition), box-shadow var(--tst-transition);
}

.tst-hero__dot.is-active {
    background: #e7ae42;
    transform: scale(1.1);
    box-shadow: 0 0 0 5px rgba(231, 174, 66, 0.18);
}

.tst-hero__scroll {
    left: auto;
    right: clamp(1.25rem, 4vw, 3rem);
    bottom: clamp(5rem, 9vw, 6.75rem);
    transform: none;
}

@media (max-width: 1024px) {
    .tst-hero {
        min-height: 92svh;
        min-height: 92dvh;
    }

    .tst-hero__content {
        padding: 7rem 1rem 5.75rem;
    }

    .tst-hero__heading {
        max-width: 9ch;
        font-size: clamp(2.7rem, 10vw, 4.4rem);
    }

    .tst-hero__subheading {
        max-width: 32rem;
    }

    .tst-hero__controls {
        left: 1rem;
        right: auto;
        bottom: 1rem;
    }

    .tst-hero__scroll {
        display: none;
    }
}

@media (max-width: 767px) {
    .tst-hero {
        min-height: 88svh;
        min-height: 88dvh;
    }

    .tst-hero__content {
        padding: 6rem 1rem 5.25rem;
    }

    .tst-hero__heading {
        max-width: 8.5ch;
        font-size: clamp(2.5rem, 13vw, 3.8rem);
    }

    .tst-hero__subheading {
        font-size: 0.98rem;
        line-height: 1.55;
    }

    .tst-hero__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .tst-hero__btn {
        width: 100%;
        justify-content: center;
    }

    .tst-hero__badges {
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: minmax(16rem, 85%);
        overflow-x: auto;
        padding-bottom: 0.35rem;
    }

    .tst-hero__badge {
        min-width: 0;
    }

    .tst-hero__controls {
        left: 1rem;
        right: 1rem;
        justify-content: center;
    }
}

@media (prefers-reduced-motion: reduce) {
    .tst-hero__slide,
    .tst-hero__slide.is-active,
    .tst-hero__heading,
    .tst-hero__subheading,
    .tst-hero__actions,
    .tst-hero__badges {
        transition: none !important;
        animation: none !important;
    }
}

/* ==========================================================================
   Homepage Story, Feed, and Partners
   ========================================================================== */

.tst-rail-header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.tst-rail-controls {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    flex-shrink: 0;
}

.tst-rail-control {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 999px;
    border: 1px solid rgba(32, 34, 43, 0.1);
    background: rgba(255, 253, 248, 0.92);
    color: var(--tst-gray-900);
    box-shadow: 0 10px 20px rgba(43, 42, 47, 0.08);
    transition: transform var(--tst-transition), background var(--tst-transition), opacity var(--tst-transition);
}

.tst-rail-control:hover:not(:disabled) {
    transform: translateY(-2px);
    background: #ffffff;
}

.tst-rail-control:disabled {
    opacity: 0.35;
    cursor: default;
}

/* About / Story Section — side-by-side text + stacked videos */
.tst-home-story {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: start;
    padding: clamp(1.5rem, 3vw, 2.5rem);
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(148, 186, 35, 0.12), transparent 34%),
        linear-gradient(135deg, #fffdf8 0%, #f7f0df 100%);
    box-shadow: 0 18px 45px rgba(43, 42, 47, 0.08);
}

.tst-home-story__copy {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.tst-home-story__copy h2 {
    margin: 0;
    font-size: clamp(2rem, 4.2vw, 3rem);
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.tst-home-story__lead {
    margin: 0;
    color: var(--tst-gray-900);
    font-size: 1.05rem;
    font-weight: 600;
}

.tst-home-story__copy p {
    margin: 0;
    color: var(--tst-text-soft);
    line-height: 1.75;
    font-size: 0.95rem;
}

.tst-home-story__actions {
    padding-top: 0.5rem;
}

/* Media column: videos stack vertically, each at 16:9 — no dead space */
.tst-home-story__media {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: sticky;
    top: 6rem;
}

.tst-home-story__video-shell {
    position: relative;
    width: 100%;
    padding-top: 56.25%; /* 16:9 */
    overflow: hidden;
    border-radius: 16px;
    background: #111;
}

.tst-home-story__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

/* Blog Feed */
.tst-home-feed {
    position: relative;
}

.tst-home-feed > .tst-rail-controls {
    display: none;
}

/* Partners grid */
.tst-partners__rail {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1.25rem;
}

/* Blog feed: 3-column grid on desktop, NOT a horizontal scroll rail */
.tst-home-feed__rail {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

/* Blog post card */
.tst-post-card {
    display: flex;
    flex-direction: column;
    border-radius: var(--tst-radius);
    overflow: hidden;
    background: var(--tst-white);
    box-shadow: var(--tst-shadow);
    border: 1px solid var(--tst-gray-300);
    transition: transform var(--tst-transition), box-shadow var(--tst-transition);
}

.tst-post-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--tst-shadow-lg);
}

.tst-post-card__media {
    position: relative;
    display: block;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: linear-gradient(135deg, var(--tst-green), var(--tst-green-dark));
}

.tst-post-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.tst-post-card:hover .tst-post-card__media img {
    transform: scale(1.05);
}

.tst-post-card__placeholder {
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    font-size: 3rem;
    font-weight: 800;
    color: rgba(255, 255, 255, 0.6);
    background: linear-gradient(135deg, var(--tst-green), var(--tst-green-dark));
}

.tst-post-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.25rem;
    flex: 1;
}

.tst-post-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    color: var(--tst-gray-500);
    font-size: 0.8rem;
}

.tst-post-card__pill {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.6rem;
    border-radius: 4px;
    background: var(--tst-green);
    color: var(--tst-white);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.7rem;
}

.tst-post-card__body h3 {
    margin: 0;
    font-size: 1.1rem;
    line-height: 1.3;
}

.tst-post-card__body h3 a {
    color: var(--tst-gray-900);
    text-decoration: none;
}

.tst-post-card__body h3 a:hover {
    color: var(--tst-green-dark);
}

.tst-post-card__body p {
    margin: 0;
    color: var(--tst-gray-700);
    font-size: 0.9rem;
    line-height: 1.6;
    flex: 1;
}

.tst-post-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--tst-green-dark);
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
    margin-top: auto;
}

.tst-post-card__link:hover {
    color: var(--tst-green);
}

.tst-home-feed__footer {
    display: flex;
    justify-content: center;
    margin-top: 2rem;
}

.tst-partner-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 1.25rem 1rem;
    border-radius: var(--tst-radius);
    background: #fff;
    border: 1px solid var(--tst-gray-300);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    text-decoration: none;
    transition: transform var(--tst-transition), box-shadow var(--tst-transition);
}

.tst-partner-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--tst-shadow-lg);
}

.tst-partner-card__logo {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 5rem;
    padding: 0.5rem;
}

.tst-partner-card__img {
    max-width: 100%;
    max-height: 4rem;
    width: auto;
    height: auto;
    object-fit: contain;
}

.tst-partner-card__name {
    color: var(--tst-gray-900);
    font-weight: 600;
    font-size: 0.85rem;
    text-align: center;
    line-height: 1.3;
}

/* Partners section: tighter spacing since it's above the footer */
.tst-partners-section {
    padding: 3rem 0 3.5rem !important;
    background: var(--tst-gray-100);
}

.tst-partners-section .tst-section-heading {
    margin-bottom: 1.75rem;
}

.tst-partners-section .tst-section-heading h2 {
    font-size: clamp(1.4rem, 3.5vw, 2rem);
}

.tst-partners-section .tst-section-heading p {
    font-size: 0.95rem;
}

@media (max-width: 1180px) {
    .tst-home-story {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .tst-home-story__media {
        position: static;
    }

    .tst-home-feed__rail {
        grid-template-columns: repeat(2, 1fr);
    }

    .tst-partners__rail {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 899px) {
    .tst-rail-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .tst-partners__rail {
        grid-template-columns: repeat(3, 1fr);
        gap: 1rem;
    }
}

@media (max-width: 767px) {
    .tst-home-story {
        padding: 1rem;
        border-radius: 18px;
    }

    .tst-home-story__copy h2 {
        font-size: clamp(1.75rem, 8vw, 2.5rem);
    }

    .tst-home-story__copy p {
        font-size: 0.92rem;
    }

    .tst-home-story__video-shell {
        border-radius: 12px;
    }

    .tst-rail-controls {
        display: none;
    }

    .tst-home-feed__rail {
        grid-template-columns: 1fr;
    }

    .tst-partners__rail {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }

    .tst-partner-card {
        padding: 1rem 0.75rem;
    }

    .tst-partner-card__logo {
        height: 4rem;
    }

    .tst-partner-card__img {
        max-height: 3rem;
    }

    .tst-partner-card__name {
        font-size: 0.8rem;
    }
}

/* ── Gallery ────────────────────────────────────────────── */
.tst-gallery {
    padding: 1rem 0 2rem;
}

.tst-gallery__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    justify-content: center;
    margin-bottom: 2.5rem;
}

.tst-gallery__filter {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.6rem 1.4rem;
    border: 2px solid var(--tst-primary, #6B8E23);
    border-radius: 50px;
    background: transparent;
    color: var(--tst-primary, #6B8E23);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.25s ease, color 0.25s ease, box-shadow 0.25s ease, transform 0.15s ease;
    white-space: nowrap;
}

.tst-gallery__filter:hover {
    background: color-mix(in srgb, var(--tst-primary, #6B8E23) 12%, transparent);
    transform: translateY(-1px);
    box-shadow: 0 3px 10px rgba(107, 142, 35, 0.15);
}

.tst-gallery__filter.is-active {
    background: var(--tst-primary, #6B8E23);
    color: #fff;
    box-shadow: 0 4px 14px rgba(107, 142, 35, 0.3);
}

.tst-gallery__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.5rem;
    height: 1.5rem;
    padding: 0 0.35rem;
    border-radius: 50px;
    background: rgba(0, 0, 0, 0.08);
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1;
}

.tst-gallery__filter.is-active .tst-gallery__badge {
    background: rgba(255, 255, 255, 0.25);
}

/* Grid — mobile-first: 2 cols */
.tst-gallery__grid {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(2, 1fr);
}

/* Tablet: 3 cols */
@media (min-width: 600px) {
    .tst-gallery__grid {
        gap: 1rem;
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Desktop: honour columns attr */
@media (min-width: 960px) {
    .tst-gallery__grid--3 {
        grid-template-columns: repeat(3, 1fr);
    }
    .tst-gallery__grid--4 {
        grid-template-columns: repeat(4, 1fr);
        gap: 1rem;
    }
    .tst-gallery__grid--5 {
        grid-template-columns: repeat(5, 1fr);
    }
}

/* Large desktop: bigger gaps */
@media (min-width: 1200px) {
    .tst-gallery__grid--4 {
        gap: 1.125rem;
    }
}

.tst-gallery__item {
    margin: 0;
    overflow: hidden;
    border-radius: 0.75rem;
    position: relative;
    aspect-ratio: 1 / 1;
    background: #e8e8e0;
}

.tst-gallery__link {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
}

.tst-gallery__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.tst-gallery__item:hover .tst-gallery__img {
    transform: scale(1.08);
}

.tst-gallery__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0);
    color: #fff;
    transition: background 0.35s ease, opacity 0.35s ease;
    opacity: 0;
    pointer-events: none;
}

.tst-gallery__item:hover .tst-gallery__overlay {
    background: rgba(0, 0, 0, 0.3);
    opacity: 1;
}

.tst-gallery__overlay svg {
    filter: drop-shadow(0 1px 4px rgba(0, 0, 0, 0.3));
}

/* Pagination */
.tst-gallery__pagination {
    display: flex;
    justify-content: center;
    margin-top: 2.5rem;
}

.tst-gallery__load-more {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 2.5rem;
    border: 2px solid var(--tst-primary, #6B8E23);
    border-radius: 50px;
    background: transparent;
    color: var(--tst-primary, #6B8E23);
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.25s ease;
    letter-spacing: 0.02em;
}

.tst-gallery__load-more:hover {
    background: var(--tst-primary, #6B8E23);
    color: #fff;
    box-shadow: 0 6px 20px rgba(107, 142, 35, 0.25);
    transform: translateY(-2px);
}

.tst-gallery__remaining {
    font-weight: 400;
    opacity: 0.7;
    font-size: 0.9em;
}

.tst-gallery__count {
    text-align: center;
    margin-top: 1rem;
    font-size: 0.85rem;
    color: #888;
    font-weight: 500;
}

/* ── Lightbox ───────────────────────────────────────────── */
.tst-lightbox {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.tst-lightbox.is-open {
    opacity: 1;
}

.tst-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(8px);
}

.tst-lightbox__content {
    position: relative;
    max-width: 85vw;
    max-height: 85vh;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.tst-lightbox__content img {
    max-width: 85vw;
    max-height: 80vh;
    border-radius: 0.625rem;
    display: block;
    object-fit: contain;
    box-shadow: 0 12px 60px rgba(0, 0, 0, 0.6);
    transition: opacity 0.15s ease;
}

.tst-lightbox__counter {
    display: block;
    text-align: center;
    color: rgba(255, 255, 255, 0.65);
    font-size: 0.85rem;
    font-weight: 500;
    margin-top: 0.75rem;
    letter-spacing: 0.05em;
}

.tst-lightbox__close {
    position: fixed;
    top: 1.5rem;
    right: 1.5rem;
    width: 3rem;
    height: 3rem;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 1.75rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: background 0.2s ease, transform 0.2s ease;
    backdrop-filter: blur(4px);
}

.tst-lightbox__close:hover {
    background: rgba(255, 255, 255, 0.25);
    transform: scale(1.1);
}

.tst-lightbox__nav {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 3.25rem;
    height: 3.25rem;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease, transform 0.2s ease;
    backdrop-filter: blur(4px);
}

.tst-lightbox__nav:hover {
    background: rgba(255, 255, 255, 0.25);
    transform: translateY(-50%) scale(1.08);
}

.tst-lightbox__prev {
    left: 1.5rem;
}

.tst-lightbox__next {
    right: 1.5rem;
}

/* ── Gallery responsive tweaks ──────────────────────────── */
@media (max-width: 599px) {
    .tst-gallery__filters {
        gap: 0.4rem;
        margin-bottom: 1.5rem;
    }
    .tst-gallery__filter {
        padding: 0.4rem 0.85rem;
        font-size: 0.8rem;
    }
    .tst-gallery__badge {
        min-width: 1.25rem;
        height: 1.25rem;
        font-size: 0.65rem;
    }
    .tst-gallery__grid {
        gap: 0.5rem;
    }
    .tst-gallery__item {
        border-radius: 0.5rem;
    }
    .tst-lightbox__nav {
        width: 2.5rem;
        height: 2.5rem;
    }
    .tst-lightbox__prev { left: 0.5rem; }
    .tst-lightbox__next { right: 0.5rem; }
    .tst-lightbox__close { top: 0.75rem; right: 0.75rem; }
    .tst-lightbox__content { max-width: 95vw; }
    .tst-lightbox__content img { max-width: 95vw; max-height: 80vh; }
}

@media (min-width: 960px) {
    .tst-gallery__filter {
        padding: 0.65rem 1.6rem;
        font-size: 0.9rem;
    }
    .tst-gallery__load-more {
        padding: 0.9rem 3rem;
    }
}

/* ==========================================================================
   Drawer Trust Badge
   ========================================================================== */

.tst-drawer__trust {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
    padding: 0.6rem 0.75rem;
    background: rgba(76, 175, 80, 0.06);
    border: 1px solid rgba(76, 175, 80, 0.15);
    border-radius: var(--tst-radius-sm);
    margin-bottom: 0.85rem;
    font-size: 0.72rem;
    color: var(--tst-gray-700);
    line-height: 1.4;
}

.tst-drawer__trust strong {
    color: var(--tst-gray-900);
}

.tst-drawer__trust-link {
    color: inherit;
    text-decoration: none;
}

.tst-drawer__trust-link:hover {
    color: var(--tst-green);
    text-decoration: underline;
}

.tst-drawer__trust svg:nth-of-type(2) {
    margin-left: 0.5rem;
    color: var(--tst-green);
}

.tst-drawer__payfast {
    margin-bottom: 0.85rem;
    padding: 0.65rem 0.75rem;
    background: #fff;
    border: 1px solid var(--tst-gray-200);
    border-radius: var(--tst-radius-sm);
}

/* PayFast lockup — drawer, cart, checkout, footer */
.tst-payfast-trust {
    display: block;
    text-decoration: none;
    color: inherit;
}

a.tst-payfast-trust:hover .tst-payfast-trust__line--brand {
    color: var(--tst-green-dark);
}

.tst-payfast-trust__inner {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.tst-payfast-trust__logo {
    height: 32px;
    width: auto;
    max-width: 140px;
    object-fit: contain;
}

.tst-payfast-trust--drawer .tst-payfast-trust__logo {
    height: 26px;
    max-width: 110px;
}

.tst-payfast-trust__text {
    display: flex;
    flex-direction: column;
    gap: 0.08rem;
    line-height: 1.25;
    text-align: left;
}

.tst-payfast-trust__line {
    display: block;
}

.tst-payfast-trust__line--intro {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--tst-gray-600);
}

.tst-payfast-trust__line--brand {
    font-size: 0.82rem;
    font-weight: 800;
    color: var(--tst-gray-900);
    letter-spacing: 0.02em;
}

.tst-payfast-trust--footer .tst-payfast-trust__inner {
    flex-direction: row;
    align-items: center;
    gap: 0.65rem;
}

.tst-payfast-trust--footer .tst-payfast-trust__logo {
    height: 28px;
    max-width: 120px;
}

.tst-payfast-trust--footer .tst-payfast-trust__line--intro {
    font-size: 0.72rem;
}

.tst-payfast-trust--footer .tst-payfast-trust__line--brand {
    font-size: 0.8rem;
}

.tst-payfast-trust--cart .tst-payfast-trust__inner,
.tst-payfast-trust--checkout .tst-payfast-trust__inner {
    justify-content: center;
}

/* ==========================================================================
   WooCommerce Cart Page — Enhanced Styling
   ========================================================================== */

.woocommerce-cart .site-content,
.woocommerce-checkout .site-content {
    padding-top: 0 !important;
}

.woocommerce-cart .entry-header,
.woocommerce-checkout .entry-header {
    background: var(--tst-gray-100) !important;
    padding: 2rem 0 1.5rem !important;
    margin-bottom: 2rem !important;
}

.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 1.75rem !important;
    font-weight: 800 !important;
}

/* Block Cart improvements */
.wc-block-cart {
    max-width: 1200px !important;
    margin: 0 auto !important;
}

.wc-block-cart .wc-block-cart__main {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    padding: 1.5rem !important;
    border: 1px solid var(--tst-gray-300) !important;
}

.wc-block-cart .wc-block-cart__sidebar {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    padding: 1.5rem !important;
    border: 1px solid var(--tst-gray-300) !important;
    position: sticky !important;
    top: 6rem !important;
}

.wc-block-cart .wc-block-components-product-name {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    color: var(--tst-gray-900) !important;
    text-decoration: none !important;
    font-size: 1rem !important;
}

.wc-block-cart .wc-block-components-product-name:hover {
    color: var(--tst-green) !important;
}

.wc-block-cart .wc-block-cart-items__row {
    border-bottom: 1px solid var(--tst-gray-100) !important;
    padding: 1.25rem 0 !important;
}

.wc-block-cart .wc-block-components-product-price .wc-block-components-formatted-money-amount {
    font-weight: 700 !important;
    color: var(--tst-green-dark) !important;
    font-size: 1.1rem !important;
}

.wc-block-cart .wc-block-components-product-metadata {
    font-size: 0.82rem !important;
    color: var(--tst-gray-500) !important;
    margin-top: 0.5rem !important;
}

.wc-block-cart .wc-block-components-product-metadata__description {
    margin: 0 !important;
}

.wc-block-cart .wc-block-components-product-metadata dt {
    font-weight: 600 !important;
    color: var(--tst-gray-700) !important;
}

.wc-block-cart .wc-block-components-product-metadata dd {
    color: var(--tst-gray-900) !important;
}

/* Cart quantity input */
.wc-block-cart .wc-block-components-quantity-selector {
    border: 2px solid var(--tst-gray-300) !important;
    border-radius: 50px !important;
    overflow: hidden !important;
}

.wc-block-cart .wc-block-components-quantity-selector input {
    font-weight: 700 !important;
    font-size: 0.95rem !important;
}

.wc-block-cart .wc-block-components-quantity-selector button {
    color: var(--tst-gray-700) !important;
}

.wc-block-cart .wc-block-components-quantity-selector button:hover {
    background: var(--tst-green) !important;
    color: #fff !important;
}

/* Cart totals */
.wc-block-cart .wc-block-cart__submit-button {
    background: var(--tst-green) !important;
    color: #fff !important;
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    padding: 0.9rem 1.5rem !important;
    transition: all 0.25s ease !important;
    border: none !important;
}

.wc-block-cart .wc-block-cart__submit-button:hover {
    background: var(--tst-green-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(76, 175, 80, 0.3) !important;
}

.wc-block-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-weight: 800 !important;
    font-size: 1.35rem !important;
    color: var(--tst-green-dark) !important;
    font-family: 'Poppins', sans-serif !important;
}

.wc-block-cart .wc-block-components-totals-item__label {
    font-weight: 600 !important;
}

/* Cart product image */
.wc-block-cart .wc-block-cart-items__row .wc-block-components-product-image img {
    border-radius: var(--tst-radius-sm) !important;
    object-fit: cover !important;
}

/* Remove link */
.wc-block-cart .wc-block-cart-item__remove-link {
    color: var(--tst-gray-500) !important;
    font-size: 0.8rem !important;
    transition: color 0.2s !important;
}

.wc-block-cart .wc-block-cart-item__remove-link:hover {
    color: #C62828 !important;
}

/* ==========================================================================
   WooCommerce Checkout Page — Enhanced Styling
   ========================================================================== */

.wc-block-checkout {
    max-width: 1200px !important;
    margin: 0 auto !important;
}

.wc-block-checkout .wc-block-checkout__main {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    padding: 2rem !important;
    border: 1px solid var(--tst-gray-300) !important;
}

.wc-block-checkout .wc-block-checkout__sidebar {
    background: #fff !important;
    border-radius: var(--tst-radius) !important;
    box-shadow: var(--tst-shadow) !important;
    padding: 1.5rem !important;
    border: 1px solid var(--tst-gray-300) !important;
    position: sticky !important;
    top: 6rem !important;
}

/* Section titles */
.wc-block-checkout .wc-block-components-checkout-step__heading {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.1rem !important;
    color: var(--tst-gray-900) !important;
}

/* Form inputs */
.wc-block-checkout .wc-block-components-text-input input,
.wc-block-checkout .wc-block-components-text-input textarea,
.wc-block-checkout .wc-block-components-combobox .components-combobox-control input {
    border: 2px solid var(--tst-gray-300) !important;
    border-radius: var(--tst-radius-sm) !important;
    padding: 0.85rem 1rem !important;
    font-size: 0.95rem !important;
    transition: border-color 0.25s ease !important;
}

.wc-block-checkout .wc-block-components-text-input input:focus,
.wc-block-checkout .wc-block-components-text-input textarea:focus {
    border-color: var(--tst-green) !important;
    box-shadow: 0 0 0 3px rgba(76, 175, 80, 0.1) !important;
    outline: none !important;
}

/* Payment method cards */
.wc-block-checkout .wc-block-components-radio-control__option {
    border: 2px solid var(--tst-gray-300) !important;
    border-radius: var(--tst-radius-sm) !important;
    padding: 1rem !important;
    margin-bottom: 0.5rem !important;
    transition: border-color 0.2s !important;
}

.wc-block-checkout .wc-block-components-radio-control__option--checked {
    border-color: var(--tst-green) !important;
    background: rgba(76, 175, 80, 0.03) !important;
}

/* Place order button */
.wc-block-checkout .wc-block-components-checkout-place-order-button {
    background: var(--tst-green) !important;
    color: #fff !important;
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    padding: 1rem 2rem !important;
    border: none !important;
    transition: all 0.25s ease !important;
    width: 100% !important;
}

.wc-block-checkout .wc-block-components-checkout-place-order-button:hover {
    background: var(--tst-green-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(76, 175, 80, 0.3) !important;
}

/* Order summary in sidebar */
.wc-block-checkout .wc-block-components-order-summary .wc-block-components-order-summary-item__image img {
    border-radius: var(--tst-radius-sm) !important;
    object-fit: cover !important;
}

.wc-block-checkout .wc-block-components-order-summary-item__description {
    font-size: 0.85rem !important;
}

.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-weight: 800 !important;
    font-size: 1.25rem !important;
    color: var(--tst-green-dark) !important;
    font-family: 'Poppins', sans-serif !important;
}

/* Coupon section */
.wc-block-checkout .wc-block-components-totals-coupon .wc-block-components-totals-coupon__button {
    background: var(--tst-gray-900) !important;
    color: #fff !important;
    border-radius: var(--tst-radius-sm) !important;
}

/* Express payment */
.wc-block-checkout .wc-block-components-express-payment {
    border: 2px dashed var(--tst-gray-300) !important;
    border-radius: var(--tst-radius) !important;
    padding: 1rem !important;
}

/* Checkout trust bar */
.tst-checkout-trust {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    margin: 1.5rem 0 0;
    background: rgba(76, 175, 80, 0.04);
    border: 1px solid rgba(76, 175, 80, 0.12);
    border-radius: var(--tst-radius);
}

.tst-checkout-trust__item {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--tst-gray-700);
    white-space: nowrap;
}

.tst-checkout-trust__item--link {
    text-decoration: none;
}

.tst-checkout-trust__item--link:hover {
    color: var(--tst-green);
}

.tst-checkout-trust__item svg {
    flex-shrink: 0;
}

.tst-checkout-trust__payfast-wrap {
    flex: 1 1 100%;
    display: flex;
    justify-content: center;
    width: 100%;
    padding-bottom: 0.85rem;
    margin-bottom: 0.35rem;
    border-bottom: 1px solid rgba(76, 175, 80, 0.15);
}

.tst-checkout-trust__payfast-wrap .tst-payfast-trust--checkout .tst-payfast-trust__logo {
    height: 36px;
    max-width: 160px;
}

/* Mobile responsive for WC pages */
@media (max-width: 782px) {
    .wc-block-cart .wc-block-cart__main,
    .wc-block-cart .wc-block-cart__sidebar,
    .wc-block-checkout .wc-block-checkout__main,
    .wc-block-checkout .wc-block-checkout__sidebar {
        padding: 1rem !important;
        border-radius: var(--tst-radius-sm) !important;
    }

    .wc-block-checkout .wc-block-checkout__main {
        padding: 1.25rem !important;
    }

    .wc-block-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
        font-size: 1.15rem !important;
    }
}

/* ==========================================================================
   Google Reviews Trust Bar — Tour Detail + Checkout
   ========================================================================== */

.tst-trust-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    padding: 0.85rem 1.25rem;
    background: #fff;
    border: 1px solid var(--tst-gray-300);
    border-radius: var(--tst-radius);
    box-shadow: 0 1px 4px rgba(0,0,0,0.04);
    margin-bottom: 1.5rem;
}

.tst-trust-bar__stars {
    display: flex;
    align-items: center;
    gap: 0.15rem;
}

.tst-trust-bar__stars svg {
    width: 16px;
    height: 16px;
}

.tst-trust-bar__rating {
    font-weight: 800;
    font-size: 1rem;
    color: var(--tst-gray-900);
    font-family: 'Poppins', sans-serif;
}

.tst-trust-bar__text {
    font-size: 0.82rem;
    color: var(--tst-gray-500);
}

.tst-trust-bar__text a {
    color: var(--tst-green);
    text-decoration: none;
    font-weight: 600;
}

.tst-trust-bar__text a:hover {
    text-decoration: underline;
}

.tst-trust-bar__google {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--tst-gray-500);
    margin-left: auto;
    text-decoration: none;
}

.tst-trust-bar__google:hover {
    color: var(--tst-green);
}

/* ==========================================================================
   Hero Google Reviews Badge
   ========================================================================== */

.tst-hero__badge {
    color: inherit;
    text-decoration: none;
    transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}

.tst-hero__badge--reviews {
    border: 1px solid rgba(255, 193, 7, 0.28);
    box-shadow: 0 16px 34px rgba(12, 18, 28, 0.18);
}

.tst-hero__badge--reviews:hover {
    transform: translateY(-2px);
    background: rgba(19, 28, 43, 0.68);
    border-color: rgba(255, 193, 7, 0.42);
}

.tst-hero__badge-stars {
    display: inline-flex;
    align-items: center;
    gap: 0.16rem;
    flex-wrap: wrap;
    flex-shrink: 0;
}

.tst-hero__badge-stars svg {
    width: 14px;
    height: 14px;
}

/* ==========================================================================
   Footer Google Reviews Badge
   ========================================================================== */

.tst-footer__reviews-badges {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.tst-footer__reviews-badge {
    display: grid;
    gap: 0.6rem;
    padding: 1rem 1.1rem;
    margin: 0;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.04));
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.18);
    color: #fff;
    text-decoration: none;
    transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}

.tst-footer__reviews-badge:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 193, 7, 0.28);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.06));
}

.tst-footer__reviews-badge-brand,
.tst-footer__reviews-badge-score,
.tst-footer__reviews-badge-stars {
    display: inline-flex;
    align-items: center;
}

.tst-footer__reviews-badge-brand {
    gap: 0.5rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.82);
}

.tst-footer__reviews-badge-score {
    gap: 0.7rem;
    flex-wrap: wrap;
}

.tst-footer__reviews-badge-rating {
    font-size: 1.9rem;
    line-height: 1;
    font-weight: 800;
    color: #fff;
}

.tst-footer__reviews-badge-stars {
    gap: 0.14rem;
}

.tst-footer__reviews-badge-stars svg {
    width: 14px;
    height: 14px;
}

.tst-footer__reviews-badge-count {
    font-size: 0.88rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.68);
}

/* ==========================================================================
   Google Reviews Carousel — Homepage
   ========================================================================== */

.tst-reviews-section {
    overflow: hidden;
}

/* Device visibility for reviews (Settings > Reviews) */
.tst-reviews--hide-mobile {
    display: none !important;
}
@media (min-width: 768px) {
    .tst-reviews--hide-mobile {
        display: block !important;
    }
}
.tst-reviews--hide-desktop {
    display: block !important;
}
@media (min-width: 768px) {
    .tst-reviews--hide-desktop {
        display: none !important;
    }
}

.tst-reviews-summary--dual {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}
.tst-reviews-summary--dual .tst-reviews-summary__link {
    flex: 0 1 auto;
}
.tst-trust-bar__sep {
    margin: 0 0.35rem;
    color: var(--tst-gray-400);
}
.tst-trust-bar__tripadvisor {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: var(--tst-gray-600);
    text-decoration: none;
    font-size: 0.82rem;
}
.tst-trust-bar__tripadvisor:hover {
    color: var(--tst-green);
}
.tst-tour-reviews-widget__ctas {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}
.tst-tour-reviews-widget__summary {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.tst-reviews-heading {
    text-align: center;
    margin-bottom: 2.5rem;
}

.tst-reviews-heading h2 {
    font-family: 'Poppins', sans-serif;
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--tst-gray-900);
    margin: 0 0 0.5rem;
}

.tst-reviews-heading p {
    color: var(--tst-gray-500);
    font-size: 1rem;
    margin: 0;
}

.tst-reviews-summary {
    display: flex;
    justify-content: center;
    margin-top: 1.25rem;
}

.tst-reviews-summary__stars {
    display: flex;
    gap: 0.1rem;
}

.tst-reviews-summary__stars svg {
    width: 20px;
    height: 20px;
}

.tst-reviews-summary__text {
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--tst-gray-900);
}

.tst-reviews-summary__brand,
.tst-reviews-summary__score {
    display: inline-flex;
    align-items: center;
}

.tst-reviews-summary__brand {
    gap: 0.45rem;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--tst-gray-500);
}

.tst-reviews-summary__score {
    gap: 0.6rem;
    justify-content: center;
}

.tst-reviews-summary__count {
    font-size: 0.92rem;
    color: var(--tst-gray-500);
}

.tst-reviews-summary__link {
    display: grid;
    gap: 0.55rem;
    min-width: min(100%, 25rem);
    padding: 1rem 1.25rem;
    background: #fff;
    border: 1px solid rgba(201, 191, 167, 0.55);
    border-radius: 20px;
    box-shadow: 0 18px 44px rgba(43, 42, 47, 0.08);
    text-decoration: none;
    text-align: center;
}

.tst-reviews-summary__link:hover {
    border-color: rgba(137, 159, 59, 0.45);
    box-shadow: 0 20px 48px rgba(43, 42, 47, 0.12);
}

.tst-reviews-summary__link:hover .tst-reviews-summary__count,
.tst-reviews-summary__link:hover .tst-reviews-summary__brand,
.tst-reviews-summary__link:hover .tst-reviews-summary__text {
    color: var(--tst-green);
}

.tst-reviews-carousel {
    position: relative;
    margin-top: 0.25rem;
}

.tst-reviews-carousel__track {
    display: flex;
    gap: 1.25rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-behavior: smooth;
    overscroll-behavior-x: contain;
    padding: 0.5rem 0.15rem 1rem;
}

.tst-reviews-carousel__track::-webkit-scrollbar {
    display: none;
}

.tst-review-card {
    flex: 0 0 min(22rem, calc(100vw - 4.5rem));
    scroll-snap-align: start;
    background: #fff;
    border: 1px solid rgba(201, 191, 167, 0.55);
    border-radius: 20px;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    min-height: 17.5rem;
    box-shadow: 0 18px 42px rgba(43, 42, 47, 0.08);
    transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
}

.tst-review-card:hover {
    border-color: rgba(137, 159, 59, 0.35);
    box-shadow: 0 24px 46px rgba(43, 42, 47, 0.14);
    transform: translateY(-2px);
}

.tst-review-card__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.tst-review-card__avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--tst-green);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    flex-shrink: 0;
    font-family: 'Poppins', sans-serif;
}

.tst-review-card__name {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--tst-gray-900);
}

.tst-review-card__name-link,
.tst-review-card__source-link {
    display: inline-block;
    text-decoration: none;
}

.tst-review-card__name-link:hover .tst-review-card__name {
    color: var(--tst-green);
}

.tst-review-card__time {
    font-size: 0.75rem;
    color: var(--tst-gray-500);
}

.tst-review-card__stars {
    display: flex;
    gap: 0.1rem;
}

.tst-review-card__stars svg {
    width: 14px;
    height: 14px;
}

.tst-review-card__images {
    position: relative;
    height: 200px;
    min-height: 200px;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
    margin: 0;
    /* ensure block context so height is always definite */
    display: block;
}

.tst-review-card__images-track {
    display: flex;
    height: 200px; /* explicit — not 100%, which fails before first paint */
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}

.tst-review-card__images-track::-webkit-scrollbar {
    display: none;
}

.tst-review-card__img-link {
    flex: 0 0 100%;
    scroll-snap-align: start;
    display: block;
    height: 200px; /* explicit — avoids height:100% resolution failure */
    width: 100%;
    border-radius: 0;
    overflow: hidden;
}

.tst-review-card__img {
    width: 100%;
    height: 200px; /* explicit */
    object-fit: cover;
    display: block;
}

.tst-review-card__img-dots {
    position: absolute;
    bottom: 0.5rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 0.3rem;
    z-index: 2;
}

.tst-review-card__img-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.55);
    border: none;
    padding: 0;
    cursor: pointer;
    transition: background 0.2s, transform 0.2s;
    flex-shrink: 0;
}

.tst-review-card__img-dot.is-active {
    background: #fff;
    transform: scale(1.35);
}

.tst-review-card__text {
    font-size: 0.92rem;
    color: var(--tst-gray-700);
    line-height: 1.6;
    flex: 1;
    display: -webkit-box;
    line-clamp: 6;
    -webkit-line-clamp: 6;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.tst-review-card__source {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.72rem;
    color: var(--tst-gray-500);
    margin-top: auto;
    padding-top: 0.5rem;
    border-top: 1px solid var(--tst-gray-100);
}

.tst-review-card__source-link:hover .tst-review-card__source {
    color: var(--tst-green);
}

/* Carousel nav */
.tst-reviews-carousel__nav {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    margin-top: 1.1rem;
}

.tst-reviews-carousel__btn {
    width: 42px;
    height: 42px;
    padding: 0;
    appearance: none;
    -webkit-appearance: none;
    border: 1px solid rgba(201, 191, 167, 0.7);
    background: #fff;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--tst-gray-700);
    box-shadow: 0 10px 24px rgba(43, 42, 47, 0.08);
    transition: all 0.25s ease;
}

.tst-reviews-carousel__btn svg {
    display: block;
    width: 20px;
    height: 20px;
    stroke: currentColor;
    fill: none;
}

.tst-reviews-carousel__btn:hover {
    background: var(--tst-green);
    color: #fff;
    border-color: var(--tst-green);
}

.tst-reviews-carousel__btn:disabled {
    opacity: 0.42;
    cursor: default;
    box-shadow: none;
}

@media (max-width: 600px) {
    .tst-footer__reviews-badge {
        padding: 0.95rem 1rem;
    }

    .tst-footer__reviews-badge-rating {
        font-size: 1.65rem;
    }

    .tst-reviews-summary__link {
        width: 100%;
    }

    .tst-review-card {
        flex-basis: min(86vw, 20rem);
    }

    .tst-reviews-heading h2 {
        font-size: 1.35rem;
    }
}

@media (min-width: 1200px) {
    .tst-review-card {
        flex-basis: 22.5rem;
    }
}

/* ==========================================================================
   Floating Social Proof Nudge
   ========================================================================== */

.tst-social-nudge {
    position: fixed;
    bottom: 1.5rem;
    left: 1.5rem;
    z-index: 9000;
    background: #fff;
    border-radius: var(--tst-radius);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.04);
    padding: 0.85rem 1rem;
    max-width: 320px;
    width: calc(100vw - 3rem);
    font-size: 0.82rem;
    line-height: 1.4;
}

.tst-social-nudge.tst-nudge-in {
    animation: tst-nudge-slide-in 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.tst-social-nudge.tst-nudge-out {
    animation: tst-nudge-slide-out 0.4s ease forwards;
}

@keyframes tst-nudge-slide-in {
    from { opacity: 0; transform: translateY(30px) scale(0.95); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes tst-nudge-slide-out {
    from { opacity: 1; transform: translateY(0) scale(1); }
    to   { opacity: 0; transform: translateY(30px) scale(0.95); }
}

.tst-social-nudge__close {
    position: absolute;
    top: 0.35rem;
    right: 0.5rem;
    background: none;
    border: none;
    font-size: 1.1rem;
    color: var(--tst-gray-500);
    cursor: pointer;
    line-height: 1;
    padding: 0.15rem;
}

.tst-social-nudge__close:hover {
    color: var(--tst-gray-900);
}

.tst-social-nudge__body {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
}

.tst-social-nudge__avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--tst-green);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.9rem;
    flex-shrink: 0;
}

.tst-social-nudge__text {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.tst-social-nudge__text strong {
    font-size: 0.82rem;
    color: var(--tst-gray-900);
}

.tst-social-nudge__name,
.tst-social-nudge__link {
    color: inherit;
    text-decoration: none;
}

.tst-social-nudge__name {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--tst-gray-900);
}

.tst-social-nudge__name:hover,
.tst-social-nudge__link:hover {
    color: var(--tst-green);
    text-decoration: underline;
}

.tst-social-nudge__text span {
    font-size: 0.78rem;
    color: var(--tst-gray-700);
}

.tst-social-nudge__text small {
    font-size: 0.7rem;
    color: var(--tst-gray-500);
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.tst-social-nudge__stars {
    display: flex;
    align-items: center;
    gap: 0.1rem;
    margin-top: 0.4rem;
    padding-top: 0.4rem;
    border-top: 1px solid var(--tst-gray-100);
}

.tst-social-nudge__stars span {
    font-size: 0.7rem;
    color: var(--tst-gray-500);
    margin-left: 0.3rem;
}

/* Desktop-only: hide floating review nudge on phones/tablets in portrait */
@media (max-width: 767px) {
    .tst-social-nudge {
        display: none !important;
        visibility: hidden;
        pointer-events: none;
    }
}

/* ==========================================================================
   WooCommerce Block Checkout & Cart — Additional Responsive Fixes
   ========================================================================== */

.wp-block-woocommerce-checkout,
.wp-block-woocommerce-cart {
    padding: 0 1rem !important;
}

/* Remove default WC block top margin */
.wc-block-checkout .wp-block-woocommerce-checkout-order-summary-block,
.wc-block-cart .wp-block-woocommerce-cart-order-summary-block {
    margin-top: 0 !important;
}

/* WC blocks wrapper — don't constrain, let WC handle its widths */

/* Address form fields */
.wc-block-checkout .wc-block-components-address-form__address_1,
.wc-block-checkout .wc-block-components-address-form__city,
.wc-block-checkout .wc-block-components-address-form__postcode {
    margin-bottom: 0.75rem !important;
}

/* Shipping methods */
.wc-block-checkout .wc-block-components-shipping-rates-control__package {
    border: 2px solid var(--tst-gray-300) !important;
    border-radius: var(--tst-radius-sm) !important;
    padding: 1rem !important;
}

/* Order summary toggle (mobile) */
.wc-block-checkout .wc-block-components-order-summary__button {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
}

/* Ensure proper layout on tablet */
@media (min-width: 783px) and (max-width: 1024px) {
    .wc-block-checkout .wc-block-checkout__main {
        padding: 1.5rem !important;
    }

    .wc-block-checkout .wc-block-checkout__sidebar {
        padding: 1.25rem !important;
    }

    .wc-block-cart .wc-block-cart__main {
        padding: 1.25rem !important;
    }
}

@media (max-width: 782px) {
    .wc-block-checkout .wc-block-checkout__sidebar {
        position: static !important;
    }

    .wc-block-checkout .wc-block-components-order-summary {
        position: static !important;
    }

    .wc-block-cart .wc-block-cart__sidebar {
        position: static !important;
    }

    .tst-checkout-trust {
        flex-direction: column;
        gap: 0.75rem;
        padding: 1rem;
    }

    .tst-checkout-trust__item {
        width: 100%;
    }
}

/* Page titles for WC pages */
.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title,
.woocommerce-cart .wp-block-post-title,
.woocommerce-checkout .wp-block-post-title {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 800 !important;
    font-size: 1.75rem !important;
    color: var(--tst-gray-900) !important;
    text-align: center !important;
    width: 100% !important;
    max-width: 1140px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    display: block !important;
    padding-inline: 1rem !important;
    margin-bottom: 1.5rem !important;
}

.woocommerce-cart .entry-header,
.woocommerce-checkout .entry-header,
.woocommerce-cart .editor-styles-wrapper .wp-block-post-title,
.woocommerce-checkout .editor-styles-wrapper .wp-block-post-title {
    text-align: center !important;
}

/* WC notices */
.wc-block-components-notice-banner {
    border-radius: var(--tst-radius-sm) !important;
    font-size: 0.88rem !important;
    margin-bottom: 1rem !important;
}

.wc-block-components-notice-banner.is-success {
    background: rgba(76, 175, 80, 0.08) !important;
    border-color: var(--tst-green) !important;
}

.wc-block-components-notice-banner.is-error {
    background: rgba(198, 40, 40, 0.06) !important;
    border-color: #C62828 !important;
}

/* Empty cart page */
.wc-block-cart .wc-block-cart__empty-cart__title {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.5rem !important;
    text-align: center !important;
    margin: 3rem 0 1rem !important;
}

.wc-block-cart .wc-block-cart__empty-cart__button {
    background: var(--tst-green) !important;
    color: #fff !important;
    border-radius: var(--tst-radius-sm) !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    padding: 0.85rem 2rem !important;
    border: none !important;
    transition: all 0.25s ease !important;
    display: inline-flex !important;
    margin: 0 auto !important;
}

.wc-block-cart .wc-block-cart__empty-cart__button:hover {
    background: var(--tst-green-dark) !important;
    transform: translateY(-1px) !important;
}

/* Cart & checkout page title responsive */
@media (max-width: 767px) {
    .woocommerce-cart .wp-block-post-title,
    .woocommerce-cart .entry-title,
    .woocommerce-checkout .wp-block-post-title,
    .woocommerce-checkout .entry-title {
        font-size: 1.35rem !important;
        margin: 1rem 0 0.75rem !important;
        padding-bottom: 0.75rem !important;
    }
}

/* Footer: payment marks + SATIB — directly under nav columns (inside .tst-footer__nav-cluster) */
.tst-footer__trust-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: flex-end;
    gap: 1rem 1.75rem;
    margin-top: 0.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.tst-footer__trust-row-pay {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 0.5rem;
}

.tst-footer__trust-row--satib-only,
.tst-footer__trust-row--pay-only {
    justify-content: flex-end;
}

.tst-footer__trust-row--satib-only .tst-footer__trust-row-satib {
    text-align: right;
}

.tst-footer__paymarks {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.6rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.tst-footer__paymarks-item img {
    height: 22px;
    width: auto;
    max-width: 58px;
    object-fit: contain;
    display: block;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.95);
    padding: 3px 5px;
    box-sizing: content-box;
}

.tst-footer__payment-strip-img {
    max-height: 50px;
    width: auto;
    max-width: min(100%, 420px);
    object-fit: contain;
}

.tst-footer__trust-row-satib {
    text-align: right;
}

.tst-footer__satib-caption {
    margin: 0 0 0.35rem;
    font-size: 0.72rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.78);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.tst-footer__satib-logo {
    max-height: 50px;
    width: auto;
    max-width: 200px;
    object-fit: contain;
    display: inline-block;
    vertical-align: middle;
}

.tst-footer__satib-link {
    display: inline-block;
    line-height: 0;
}

.tst-footer__satib-text-lockup {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.88rem;
    font-weight: 600;
}

.tst-footer__satib-icon {
    stroke: var(--tst-green);
    flex-shrink: 0;
}
