/**
* MrPlantPlant Ltd (https://mrplantplant.com)
* Copyright 2025
* Licensed to Tree Frog Grading Limited
*/

:root {
    --tfg-alpha: #CB3687;
    --tfg-bravo: #49A3E1;
    --tfg-grade: #78C285;
    --tfg-error: #E77D31;
    --tfg-alpha-dark: #852259;
    --tfg-bravo-dark: #207ec0;
    --tfg-grade-dark: #62b871;
    --tfg-grade-darker: #357440;
    --tfg-error-dark: #e26e1a;
    --tfg-grade-lighter: #b5ddbc;
    --tfg-alpha-light: #eaafcf;
    --tfg-bravo-light: #b6daf3;
    --tfg-error-light: #f5cbad;
    --tfg-grade-light: #9ad1a3;
    --tfg-error-darker: #bc5b16;
    --bg-gradient-bravo-to-alpha: linear-gradient(135deg, var(--tfg-bravo) 0%, var(--tfg-alpha) 100%);
    --bg-gradient-bravo-dark-to-alpha-dark: linear-gradient(135deg, var(--tfg-bravo-dark) 0%, var(--tfg-alpha-dark) 100%);

    --tfg-primary: var(--tfg-alpha);
    --tfg-secondary: var(--tfg-bravo);
    --bs-primary-rgb: 203, 54, 135 ;


    --bs-orange-rgb: 247, 100, 0;
    --bs-primary: var(--tfg-alpha);
    --bs-secondary: var(--tfg-bravo);
    --bs-primary-dark: var(--tfg-alpha-dark);

    /*from template inline */
    --tfg-accent: #06b6d4;
    --tfg-emerald: #10b981;
    --tfg-dark-blue: #2C3E50;

    /* Typography */
    --font-primary: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-heading: 'Poppins', sans-serif;
}

.sidenav .sidenav-menu .nav .nav-link .nav-link-icon {
    min-width: 30px
}

.btn-outline-alpha {
    --bs-btn-color: #FF6ABB;
    --bs-btn-border-color: #FF6ABB;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--tfg-alpha);
    --bs-btn-hover-border-color: var(--tfg-alpha);
    --bs-btn-focus-shadow-rgb: 0, 97, 242;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--tfg-alpha);
    --bs-btn-active-border-color: var(--tfg-alpha);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: var(--tfg-alpha);
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: var(--tfg-alpha);
    --bs-gradient: none;
}

.btn-outline-bravo {
    --bs-btn-color: #49A3E1;
    --bs-btn-border-color: #49A3E1;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #49A3E1;
    --bs-btn-hover-border-color: #49A3E1;
    --bs-btn-focus-shadow-rgb: 0, 97, 242;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #49A3E1;
    --bs-btn-active-border-color: #49A3E1;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #49A3E1;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #49A3E1;
    --bs-gradient: none;
}

.btn-outline-grade {
    --bs-btn-color: #78C285;
    --bs-btn-border-color: #78C285;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #78C285;
    --bs-btn-hover-border-color: #78C285;
    --bs-btn-focus-shadow-rgb: 0, 97, 242;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #78C285;
    --bs-btn-active-border-color: #78C285;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #78C285;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #78C285;
    --bs-gradient: none;
}

.btn-outline-error {
    --bs-btn-color: #E77D31;
    --bs-btn-border-color: #E77D31;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #E77D31;
    --bs-btn-hover-border-color: #E77D31;
    --bs-btn-focus-shadow-rgb: 0, 97, 242;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #E77D31;
    --bs-btn-active-border-color: #E77D31;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #E77D31;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #E77D31;
    --bs-gradient: none;
}

/*from inline template */
.body {
    font-family: var(--font-primary);
    line-height: 1.6;
    color: #495057;
}

.h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
}

.navbar .btn {
    padding: 0.75rem 2rem;
    font-weight: 600;
}

.btn-highlight {
    background: linear-gradient(135deg, var(--tfg-alpha), var(--tfg-bravo));
    border: none;
    color: white;
    font-weight: 600;
    padding: 0.75rem 2rem;
    transition: all 0.3s ease;
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.2);
}
.btn-highlight:hover {
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, 0.3);
    background: linear-gradient(135deg, var(--tfg-bravo), var(--tfg-alpha));
}

.btn-alpha {
    background: var(--tfg-alpha);
    border: none;
    color: white;
    font-weight: 600;
    padding: 0.75rem 2rem;
    transition: all 0.3s ease;
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.2);
}
.btn-alpha:hover {
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, 0.3);
    background: var(--tfg-alpha-dark);
}

.btn-bravo {
    background: var(--tfg-bravo);
    border: none;
    color: white;
    font-weight: 600;
    padding: 0.75rem 2rem;
    transition: all 0.3s ease;
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.2);
}
.btn-bravo:hover {
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, 0.3);
    background: var(--tfg-bravo-dark);
}

.btn-grade {
    background: var(--tfg-grade);
    border: none;
    border-radius: 0.5rem;
    color: white;
    font-weight: 600;
    font-size: 1rem;
    padding: 1.125rem 1.5rem;
    transition: all 0.3s ease;
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.2);
}
.btn-grade:hover {
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, 0.3);
    background: var(--tfg-grade-dark);
}

.icon-circle {
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
}
/* Custom Navbar */
.navbar-custom {
    /*background: rgba(255, 255, 255, 0.95);*/
    backdrop-filter: blur(10px);
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    transition: all 0.3s ease;
}

.navbar-brand img {
    height: 40px; /* Adjust logo height as needed */
}

.nav-link {
    font-weight: 500;
    color: var(--bs-light) !important;
    transition: color 0.3s ease;
}

.nav-link:hover {
    color: var(--tfg-alpha) !important;
}

/* Jumbotron */
.jumbotron-custom {
    background: var(--bg-gradient-bravo-dark-to-alpha-dark);
    color: white;
    padding: 3rem 0 2rem;
    overflow: hidden;
}



/*.jumbotron-custom::before {*/
/*    content: '';*/
/*    position: absolute;*/
/*    top: 0;*/
/*    left: 0;*/
/*    right: 0;*/
/*    bottom: 0;*/
/*    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="white" opacity="0.1"/><circle cx="75" cy="75" r="1" fill="white" opacity="0.1"/><circle cx="50" cy="10" r="0.5" fill="white" opacity="0.05"/><circle cx="90" cy="40" r="0.5" fill="white" opacity="0.05"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');*/
/*    opacity: 0.1;*/
/*}*/

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

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--tfg-grade-dark);
    color: white;
    padding: 0.5rem 1rem;
    border-radius: 50px;
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}

.display-3 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.1;
    color: #fff;
}

.lead {
    font-size: 1.1rem;
    margin-bottom: 1rem;
    opacity: 0.9;
}

.jumbotron-custom .text-info {
    color: var(--tfg-grade) !important;
    /*font-style: normal;*/
}

/* --- Brand Carousel --- */
/* Root customizables */
:root {
    --carousel-speed: 45s;      /* Increase for slower scroll, decrease for faster */
    --carousel-gap: clamp(2rem, 5vw, 4rem);
    --carousel-logo-height: 48px;
}

/* Section: ensure no side padding restricts width */
.brand-carousel {
    background: var(--tfg-bravo-dark);
    position: relative;
    overflow: hidden;
    padding-left: 0;
    padding-right: 0;
}

/* Make the inner "container" full-bleed */
.brand-carousel .brand-carousel-barrier {
    --edge-fade: 6%;
    position: relative;
    overflow: hidden;

    /* Break out of Bootstrap container constraints */
    max-width: 100vw;
    width: 100vw;
    margin: 0 auto;
    padding-left: 0;
    padding-right: 0;

    /* Optional soft fade on edges */
    mask-image: linear-gradient(to right, transparent, black var(--edge-fade), black calc(100% - var(--edge-fade)), transparent);
    -webkit-mask-image: linear-gradient(to right, transparent, black var(--edge-fade), black calc(100% - var(--edge-fade)), transparent);
}

/* The moving lane */
.brand-carousel-lane {
    display: flex;
    align-items: center;
    gap: var(--carousel-gap);
    width: max-content;
    will-change: transform;
    animation: tfg-scroll var(--carousel-speed) linear infinite;

    /* Remove default bullets and spacing on the ul to hide the dots */
    list-style: none;
    margin: 0;
    padding: 0;
}

/* Pause only when user hovers the whole carousel */
.brand-carousel:hover .brand-carousel-lane {
    animation-play-state: paused;
}

/* Items keep their intrinsic width and don't flex */
.brand-carousel-logo {
    flex: 0 0 auto;
}

/* Images: consistent height, keep aspect ratio, no layout shift */
.brand-carousel-image {
    display: block;
    height: var(--carousel-logo-height);
    width: auto;
    object-fit: contain;
    filter: drop-shadow(0 1px 1px rgba(0,0,0,.2));
    user-select: none;
    pointer-events: none; /* images don't intercept hover; parent handles pause */
}

/* Infinite marquee animation:
   Requires the sequence of items to be duplicated back-to-back in the markup.
   The track translates by 50% of its full (doubled) width, then repeats. */
@keyframes tfg-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    .brand-carousel-lane {
        animation: none;
        transform: none;
    }
}

/* Feature Cards */
.feature-card {
    border-radius: 1rem;
    box-shadow: 0 4px 6px rgba(0,0,0,0.05);
    transition: all 0.3s ease;
    border: 1px solid #e9ecef;
    height: 100%;
}

.feature-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 24px rgba(0,0,0,0.1);
}

.feature-icon {
    width: 4rem;
    height: 4rem;
    background: var(--bs-light);
    border-radius: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--bs-gray-900);
    font-size: 1.5rem;
    margin-bottom: 1.5rem;
}
#overallGrades {
    border: 3px solid currentColor; /* works with border-secondary color */
}


/* Thicken the vertical borders on the cells */
#overallGrades > :not(caption) > * > * {
    border-width: 0 3px;
}

/* Stats Section */
.stats-section {
    background: var(--tfg-alpha-dark);
    color: white;
}

.stat-number {
  font-family: var(--font-heading);
  font-size: 3rem;
  font-weight: 700;
  background: white;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

/* Footer */
.footer-custom {
    background: var(--bs-gray-800);
    color: var(--bs-light);
}

.footer-custom h5 {
    color: var(--bs-light);
    font-weight: 600;
    margin-bottom: 1rem;
}

.footer-custom a {
    color: var(--bs-light);
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer-custom a:hover {
    color: var(--tfg-alpha);
}

.footer-custom .social-links a {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    background: #e9ecef;
    color: var(--bs-light);
    border-radius: 50%;
    transition: all 0.3s;
}

.footer-custom .social-links a:hover {
    background: var(--tfg-alpha);
    color: #000;
}

/* Animations */
.fade-in-up {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.6s ease;
}

.fade-in-up.animated {
    opacity: 1;
    transform: translateY(0);
}

/* Custom spacing */
.py-6 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
}

/* Trust badges */
.trust-badge {
    background: var(--bs-light);
    border-radius: 0.75rem;
    padding: 1rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    text-align: center;
    transition: transform 0.3s ease;
    height: 100%;
}

.trust-badge:hover {
    transform: translateY(-3px);
}

.trust-badge i {
    font-size: 2rem;
    color: var(--tfg-grade);
    margin-bottom: 0.5rem;
}

.trust-badge-dark {
    background: var(--bs-gray-900);
    border-radius: 0.75rem;
    padding: 1rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    text-align: center;
    transition: transform 0.3s ease;
    height: 100%;
}

.trust-badge-dark:hover {
    transform: translateY(-3px);
}

.trust-badge-dark i {
    font-size: 2rem;
    color: var(--tfg-grade);
    margin-bottom: 0.5rem;
}

html, body {
  height: 100%;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1 0 auto; /* grows to fill the space */
}

footer {
  margin-top: auto; /* pushes footer to the bottom when content is short */
}

/*!* Page-wide background using Bootstrap's gray-300 *!*/
/*html, body {*/
/*  background-color: var(--bs-gray-300);*/
/*  !* Optional: uncomment for better contrast on dark background *!*/
/*  !*color: var(--bs-light);*!*/
/*}*/

/*!*!* Ensure sections don't override the page background *!*!*/
/*!*body, main, section {*!*/
/*!*  background: transparent;*!*/
/*}*/

.bg-gradient-bravo-to-alpha {
  background-color: var(--tfg-bravo) !important; /* fallback color */
  background-image: linear-gradient(135deg, var(--tfg-bravo) 0%, var(--tfg-alpha) 100%) !important;
}
.bg-gradient-bravo-to-alpha-dark {
    background-color: var(--tfg-bravo-dark) !important;
    background-image: linear-gradient(135deg, var(--tfg-bravo-dark) 0%, var(--tfg-alpha-dark) 100%) !important;
}
.bg-tfg-alpha {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-alpha, var(--bs-bg-opacity)) !important;
}

.bg-tfg-alpha-light {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-alpha-light, var(--bs-bg-opacity)) !important;
}
.bg-tfg-alpha-dark {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-alpha-dark, var(--bs-bg-opacity)) !important;
}

.bg-tfg-bravo-light {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-bravo-light, var(--bs-bg-opacity)) !important;
}
.bg-tfg-bravo {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-bravo, var(--bs-bg-opacity)) !important;
}
.bg-tfg-bravo-dark {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-bravo-dark, var(--bs-bg-opacity)) !important;
}

.bg-tfg-grade {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-grade, var(--bs-bg-opacity)) !important;
}

.bg-tfg-grade-lighter {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-grade-lighter, var(--bs-bg-opacity)) !important;
}

.bg-tfg-grade-light {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-grade-light, var(--bs-bg-opacity)) !important;
}
.bg-tfg-grade-dark {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-grade-dark, var(--bs-bg-opacity)) !important;
}
.bg-tfg-grade-darker {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-grade-darker, var(--bs-bg-opacity)) !important;
}
.bg-tfg-error {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-error, var(--bs-bg-opacity)) !important;
}
.bg-tfg-error-dark {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-error-dark, var(--bs-bg-opacity)) !important;
}
.bg-tfg-error-darker {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-error-darker, var(--bs-bg-opacity)) !important;
}
.bg-tfg-error-light {
    --bs-bg-opacity: 1;
    background-color: var(--tfg-error-light, var(--bs-bg-opacity)) !important;
}
.bg-bs-gray-800 {
    --bs-bg-opacity: 1;
    background-color: var(--bs-gray-800, var(--bs-bg-opacity)) !important;
}

.btn-primary {
    --bs-btn-color: var(--bs-white);
    --bs-btn-bg: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-color: var(--bs-white);
    --bs-btn-hover-bg: var(--tfg-alpha-dark);
    --bs-btn-hover-border-color: #852259;
    --bs-btn-focus-shadow-rgb: 38, 121, 244;
    --bs-btn-active-color: var(--bs-white);
    --bs-btn-active-bg: #852259;
    --bs-btn-active-border-color: #852259;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: var(--bs-white);
    --bs-btn-disabled-bg: var(--bs-primary);
    --bs-btn-disabled-border-color: var(--bs-primary);
}

.text-primary {
    --bs-text-opacity: 1;
    color: var(--tfg-alpha) !important;
}

.text-primary-dark {
    --bs-text-opacity: 1;
    color:var(--tfg-alpha-dark) !important;
}
.text-gray-900 {
    color: #212832 !important;
}
.text-secondary {
    --bs-text-opacity: 1;
    color: var(--tfg-bravo-dark) !important;
}
.text-grade-dark {
    --bs-text-opacity: 1;
    color: var(--tfg-grade-dark) !important;
}
.bg-orange {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-orange-rgb), var(--bs-bg-opacity)) !important;
}

.nav-pills {
    --bs-nav-pills-border-radius: 0.35rem;
    --bs-nav-pills-link-active-color: var(--bs-white);
    --bs-nav-pills-link-active-bg: var(--bs-secondary);
}
.bg-tfg-bravo-gradient {
    background-color: var(--tfg-bravo) !important; /* fallback color */
    background-image: linear-gradient(135deg, var(--tfg-bravo-dark) 0%, var(--tfg-bravo) 100%) !important;
}
.nav-wizard .nav-link .wizard-step-text .wizard-step-text-name {
    font-size: 1rem;
    margin-bottom: 0.25rem;
    color: var(--bs-secondary);
}
.nav-wizard .nav-link .wizard-step-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 2.5rem;
    width: 2.5rem;
    flex-shrink: 0;
    margin-right: 1rem;
    border-radius: 0.35rem;
    background-color: var(--bs-secondary);
    color: white;
}
.nav-wizard .nav-link.active .wizard-step-icon {
    background-color: var(--bs-white);
    color: var(--bs-secondary);
}
.nav-wizard .nav-link.active .wizard-step-icon i,
.nav-wizard .nav-link.active .wizard-step-icon svg,
.nav-wizard .nav-link.active .wizard-step-icon .feather {
    color: var(--bs-secondary);
}
.section-subtitle {
    color: var(--bs-text-light);
    font-size: 1.1rem;
    line-height: 1.6;
}
.accordion {
    --bs-accordion-color: var(--bs-white);
    /*--bs-accordion-bg: var(--bs-white);*/
    --bs-accordion-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, border-radius 0.15s ease;
    --bs-accordion-border-color: var(--bs-border-color);
    --bs-accordion-border-width: 1px;
    --bs-accordion-border-radius: 0.35rem;
    --bs-accordion-inner-border-radius: calc(0.35rem - 1px);
    --bs-accordion-btn-padding-x: 1.25rem;
    --bs-accordion-btn-padding-y: 1rem;
    --bs-accordion-btn-color: var(--bs-white);
    --bs-accordion-btn-bg: var(--bs-accordion-bg);
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2369707a'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    --bs-accordion-btn-icon-width: 1.25rem;
    --bs-accordion-btn-icon-transform: rotate(-180deg);
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230057da'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    --bs-accordion-btn-focus-border-color: transparent;
    --bs-accordion-btn-focus-box-shadow: 0 0 0 0.25rem rgba(0, 97, 242, 0.25);
    --bs-accordion-body-padding-x: 1.25rem;
    --bs-accordion-body-padding-y: 1rem;
    --bs-accordion-active-color: var(--bs-gray-900);
    --bs-accordion-active-bg: #e6effe;
}

/* See More/Less defaults */
.see-more-controls .hide-text {
    display: none;
}
.see-more-controls .show-text {
    display: inline;
}

/* Hide the extra items until checked */
.more-items {
    display: none;
    animation: fadeIn 0.3s ease-in-out;
}

/* When the checkbox is checked, reveal content and swap texts.
   Important: #showMoreGrading, .more-items, and .see-more-controls must be siblings
   under the same parent (we wrap them inside .see-more-group). */
.see-more-group #showMoreGrading:checked ~ .more-items {
    display: block;
}
.see-more-group #showMoreGrading:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMoreGrading:checked ~ .see-more-controls .hide-text {
    display: inline;
}

.see-more-group #showMoreSubmission:checked ~ .more-items {
    display: block;
}
.see-more-group #showMoreSubmission:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMoreSubmission:checked ~ .see-more-controls .hide-text {
    display: inline;
}

.see-more-group #showMorePricing:checked ~ .more-items {
    display: block;
}
.see-more-group #showMorePricing:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMorePricing:checked ~ .see-more-controls .hide-text {
    display: inline;
}

.see-more-group #showMorePackaging:checked ~ .more-items {
    display: block;
}
.see-more-group #showMorePackaging:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMorePackaging:checked ~ .see-more-controls .hide-text {
    display: inline;
}

.see-more-group #showMoreDelivery:checked ~ .more-items {
    display: block;
}
.see-more-group #showMoreDelivery:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMoreDelivery:checked ~ .see-more-controls .hide-text {
    display: inline;
}

.see-more-group #showMoreAccount:checked ~ .more-items {
    display: block;
}
.see-more-group #showMoreAccount:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMoreAccount:checked ~ .see-more-controls .hide-text {
    display: inline;
}

.see-more-group #showMoreStandards:checked ~ .more-items {
    display: block;
}
.see-more-group #showMoreStandards:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMoreStandards:checked ~ .see-more-controls .hide-text {
    display: inline;
}

.see-more-group #showMoreTracking:checked ~ .more-items {
    display: block;
}
.see-more-group #showMoreTracking:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMoreTracking:checked ~ .see-more-controls .hide-text {
    display: inline;
}

.see-more-group #showMoreSlabs:checked ~ .more-items {
    display: block;
}
.see-more-group #showMoreSlabs:checked ~ .see-more-controls .show-text {
    display: none;
}
.see-more-group #showMoreSlabs:checked ~ .see-more-controls .hide-text {
    display: inline;
}

    /* Force TFG Alpha chevron for accordions (handles both collapsed and expanded) */
.accordion.see-more-group .accordion-item > .accordion-header > .accordion-button::after {
    content: "" !important;
    opacity: 1 !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: var(--bs-accordion-btn-icon-width, 1.25rem) var(--bs-accordion-btn-icon-width, 1.25rem) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='%23CB3687'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E") !important;
}

.outline-shadow {
  text-shadow:
    /* white outline/glow */
    0 0 2px #ffffff,
    0 0 6px #ffffff,
    /* subtle black drop shadow beneath */
    0 4px 8px rgba(0, 0, 0, 1); !important;
}

/* CUSTOM FORM MODIFICATIONS */

form#form_card_input textarea {
    height: 300px;
    resize: vertical;
}

form#form_service_and_quantity button[type="submit"] {
    width: 100%;
}


main .card:last-of-type {
    margin-bottom: 25px;
}

/* --- Hero CTA and card layout overlap fixes --- */
/* Ensure CTAs sit above decorative cards if they intersect */
#home .cta-buttons { position: relative; z-index: 2; }
/* Card lane default stacking */
#home .hero-cards { position: relative; z-index: 1; }

/* Disable transforms and add extra spacing on extra-small screens */
@media (max-width: 575.98px) {
  #home { padding-bottom: 2rem; }
  #home .hero-cards { transform: none !important; }
  #home .hero-cards .stagger { transform: none !important; }
}

/* Re-enable transforms from small breakpoint up */
@media (min-width: 576px) {
  #home .hero-cards {
    transform: perspective(1000px) rotateY(-5deg) rotateX(5deg);
  }
  #home .hero-cards .stagger {
    transform: translateY(-20px);
  }
}

img.faded-edge {
    --edge-fade: 6%;
    mask-image:
        linear-gradient(to right, transparent, black var(--edge-fade), black calc(100% - var(--edge-fade)), transparent),
        linear-gradient(to bottom, transparent, black var(--edge-fade), black calc(100% - var(--edge-fade)), transparent);
    -webkit-mask-image:
        linear-gradient(to right, transparent, black var(--edge-fade), black calc(100% - var(--edge-fade)), transparent),
        linear-gradient(to bottom, transparent, black var(--edge-fade), black calc(100% - var(--edge-fade)), transparent);
    mask-composite: intersect;
    -webkit-mask-composite: source-in;
    /*background-color: rgba(133, 34, 89, 0.3);*/
}

.jumbotron-custom img.img-fluid {
    max-width: 135%;
}