/* Body  */
:root {
  --primary: #0082c2;
  --secondary: #0082c2;
  --white: #fff;
  --black: #000;
  --footer: #171717;
}

@font-face {
  font-family: 'Figtree';
  src: url('assets/fonts/Figtree-VariableFont_wght.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-variation-settings: "italic" 0; /* Forces upright */
}

html{
  margin: 0;
}


body {
  font-family: "Figtree", sans-serif;
}

@font-face {
  font-family: "Bebas Neue";
  src: url("assets/fonts/BebasNeue-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}

h1,
h2,
h3,
h4 {
  font-family: "Bebas Neue", sans-serif;
}

h1 {
  font-size: 3.25rem !important;
  color: var(--white) !important;
}

h2 {
  font-size: 2rem !important;
  color: var(--footer);
}

h3 {
  font-size: 2rem !important;
}

a {
  text-decoration: none !important;
}

.blog a {
  color: var(--primary)!important;
}

a.header.tel, a.dropdown {
  color: #0082c2!important;
  font-weight: 600!important;
}

h1.entry-title {
  color: var(--primary)!important;
}




p {
  line-height: 200%;
  font-size: 1rem;
}

#root {
  min-height: 100vh;
  /* font-family: Proxima Nova, sans-serif; */
}

.mulish {
  font-family: "Figtree", sans-serif;
}

/* Custom Styling */

.banner {
  display: none !important;
}

/* .banner {
  background-color: var(--secondary);
  color: white;
  position: sticky;
  top: 0px;
  height: 40px;
  left: 0;
  width: 100%;
  z-index: 9999;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
} */

/* .banner-link {
  text-decoration: none;
  width: inherit !important;
}

.banner-message {
  overflow: hidden;
}

.scrolling-text {
  animation: scrollLeft 20s linear infinite; /
  display: inline-block;
  white-space: nowrap;
  color: #ffffff !important;
} */

/* @keyframes scrollLeft {
  0% {
    transform: translateX(100%);
  }
  100% {
    transform: translateX(-100%);
  }
} */

/* .navbar {
  position: relative;
  z-index: 10;
  align-items: center;
  display: flex;
}
div#navbarNav {
  justify-content: center;
}

li.nav-item {
  padding: 0 20px;
}
.navbar .fa-phone {
  margin-right: 15px;
  font-size: 1.5rem;
}
.navbar .nav-link.phone {
  display: flex;
  align-items: center;
}

nav #basic-navbar-nav {
  width: max-content;
  justify-content: space-evenly;
}

nav .navbar-nav {
  align-items: center;
} */

a#basic-nav-dropdown {
  padding-left: 32px;
  padding-right: 32px;
}

figcaption.circa {
  bottom: 10px;
  left: 10px;
  background: rgba(0,0,0,0.8);
  color: #fff;
  padding: 4px 12px;
  border-radius: 9999px;
  font-size: 0.85rem;
  font-weight: 500;
  white-space: nowrap;
  margin-top: 10px;
  width: min-content;
}

.archive--img {
  display: flex!important;
  flex-direction: column;
  justify-content: center;
}


/* nav a,
.navbar a {
  padding-right: 32px;
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
  padding-top: 8px;
  padding-bottom: 8px;
}

.navbar {
  display: flex;
  justify-content: space-between;
  width: 100%;
} */

/* New Header  */

.header.logo {
  width: auto;
  transition: 0.4s ease-in-out;
  margin-bottom: 0;
  display: inline-block;
  float: none;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  height: 100%;
  z-index: 10;
  max-height: 180px !important;
  max-width: 180px !important;
}
.logo.scrolled {
  display: inline-block;
  max-width: 200px;
  height: auto;
  overflow: hidden;
}
.logo.scrolled img.header.logo {
  max-width: 100%;
  height: auto;
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
}

.menu-container {
  transition: 0.4s ease-in-out;
}
.sticky-header {
  left: 0;
  width: 100%;
  height: 180px!important;
  background-color: #fff!important;
  z-index: 1000;
  transition: height 0.4s ease-in-out, padding 0.4s ease-in-out;
  font-size: 14px;
}

.btn,
.services-menu,
.specialist-menu,
a.btn {
  transition: 0.3s;
}
.sticky-header .container {
  transition: padding 0.4s ease-in-out;
}
.sticky-header .mega-header {
  border-bottom: 2px solid #0082c2;
  font-weight: 400;
  font-size: 1.35rem;
}
.sticky-header .logo img {
  transition: height 0.4s ease-in-out;
}
.sticky-header .dropdown-toggle,
.sticky-header li a {
  font-weight: 500;
  color: #0082c2;
}
.sticky-header.scrolled {
  height: 50px;
}
.sticky-header.scrolled .container {
  padding: 0 1rem;
}
.sticky-header.scrolled .logo img {
  height: 40px;
}
.home .card-wrapper .card::before,
.home .card-wrapper a {
  cursor: pointer !important;
}
.mobile-header {
  z-index: 1000;
  margin-bottom: 80px;
  display: flex;
  position: relative;
}

@media (max-width: 1023px) {
  .heading--container {
  width: 101%;
  padding: 10px 10px !important;
  text-align: center;
  position: relative;
  top: -40px;
  left: -2px;
  }
}



.mobile-header #mobile-menu {
  border-top: 3px solid #0082c2;
  color: #0082c2;
  font-size: 14px;
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.5s ease-in-out;
  width: 100vw;
  top: 100px;
  min-width: 100%;
  position: absolute;
  
}
.mobile-header #mobile-menu a {
  color: #0082c2 !important;
}

.mobile-header #mobile-menu a.btn {
  color: #ffffff!important;
}

.mega-menu {
  position: absolute;
  top: 100%;
  left: 0;
  background: #fff;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  list-style: none;
  margin: 0;
  border-radius: 1px;
  z-index: 10;
  transition: opacity 0.5s;
  border-top: 4px solid #0082c2;
  opacity: 0;
  display: none;
}

.mega-menu .service-image {
  height: 275px!important;
}

ul#menu-header-menu {
  margin-bottom: 0!important;  
}

.mega-menu li {
  margin: 0 15px 30px;
  transition: 0.4s ease-in-out;
}
.buttons {
  display: flex;
}
.menu-item {
  margin: 0 !important;
  padding: 1rem !important;
}

/* === Responsive (lg breakpoint ≥1024px) === */
@media (min-width: 1024px) {
  .lg\:hidden { display: none!important }
  .lg\:flex { display: flex }
}

.menu-container .dropdown {
  position: unset!important; 
}

#scrollToTopBtn {
  position: fixed;
  bottom: 20px;
  right: 20px;
  background-color: var(--primary);
  color: #ffffff;
  border: none;
  border-radius: 100%;
  padding: 15px;
  font-size: 20px;
  height: 50px;
  cursor: pointer;
  display: flex;
  width: 50px;
  align-items: center;
  justify-content: center;
}

#additional--service .navbar a,
#additional--service .nav-link,
.competition .navbar a,
.competition .nav-link {
  color: #fff;
}
#additional--service .navbar a.dropdown-item,
#additional--service .nav-link.dropdown-item,
.competition .navbar a.dropdown-item,
.competition .nav-link.dropdown-item {
  color: var(--primary) !important;
}

.color-primary {
  color: #0082c2;
}

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

.secondary--color {
  color: var(--secondary);
}

.flex {
  display: flex;
}

.jc-center {
  justify-content: center;
  display: flex;
}

.page-bio {
  text-align: center;
}
.page-bio p {
  width: 75%;
  margin: auto;
}
.page-bio h2 {
  color: #000;
}

.img--wrapper {
  position: relative;
}

.img--border {
  position: absolute;
  background: var(--secondary);
  height: 100%;
  width: 100%;
  right: -10px;
  bottom: -10px;
  border-radius: 0.5rem;
  z-index: -1;
}

.service--info {
  text-align: center;
}
.service--info p {
  width: 75%;
  margin: auto;
  margin-top: 16px;
}

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

img {
  max-height: 400px;
}

#section--about .img-wrapper {
  display: flex;
  justify-content: center;
}
#section--about .img-wrapper .what-we-do {
  max-height: 623px !important;
}

.s-e {
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
}

/* .primary {
  color: var(--primary);
} */

/* .btn {
  padding: 8px 20px;
  border-radius: 5rem;
  outline: none;
  border: none;
  cursor: pointer;
} */

/* .btn--primary,
.btn--get-in-touch {
  border: var(--black) 2px solid;
  background-color: transparent;
  color: var(--black);
}

.btn--primary:hover,
.btn--primary:hover > span.primary--color,
.btn--get-in-touch:hover,
.btn--get-in-touch:hover > span.primary--color {
  color: var(--white) !important;
  background-color: var(--primary) !important;
  transform: scale(1.05);
  transition: all 0.3s ease-in-out;
} */

.btn--contact {
  color: var(--white);
  background-color: var(--secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  font-weight: 600;
  border-radius: 0.5rem;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.3s ease-in-out; 
}

.btn--contact:hover {
  transform: scale(1.05); 
  color: var(--white);
  background-color: var(--secondary);
}


.btn--learn-more,
.btn--learn-more:hover {
  color: var(--white);
  border: solid 1px var(--white);
  background-color: transparent;
}

.btn--consultation {
  color: var(--secondary);
  background-color: var(--white);
  border: 2px solid var(--white);
  padding-right: 40px;
  padding-left: 40px;
}

.btn--consultation:hover {
  transition: all 0.3s ease-in-out;
  color: var(--white);
  background-color: var(--secondary);
}

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

.white {
  color: #ffffff;
}

.cta {
  background-color: #000000;
  display: flex;
  flex-direction: row;
  justify-content: space-around;
  color: #ffffff;
  padding: 0 15px;
  align-items: center;
  font-size: 1.35rem;
  border-bottom-left-radius: 1.5rem;
  border-bottom-right-radius: 1.5rem;
  border: 6px solid var(--secondary);
}

.card--info a {
  color: #212629 !important;
}

/* Home Page */
.hero {
  height: 700px;
}

.hero .container {
  height: inherit;
}

/* Swiper Carousel */
.swiper {
  width: 100%;
  height: 100%;
}

.swiper-pagination-bullet,
.swiper-pagination-bullet-active {
  border-radius: 0 !important;
  width: 50px !important;
  height: 5px !important;
}

.swiper-pagination-bullet {
  background-color: #dedede !important;
  opacity: 0.75;
}

.swiper-pagination-bullet-active {
  background-color: var(--primary) !important;
}

.swiper-slide-active {
  background: #fff;
  overflow: none;
}

.swiper-slide {
  background-repeat: no-repeat !important;
  overflow: none;
}

.home-hero {
  height: 100%;
}
.home-hero .hero--content {
  height: inherit;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
}
.home-hero .hero--content .left-side {
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
}
.home-hero .hero--content .left-side .p-4 {
  height: 100%;
  display: flex;
  justify-content: center;
  flex-direction: column;
  text-align: center !important;
}

.hero--content .left-side h1 {
  text-align: center !important;
}

@media only screen and (min-width: 1024px) and (max-width: 1200px) {
  .home-hero h1 {
    font-size: 2.25rem !important;
  }
}

.swiper .right-side {
  width: 70%;
  height: 100%;
}
.swiper .left-side {
  width: 30%;
  height: 50%;
  position: relative;
}
.swiper .left-side .inside {
position: absolute;
width: 130%;
height: 100%;
background-color: #0082c2c7;
left: 15%;
}
.swiper .swiper-slide.one .right-side {
  background: url("./assets/images/microfilm-uka.jpeg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}
.swiper .swiper-slide.two .right-side {
  background: url("./assets/images/digitisation-uka.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}
.swiper .swiper-slide.three .right-side {
  background: url("./assets/images/disaster-recovery-uka.jpg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

@keyframes slide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
.logos {
  overflow: hidden;
  background: white;
  white-space: nowrap;
  position: relative;
}

.logos:before,
.logos:after {
  position: absolute;
  top: 0;
  width: 250px;
  height: 100%;
  content: "";
  z-index: 2;
}

.logos:before {
  left: 0;
  background: linear-gradient(to left, rgba(255, 255, 255, 0), white);
}

.logos:after {
  right: 0;
  background: linear-gradient(to right, rgba(255, 255, 255, 0), white);
}

.logos:hover .logos-slide {
  animation-play-state: paused;
}

.logos-slide {
  display: flex;
  flex-direction: row;
  animation: 45s slide infinite linear;
}

.logos-slide img {
  height: 50px;
  margin: 0 40px;
}

/* Overlay on service image */

#sec--services .card,
.hero-section {
  background-size: cover !important;
  background-position: top center !important;
}

#sec--services .contact-section {
  align-items: baseline;
}

#sec--services .contact-us {
  padding-right: 20px;
}

.home .sec--services .card:hover {
  transition: eaae-in-out 0.5s;
  scale: 1.1;
}
#sec--services .document-storage .card,
#sec--services .scanning .card,
#sec--services .vault-storage .card {
  min-height: 375px !important;
  align-items: unset !important;
  border-bottom-left-radius: 50px;
  border-top-right-radius: 50px;
}

#sec--services hr {
  height: 1px;
  border: 1px solid #0082c2;
}
.durasteel-img {
  max-height: 450px;
  height: 100%;
}



#sec--services .document-storage .card::before,
#sec--services .scanning .card::before,
#sec--services .vault-storage .card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border-bottom-left-radius: 50px;
  border-top-right-radius: 50px;
  background-image: linear-gradient(
    0deg,
    #000 0,
    rgba(0, 0, 0, 0.25) 40%,
    rgba(0, 0, 0, 0) 100%
  ) !important;
}
#sec--services .card {
    min-height: 300px;
    display: flex;
    position: relative;
    border: 0.5px solid #ffffffba;
    justify-content: end;
}

#sec--services .card h3 {
  position: relative;
  z-index: 10;
}

#home #sec--services .card {
  border-radius: 0!important;
}

#sec--services h3 {
  font-size: 1.35rem !important;
}

@media (max-width: 768px) {

#sec--services h3 {
  font-size: 1.25rem !important;
}

.swiper-pagination {
  bottom: 180px!important;
}

}


#sec--services .card.digitisation {
  background: url("assets/images/services/service-digitisation-uka.jpg");
}
#sec--services .card.microfilm {
  background: url("assets/images/services/uka-microfilm-service-two.jpg");
}
#sec--services .card.disaster-recovery {
  background: url("assets/images/services/uka-disaster-recovery.jpg");
}
#sec--services .card.additional {
  background: url("assets/images/services/additional-service.jpg");
}
/* #sec--services .card.additional {
  background: url("../images/Scanning-hero.jpg");
} */
#sec--services .card.surverying {
  background: url("assets/images/services/drone-service--surveying.jpg");
}
#sec--services .card.photography {
  background: url("assets/images/services/drone-service--photography.jpg");
}
#sec--services .card.video-prod {
  background: url("assets/images/services/drone-servive--videography.jpg");
}

#sec--services .card.digital-pres {
  background: url("assets/images/digital-preservation-uk-archiving.jpg");
}

#sec--services .card.leading-operator {
  background: url("assets/images/leading-operator-drone.jpg");
}

#sec--services .card.caa-approved {
  background: url("assets/images/caa-approved.jpg");
}



.services-container {
  display: flex;
  flex-wrap: wrap;
  gap: 35px;
  justify-content: space-between;
}

.service-box {
  position: relative;
  width: calc(50% - 20px);
  height: 350px;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.3s ease-in-out;
}

.service-box:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  z-index: 2;
  pointer-events: none;
  cursor: pointer;
}

.service-box img {
  width: calc(100% + 10px);
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease-in-out;
}

.service-box h2 {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0;
  padding: 10px 20px;
  font-size: 2rem !important;
  z-index: 2;
  font-weight: 300;
  font-family: "Poppins", sans-serif;
  color: #ffffff;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 1),
    rgba(0, 0, 0, 0.75) 40%,
    transparent
  );
}

.service-box a {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;

  z-index: 1;
  text-indent: 100%;
  white-space: nowrap;
  color: transparent;
  overflow: hidden;
}

.service-box .triangle {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 0;
  height: 0;
  border-bottom: 100px solid #ff8200;
  border-left: 70px solid transparent;
  transition: all 0.3s ease-in-out;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Arrow Icon Inside Triangle */
.service-box .triangle i {
  color: white;
  position: relative;
  font-size: 20px;
  bottom: -80px;
  left: -30px;
}

/* Adjust Arrow Icon When Hovered */
.service-box:hover .triangle {
  border-bottom-width: 120px;
  border-left-width: 90px;
}

/* Ensuring the Arrow Stays Centered */
.service-box:hover .triangle i {
  position: relative;
  z-index: 4;
}

/* Hover Effects */
.service-box:hover .triangle {
  border-bottom-width: 120px;
  border-left-width: 90px;
}

.service-box:hover img {
  transform: translateX(-10px);
}

/* Responsive Styles for Mobile */
@media (max-width: 768px) {
  .service-box {
    width: 100%;
    height: 300px;
  }
  
  .contact-section {
    display: flex;
    flex-direction: column;
    text-align: center;
    align-items: center;
  }

  .service-box h2 {
    font-size: 1.75rem !important;
  }
  
  #client-priority {
    background: unset!important;
  }
  

}

@media only screen and (min-width: 768px) and (max-width: 1023px) {
  .service-box img {
    max-height: 100% !important;
  }
}

/* About Section */

#client-priority.what-we-do .section--wrapper {
  background: url("assets/images/Digitisation-UKA-whatwedo.jpg")
    right 0 center/contain no-repeat;
  align-items: baseline;
}

#client-priority .content {
  background-color: rgba(255, 255, 255, 0.92);
  padding: 30px !important;
  max-width: 550px;
}

#client-priority.priority {
  background: url("assets/images/Digitisation-UKA-preserving-heritage.jpg")
    right 0 center/contain no-repeat!important;
  align-items: baseline;
}

#client-priority.microfilm-preservation-journey {
  background: url("assets/images/prservation-microfilm.jpeg")
    right 0 center/contain no-repeat!important;
  align-items: baseline;
}

#client-priority.microfilm-preservation-journey {
  background: url("assets/images/prservation-microfilm.jpeg")
    right 0 center/contain no-repeat!important;
  align-items: baseline;
}

#client-priority.drone-surveying {
  background: url("assets/images/photogrammetry-surveying.webp")
    right 0 center/contain no-repeat!important;
  align-items: baseline;
}

#client-priority.caa-approved {
  background: url("assets/images/drone-caa-approved.jpg")
  right 0 center/contain no-repeat!important;
}

#client-priority.drone-photography {
background: url("assets/images/Glasgow-Cathedral-UKAxDRONESCOTLAND.jpg")
right 0 center/contain no-repeat!important;
align-items: baseline;
}

#client-priority.drone-photography-2 {
  background: url("assets/images/aerial-drone-photography.jpg")
  right 0 center/contain no-repeat!important;
  align-items: baseline;
}

#client-priority.our-priority {
  background: url("assets/images/About-Us-Priority.png")
  right 0 center/contain no-repeat!important;
  align-items: baseline;
}

  
.section--wrapper {
  padding-top: 0; 
}

@media (min-width: 1024px) {
  .section--wrapper {
    padding-top: 8rem; 
    padding-bottom: 8rem; 
  }
  
  #client-priority .content {
    padding: 30px 30px 30px 0!important;
    min-height: 350px;
            display: flex;
            flex-direction: column;
            justify-content: center;
  }
  
  #client-priority.priority .content {
    padding: 30px 0 30px 30px!important;
  }
}

#client-priority.priority .section--wrapper {
  display: flex;
  justify-content: end;
}

.drone-img {
  display: block;
  border-radius: 1rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  transition: transform 0.4s ease, box-shadow 0.4s ease;
  transform-origin: center;
}

.drone-img:hover {
  transform: scale(1.05) translateY(-2px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
}





.needs-priority .img--wrapper {
  position: relative;
  height: 100%;
}
.needs-priority .img--border {
  width: 100%;
  height: 100%;
  position: absolute;
  background-color: var(--secondary);
  z-index: -1;
  border-radius: 0.5rem;
  left: 8px;
  bottom: -8px;
}
.needs-priority .col-md-6 {
  display: flex;
  align-items: center;
  position: relative;
}
.needs-priority .content--wrapper {
  margin: auto;
  padding: 40px;
  position: absolute;
  width: 125%;
  z-index: 1;
  border-radius: 0.5rem;
  background-color: #ffffff;
}

.section.meet-team .section--heading h2,
.section.meet-team .section--heading p {
  text-align: center;
}
.section.meet-team .section--heading p {
  width: 75%;
  margin: auto;
}
.section.meet-team hr,
.sdm-holdings hr {
  border: 2px solid var(--primary);
  width: 75%;
  margin: auto;
}

.section.meet-team .members-row {
  display: flex;
  flex-direction: row;
  justify-content: center;
  margin: auto;
  height: 100%;
  width: 100%;
}
.section.meet-team .members-row .content--item {
  display: flex;
  flex-direction: column;
  padding: 2rem 4rem;
  align-items: center;
}
.section.meet-team .members-row .content--item .member--name {
  margin-top: 1rem;
  font-weight: 500;
  color: #626262;
  font-size: 1.25rem;
  text-align: center;
}
.section.meet-team .members-row .content--item .member--title {
  margin-top: 0.5rem;
  font-weight: 300;
  color: #626262;
  font-size: 1rem;
  text-align: center;
}
.section.meet-team .careers {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.section.meet-team .careers .annoucement {
  font-size: 3.5rem;
  font-family: "Bebas Neue", sans-serif;
}

.sdm-holdings {
  align-items: center;
}
.sdm-holdings .sdm--color {
  color: #0082c2;
}
.sdm-holdings .img {
  justify-content: center;
  display: flex;
  height: 250px;
}

.charity {
  background-color: #747474;
  display: flex;
  flex-direction: row;
  color: #fff !important;
}
.charity h2 {
  color: #fff !important;
}
.charity .col-md-6 {
  display: flex;
  justify-content: center;
}
.charity .col-md-6.col-md-6:first-child {
  align-items: center;
}
.charity .col-md-6.two {
  flex-direction: column !important;
  padding: 20px;
}
.charity .col-md-6 img {
  max-height: 100px;
  margin: 25px;
}

.contact--mini-heading {
  font-size: 22px;
  color: var(--primary);
}

.contact--hero a {
  color: unset;
}

.contact--hero {
  color: #000000 !important;
  display: flex;
  flex-direction: row;
  justify-content: space-around;
}
.contact--hero form {
  padding: 50px;
  border-radius: 0.5rem;
  background-color: #ffffff;
  -webkit-box-shadow: 3px 3px 20px 0px rgba(0, 0, 0, 0.25);
  -moz-box-shadow: 3px 3px 20px 0px rgba(0, 0, 0, 0.25);
  box-shadow: 3px 3px 20px 0px rgba(0, 0, 0, 0.25);
}
.contact--hero form .radio--wrapper {
  display: flex;
  flex-wrap: wrap;
}
.contact--hero form button {
  width: 100%;
  background-color: var(--secondary);
}
.contact--hero form .form-group {
  margin: 20px 0;
}
.contact--hero form .form-group .form-check {
  margin: 0px 15px 0 0;
}
.contact--hero form .form-group .form-check .form-check-input:checked {
  background-color: var(--secondary);
  border-color: var(--secondary);
}
.contact--hero form label {
  color: #5a5a5a;
  font-weight: 300;
  font-size: 14px;
}
.contact--hero h1 {
  color: #000000 !important;
}
.contact--hero .email-us,
.contact--hero .tel {
  font-size: 2rem;
  font-family: Bebas Neue, sans-serif;
  color: var(--primary);
}
.contact--hero .email-us a,
.contact--hero .tel a {
  text-decoration: none;
  color: var(--primary);
}
.contact--hero .fa-solid {
  padding-right: 20px;
}

.locations {
  margin-top: -75px;
  background: #18193f;
  padding-top: 200px;
}
.locations .map--wrapper {
  display: flex;
  justify-content: space-evenly;
}
.locations .card {
  width: 35%;
  border-radius: 0.5rem;
}
.locations .card .mapboxgl-marker.mapboxgl-marker-anchor-center {
  position: absolute;
  top: 0%;
}
.locations .card canvas {
  border-radius: 1.5rem !important;
}
.locations .card .mapboxgl-ctrl-logo {
  display: none !important;
}
.locations .card svg {
  width: 40px;
  height: 60.7px;
}
.locations .card path {
  fill: var(--secondary);
}
.locations .card .mapboxgl-control-container {
  display: none;
}
.locations .card .card--content:nth-child(2) {
  padding: 30px;
}
.locations .card .card--content:nth-child(2) .card--heading {
  font-family: Bebas Neue, sans-serif;
  font-size: 1.5rem;
}
.locations .card .card--content:nth-child(2) .card--info {
  display: flex;
  flex-direction: row;
}
.locations .card .card--content:nth-child(2) .card--info .fa-solid {
  color: var(--primary);
}
.locations .card .card--content:nth-child(2) .card--info a {
  text-decoration: none;
}
.locations h2 {
  text-align: center;
  color: #ffffff;
}

#map {
  top: 0;
  bottom: 0;
  width: 100%;
  height: 400px;
  width: 400px;
}

#digitisation .service--info {
  text-align: center;
}
#digitisation .service--info p {
  width: 75%;
  margin: auto;
  margin-top: 16px;
}
#digitisation .service--type h3 {
  font-family: Bebas Neue, sans-serif;
  text-align: center;
  margin-top: 5rem;
}
#digitisation .service--type .p {
  text-align: center;
}
#digitisation .service--type .card--wrapper {
  display: flex;
  justify-content: space-between;
}
#digitisation .service--type .card:nth-child(1) {
  margin-right: 1rem;
}
#digitisation .service--type .card:nth-child(2) {
  margin-left: 1rem;
}
#digitisation .service--type .card {
  display: flex;
  flex-direction: row;
  max-width: 45%;
  padding: 25px;
  align-items: center;
  -webkit-box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.4);
  border: 6px solid transparent;
  justify-content: space-between;
}
#digitisation .service--type .card .heading {
  font-family: Bebas Neue, sans-serif;
  color: var(--primary);
  font-size: 1.5rem;
}
#digitisation .service--type .card:hover {
  border: 6px solid var(--secondary);
  transition: 0.5s ease-in-out all;
}
#digitisation .service--type .card img {
  height: 75px;
}
#digitisation .service--type .card .card--content {
  display: flex;
  width: 75%;
  flex-direction: column;
}
#digitisation .divider {
  margin-top: 5rem;
  margin-bottom: 5rem;
  opacity: 0.3;
  border-top: 2px solid #000;
}
#digitisation img {
  max-height: 400px;
}
#digitisation .contact--module .top {
  padding: 0 75px 37px 75px;
}
#digitisation .contact--module .contact--options {
  display: flex;
  flex-direction: column;
}
#digitisation .contact--module .contact--options .call,
#digitisation .contact--module .contact--options .email {
  width: 100%;
  height: 100%;
  display: flex;
}
#digitisation .contact--module .contact--options .call .content,
#digitisation .contact--module .contact--options .email .content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: 1.25rem;
}
#digitisation .contact--module .contact--options .call .content a,
#digitisation .contact--module .contact--options .email .content a {
  text-decoration: none;
  color: #000;
}
#digitisation .contact--module .contact--options .call .icon--wrapper,
#digitisation .contact--module .contact--options .email .icon--wrapper {
  width: 25%;
  display: flex;
  align-items: center;
  justify-content: center;
}
#digitisation .contact--module .contact--options .call .icon--wrapper img,
#digitisation .contact--module .contact--options .email .icon--wrapper img {
  height: 50px;
  width: auto;
}
#digitisation .contact--module .contact--options .call {
  background-color: #edf0f4;
}
#digitisation .contact--module .contact--options .email {
  background-color: #dbe2eb;
}
#digitisation .contact--module .bottom {
  display: flex;
  flex-direction: row;
  background-color: #cedeec;
  padding: 75px;
}
#digitisation .contact--module .bottom .submit,
#digitisation .contact--module .bottom .experts {
  width: 100%;
  display: flex;
  flex-direction: column;
  text-align: center;
  align-items: center;
}
#digitisation .contact--module .bottom .submit img,
#digitisation .contact--module .bottom .experts img {
  height: auto;
  width: 50px;
}
#digitisation .contact--module .bottom .vertical-hr {
  height: 100px; /* Adjust height as needed */
  border-left: 1px solid black; /* Set border for the vertical line */
  margin: 0 20px; /* Adjust margin as needed */
  border-top: 0;
}
#digitisation .service--desc h2,
#digitisation .service--desc h3 {
  color: var(--primary) !important;
}
#digitisation .service--desc span.description {
  line-height: 200%;
}
#digitisation .service--desc .item--description {
  display: flex;
  flex-direction: row;
  align-items: center;
}
#digitisation .service--desc .item--description.solution {
  display: flex;
  flex-direction: column;
}
#digitisation .service--desc .item--description .double--item {
  display: flex;
  flex-direction: row;
}
#digitisation .service--desc .item--description .double--item .item--card {
  position: relative;
  margin: 20px 40px 20px 0;
  box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.4);
  width: 50%;
}
#digitisation
  .service--desc
  .item--description
  .double--item
  .item--card
  .card--border {
  position: absolute;
  background-color: var(--primary);
  top: 4px;
  left: 4px;
  width: 100%;
  height: 100%;
  z-index: -1;
}
#digitisation .service--desc .item--description .double--item .item--card img {
  max-width: 100px;
}
#digitisation
  .service--desc
  .item--description
  .double--item
  .item--card
  .card--content {
  display: flex;
  align-items: center;
  background-color: white;
  position: relative;
  z-index: 0;
  padding: 40px;
}
#digitisation
  .service--desc
  .item--description
  .double--item
  .item--card
  .card--content
  .content {
  display: flex;
  flex-direction: column;
  margin-left: 30px;
}
#digitisation
  .service--desc
  .item--description
  .double--item
  .item--card
  .card--content
  .content
  .card--heading {
  margin-bottom: 15px;
}
#digitisation .service--desc .item--description .side--content {
  width: 100%;
}
#digitisation .service--desc .item--description .side--img {
  width: 25%;
}
#digitisation .service--desc .item--description .side--img img {
  max-height: 300px !important;
  padding: 1.25rem;
}

.service--selection .service--content {
  color: #fff;
  font-size: 2rem;
  display: flex;
  align-items: flex-end;
  height: 100%;
  padding: 20px;
  justify-content: center;
}
.service--selection .tall {
  height: 550px;
}
.service--selection .short {
  height: 275px;
}
.service--selection .type--one {
  width: 25%;
  margin: 0;
  padding: 0;
}
.service--selection .type--two {
  width: 50%;
  margin: 0;
  padding: 0;
}
.service--selection .type--three {
  width: 75%;
  margin: 0;
  padding: 0;
}
.service--selection .type--four {
  width: 100%;
  margin: 0;
  padding: 0;
}
.service--selection .type--one,
.service--selection .type--two,
.service--selection .type--three,
.service--selection .type--four {
  border: solid 5px #ffffff;
  background-color: #000000;
  filter: grayscale(100%);
}
.service--selection .type--one:hover,
.service--selection .type--two:hover,
.service--selection .type--three:hover,
.service--selection .type--four:hover {
  cursor: pointer;
  -webkit-box-shadow:inset 0px 0px 0px 10px #000;
  -moz-box-shadow:inset 0px 0px 0px 10px #000;
  box-shadow:inset 0px 0px 0px 10px #000;
  filter: grayscale(0%);
  transition: 0.5s ease-in-out all;
}
.service--selection .type--four {
  border: solid 5px #ffffff;
  background-color: #000;
}
.service--selection .col-md-3,
.service--selection .col-md-6,
.service--selection .col-md-9,
.service--selection .row {
  margin: 0;
  padding: 0;
}
.service--selection h2 {
  text-align: center;
}
.service--selection .service--name {
  font-family: Bebas Neue, sans-serif;
}
.service--selection .bound-volumes {
  background: linear-gradient(
      0deg,
      rgb(0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 20%,
      rgba(80, 80, 80, 0.0372340426) 50%,
      rgba(255, 255, 255, 0) 100%
    ),
    url("assets/images/services/bound-volumes.jpeg");
  background-size: cover;
  background-position: center center;
}
.service--selection .artefacts {
  background: linear-gradient(
      0deg,
      rgb(0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 22%,
      rgba(80, 80, 80, 0.0372340426) 50%,
      rgba(255, 255, 255, 0) 100%
    ),
    url("assets/images/services/artefacts.jpg");
  background-size: cover;
  background-position: center center;
}
.service--selection .microfilm {
  background: linear-gradient(
      0deg,
      rgb(0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 22%,
      rgba(80, 80, 80, 0.0372340426) 50%,
      rgba(255, 255, 255, 0) 100%
    ),
    url("assets/images/services/microfilm-microfiche.jpg");
  background-size: cover;
  background-position: center center;
}
.service--selection .documents {
  background: linear-gradient(
      0deg,
      rgb(0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 22%,
      rgba(80, 80, 80, 0.0372340426) 50%,
      rgba(255, 255, 255, 0) 100%
    ),
    url("assets/images/services/documents.png");
  background-size: cover;
  background-position: center center;
}
.service--selection .photographic-mediums {
  background: linear-gradient(
      0deg,
      rgb(0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 22%,
      rgba(80, 80, 80, 0.0372340426) 50%,
      rgba(255, 255, 255, 0) 100%
    ),
    url("assets/images/services/photograaphic.png");
  background-size: cover;
  background-position: center center;
}
.service--selection .newspapers {
  background: linear-gradient(
      0deg,
      rgb(0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 22%,
      rgba(80, 80, 80, 0.0372340426) 50%,
      rgba(255, 255, 255, 0) 100%
    ),
    url("assets/images/services/newspapers.png");
  background-size: cover;
  background-position: center center;
}
.service--selection .large-formats {
  background: linear-gradient(
      0deg,
      rgb(0, 0, 0) 0%,
      rgba(0, 0, 0, 0.75) 22%,
      rgba(80, 80, 80, 0.0372340426) 50%,
      rgba(255, 255, 255, 0) 100%
    ),
    url("assets/images/services/large-formats.png");
  background-size: cover;
  background-position: center center;
}

/* Contact Module Styling */
.contact--module {
  background: linear-gradient(
    165deg,
    rgba(255, 255, 255, 0.8) 0%,
    rgba(237, 237, 250, 1) 58%
  );
}

.module--desc {
  text-align: center;
}

.contact-module {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  justify-content: space-between;
  font-family: "Figtree", sans-serif;
}

.contact-box {
  border: 1px solid rgba(0, 0, 0, 0.075);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: 35px;
  width: calc(33% - 20px); /* Ensures three boxes per row on larger screens */
  position: relative;
  border-radius: 4px;
  transition: transform 0.3s ease;
  background-color: #ffffff;
}

.contact-box:hover {
  transform: translateY(-5px);
}

.contact-icon {
  font-size: 1rem;
  color: #333;
  margin-bottom: 4rem;
  border: 1px solid #ebebeb;
  padding: 13px;
  border-radius: 7px;
  height: 50px;
  width: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.contact-box h3 {
  font-size: 1.5rem !important;
  font-weight: 500 !important;
  margin: 0 0 20px 0;
}

.contact-box p {
  font-size: 1rem;
  font-weight: 300;
  margin: 0 0 20px 0;
}

.contact-box a {
  font-size: 1rem;
  font-weight: bold;
  color: #333;
  text-decoration: underline;
}

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

/* Responsive Styling for Mobile */
@media (max-width: 768px) {
  .contact-module {
    flex-direction: column;
    gap: 15px;
  }

  .contact-box {
    width: 100%;
  }
}

#microfilm--service img {
  border-radius: 1.5rm;
}

#blog .heading {
  font-family: "Bebas Neue", sans-serif;
  display: flex;
  flex-direction: column;
  margin-top: 3rem;
}
#blog .heading .blog--sub {
  font-size: 1.5rem;
}
#blog .heading .blog--heading {
  font-size: 3rem;
  color: var(--primary);
}
#blog .blog--img {
  max-height: 250px;
}

div#basic-navbar-nav {
  width: max-content;
  justify-content: space-evenly;
}

.add--service {
  background: var(--primary) url("assets/images/addtional-service-bg-4.png") !important;
  color: #ffffff;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  background-position: bottom center !important;
}
.add--service .navbar-nav {
  padding: 0 20px;
}
.add--service .hero {
  min-height: 700px !important;
}
.add--service .hero--content {
  color: #fff;
  width: 40%;
}
.add--service .hero--heading {
  width: 50%;
}
.add--service .hero--heading h1 {
  font-size: 3.75rem;
}
.add--service .container {
  display: flex;
  flex-direction: row;
  justify-content: space;
}

.page--wrapper.bottom {
  margin-top: 30px;
}
.page--wrapper.bottom .top {
  display: flex;
}
.page--wrapper.bottom .heading {
  width: 50%;
}
.page--wrapper.bottom .heading h1 {
  color: var(--primary) !important;
}
.page--wrapper.bottom .content {
  width: 50%;
  display: flex;
  flex-direction: column;
  align-items: end;
  align-items: flex-end;
  -webkit-align-items: flex-end;
}
.page--wrapper.bottom .content span {
  text-align: end;
}
.page--wrapper.bottom div:nth-chilld(2) {
  text-align: right;
}

.service--item-desc {
  display: flex;
  align-items: center;
}
.service--item-desc .description {
  width: 75%;
}
.service--item-desc .description:nth-child(odd) {
  margin-right: 50px;
}
.service--item-desc .description:nth-child(even) {
  margin-left: 50px;
}
.service--item-desc img {
  width: 25%;
  height: fit-content;
}

#disaster-recovery .main {
  display: flex;
}
#disaster-recovery .main .content {
  width: 50%;
  padding: 35px;
}
#disaster-recovery .main .img--wrapper {
  width: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  height: auto;
}
#disaster-recovery .main .img--wrapper img {
  max-height: 650px;
}
#disaster-recovery .main .section--list li {
  list-style: none;
  position: relative;
}
#disaster-recovery .main .section--list li::before {
  content: ">";
  font-family: "Figtree", sans-serif;
  position: absolute;
  left: -32px;
  top: 26px;
  color: var(--primary);
  font-weight: 300;
}
#disaster-recovery .btn--wrapper {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
}
#disaster-recovery .img--wrapper {
  height: fit-content;
}
#disaster-recovery .section--disaster-help.section--storage .content,
#disaster-recovery .section--storage.section--storage .content {
  padding-left: 50px;
}
#disaster-recovery .section--disaster-help .wrapper,
#disaster-recovery .section--storage .wrapper {
  align-items: center;
}
#disaster-recovery .section--disaster-help p,
#disaster-recovery .section--storage p {
  margin-right: 40px;
}
#disaster-recovery .section--disaster-help img,
#disaster-recovery .section--storage img {
  border-radius: 0.5rem;
}

#faq .fa-chevron-up {
  margin-left: 16px;
  color: #969696;
}
#faq h1 {
  text-align: center;
  color: var(--primary) !important;
  position: relative;
  z-index: 1;
}
#faq .hero {
  position: relative;
  color: #000;
  z-index: 0;
  min-height: auto !important;
  height: auto !important;
}
#faq .hero .faq-container {
  width: 100%;
  background-color: rgb(255, 255, 255);
  border-radius: 0.5rem;
  box-shadow: 3px 3px 20px 0px rgba(0, 0, 0, 0.25);
  margin-bottom: 3.5rem;
  padding: 100px;
  display: flex;
  z-index: 1;
}
#faq .hero .faq-container .faq--content-wrapper {
  overflow: auto;
}
#faq .hero .faq-container .faq--selection {
  width: 35%;
}
#faq .hero .faq-container .faq--selection ul {
  padding: 0;
}
#faq .hero .faq-container .faq--selection li {
  color: var(--primary);
  font-size: 1.75rem;
  list-style: none;
  padding-right: 30px;
  margin-bottom: 45px;
  padding-left: 30px;
  color: #969696;
}
#faq .hero .faq-container .faq--selection .wording {
  cursor: pointer;
}
#faq .hero .faq-container .faq--selection .active {
  color: var(--primary);
  border-left: 2px solid #000000;
  font-weight: 600;
}
#faq .hero .faq-container .faq--content-wrapper {
  width: 65%;
}

.accordion {
  margin-bottom: 10px;
}

.accordion-question {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  font-weight: 600;
}

.accordion.expanded .fa-chevron-up {
  transform: rotate(180deg);
}

.accordion-answer {
  max-height: 0;
  overflow: hidden;
  transition: 1s ease-in;
  color: #7d7d7d;
}

.accordion.expanded .accordion-answer {
  max-height: max-content;
}

.seperator {
  opacity: 0.1;
}

/* Catalogue Page */

.container.header {
  margin: auto;
  text-align: center;
}

#catalogue .header--section h1 {
  color: var(--primary) !important;
  text-align: center;
}

#catalogue .header--section p {
  text-align: center;
}

#catalogue .header--section .btn--primary {
  margin: auto;
  align-content: center;
  display: flex;
  width: fit-content;
}

.category-letter {
  margin-bottom: 10px;
}

.category--accordion {
  padding: 10px;
  cursor: pointer;
}

.accordion-btn {
  background: none;
  border: none;
  font-size: 16px;
  font-weight: bold;
  cursor: pointer;
  width: 100%;
  text-align: left;
  padding: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.catalogue .category--item {
  /* display: none; */
  /* overflow: hidden; */
  transition: max-height 0.3s ease-out;
  /* max-height: 0; */
  border-top: none;
  padding: 0 10px;
}

.main-letter {
  color: var(--primary);
  font-size: 3rem;
  font-weight: 600;
}

.catalogue .category--item li {
  min-height: 3.25rem !important;
  width: 100%;
  align-items: center;
  display: grid;
  width: -webkit-fill-available;
}

.catalogue .category--item.open {
  display: block;
  max-height: 1000px; /* large value to enable smooth transition */
}

.catalogue .category--item ul {
  list-style: none;
  padding: 10px 0;
  margin: 0;
}

.catalogue .list--item li {
  padding: 5px 0;
}

.catalogue .border-container {
  position: relative;
  background-color: #dbdbdb;
  padding: 5px;
}

.catalogue .border {
  position: absolute;
  bottom: -5px;
  width: 100%;
  background-color: var(--primary);
  height: 100%;
  left: 5px;
  z-index: -1;
}

.catalogue .list--year {
  bottom: 4px;
  right: 4px;
}

.arrow {
  transition: transform 0.3s ease;
}

.arrow.down {
  transform: rotate(360deg);
}

.accordion-btn hr {
  width: 90%;
}

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

/* Catalogue Management Page */

#edit-catalogue h1 {
  color: #000000 !important;
}

#edit-catalogue .container {
  display: flex;
  margin: 0 auto;
  padding: 20px;
}

#edit-catalogue .container.navi {
  display: flex;
  margin: 0 auto;
  padding: 20px;
}

.alert {
  background-color: #d4edda;
  color: #155724;
  padding: 15px;
  margin-bottom: 20px;
  border: 1px solid #c3e6cb;
  border-radius: 4px;
}

form {
  margin-bottom: 20px;
  border: 1px solid #ccc;
  padding: 15px;
  border-radius: 4px;
}

#edit-catalogue input[type="text"] {
  display: block;
  width: calc(100% - 22px);
  margin-bottom: 10px;
  padding: 10px;
  border-radius: 4px;
  border: 1px solid #ccc;
}

#edit-catalogue button {
  padding: 10px 15px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

#edit-catalogue button[name="add"] {
  background-color: #28a745;
  color: white;
}

#edit-catalogue button[name="edit"] {
  background-color: #007bff;
  color: white;
}

#edit-catalogue button[name="delete"] {
  background-color: #dc3545;
  color: white;
}

button:hover {
  opacity: 0.9;
}

/* Add this to your theme's stylesheet or create a new CSS file */

#edit-catalogue {
  display: flex;
}

.sidebar {
  width: 200px;
  background: #f8f9fa;
  padding: 20px;
  border-right: 1px solid #ddd;
}

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

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

.sidebar ul li a {
  text-decoration: none;
  color: #007bff;
  font-weight: bold;
}

.sidebar ul li a:hover {
  text-decoration: underline;
}

.content {
  flex: 1;
  padding: 20px;
}



form {
  margin-bottom: 20px;
  border: 1px solid #ccc;
  padding: 15px;
  border-radius: 4px;
}


.input--container {
}

/* LONDON - Location Page */

.hero.uka--london {
  width: 100%;
  height: 550px !important;
}

.hero--banner {
  background: #ffffff;
  display: flex;
  justify-content: center;
  flex-direction: column;
  position: relative;
  height: 100px;
}

#edinburgh #map1:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(120deg, #000000, #000000);
  opacity: 0.25;
}

/* #map3:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(120deg, #000000, #000000);
  opacity: 0.25;
} */

.hero--banner-inner {
  position: absolute;
  width: 100%;
  text-align: center;
  top: -100px;
  padding: 25px;
  background-color: #ffffff;
}

.hero--banner-inner h1 {
  color: var(--primary) !important;
  text-align: center;
}

.mapboxgl-ctrl-logo {
  display: none !important;
}

.mapboxgl-ctrl.mapboxgl-ctrl-attrib {
  display: none !important;
}

hr.banner {
  width: 50%;
}

.hero--banner h1 {
  font-size: 3.5rem;
}

.icon-seo {
  border: 5.5px solid #1c1d41;
  border-radius: 100%;
  padding: 10px;
}

#london-location .card--wrapper,
#edinburgh-location .card--wrap {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}

.preservation-cta.london .right {
  display: flex;
  justify-content: flex-end;
}

.sec-seperator {
  background: linear-gradient(
      180deg,
      rgba(28, 29, 65, 0.97) 0%,
      rgba(0, 130, 194, 0.97) 100%
    ),
    url(./assets/images/customer-service-two.jpg);

  background-blend-mode: multiply;
  background-size: cover;
  background-position: top center;
  min-height: 400px;
  padding: 75px;
  display: flex;
  align-items: center;
}

.sec-seperator p {
  color: #ffffff;
  font-size: 1.75rem;
  font-weight: 300;
  text-align: center;
}

.sec-seperator .container {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.sec-seperator .btn.btn--wrapper {
  background-color: #ffffff;
  font-weight: 600;
  border: 2px solid #ffffff;
}

.sec-seperator .btn.btn--wrapper:hover {
  transform: scale(1.15);
  color: #ffffff;
  background-color: #000000;
  border: solid 2px #ffffff;
  transition: 0.5s all ease-in-out;
}

.london--cta .fw-bold {
  color: #ffffff;
}

#london-location .col-lg-6.img,
#edinburgh-location .col-lg-6.img {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 3.5rem;
  order: -1;
  height: 350px;
}

#london-location .preservation-cta,
#edinburgh-location .preservation-cta {
  margin-top: 1rem !important;
}

#london-location .col-lg-6.right,
#edinburgh-location .col-lg-6.right {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 3.5rem;
  order: -1;
  height: 350px;
}

.sec-seperator p {
  font-size: 1.25rem;
}

.sec-seperator .container {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* Footer */
#footer {
  background-color: #171717;
  color: var(--white);
  padding: 6rem;
}

#footer a {
  color: #ffffff !important;
}

/* Wrapper */
#footer .wrapper {
  width: 100%;
}

/* Legal */
#footer .legal {
  font-size: 0.65rem;
  font-weight: 100;
  display: flex;
  flex-direction: row;
  list-style-type: none;
  color: #fff;
  justify-content: space-between;
}

#footer .legal a {
  text-decoration: none;
  color: #fff;
}

/* Container */
#footer .container {
  display: flex;
  flex-direction: row;
}

/* Footer Column */
#footer .footer--col {
  width: 20%;
  display: flex;
  flex-direction: column;
}

/* Main Footer Column */
#footer .footer--col.main {
  width: 40%;
}

/* Footer Heading */
#footer .footer--col .footer--heading {
  font-family: Bebas Neue, sans-serif;
  font-size: 1.75rem;
  font-weight: 800;
}

/* Footer Logo */
#footer .footer--col .footer--logo {
  height: auto;
  padding: 10px 10px 10px 0;
  width: 50%;
}

/* Footer List */
#footer .footer--col ul {
  list-style-type: none;
  margin: 0;
  padding: 10px 0 30px 0;
  color: #ffffff !important;
}

/* Footer List Item */
#footer .footer--col ul .list--item {
  padding: 10px 0;
  font-weight: 300;
  font-size: 14px;
  color: #ffffff !important;
}

/* Footer List Item Link */
#footer .footer--col ul category--item a {
  color: var(--white);
  text-decoration: none;
  font-weight: 300;
  color: #ffffff !important;
}

/* Media Query for Small Screens */
@media only screen and (max-width: 767px) {
  #footer .container {
    display: flex;
    flex-direction: column;
  }

  h1 {
    font-size: 1.75rem !important;
  }
  h2 {
    font-size: 1.6rem !important;
  }
  h3 {
    font-size: 1.5rem !important;
  }

  .hero--banner-inner h1 {
    font-size: 2rem !important;
  }

  .hero--banner {
    max-height: 50px;
  }

  #london-location .content--item,
  #edinburgh-location .content--item {
    padding-top: 40px !important;
  }

  .sec-seperator {
    padding: 35px !important;
  }
}

/* Styles for small screens */
@media only screen and (max-width: 767px) {
  .col-md-6.content {
    margin-bottom: 2.5rem;
  }

  /* .navbar img {
    height: 50px;
  }
  .navbar .navbar-collapse {
    position: relative;
  }
  .navbar .navbar-nav {
    bottom: -230px;
    left: 0;
    padding: 5%;
    background: #ffffff;
    width: 100%;
    visibility: visible;
    z-index: 9999;
    border-top: 3px solid var(--secondary);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    -moz-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    -webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  }
  .navbar .navbar-nav .navbar-collapse {
    transition: ease-in-out 0.2s;
  }
  .logos-slide img {
    height: 20px;
    margin: 0 40px;
  }
  .logos {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .logos:before,
  .logos:after {
    position: absolute;
    top: 0;
    width: 75px;
    height: 100%;
    content: "";
    z-index: 2;
  }
  .navbar-brand {
    margin: 0;
  } */
  
  #section--about .top img:first-child {
    max-height: 150px;
    padding-right: 24px;
  }
  #section--about .top {
    display: flex;
    justify-content: flex-end;
  }
  .home-hero {
    height: 100%;
  }
  .home-hero .hero--content {
    height: inherit;
    display: flex;
    flex-direction: column;
  }
  .home-hero .hero--content .right-side {
    order: -1;
  }
  .home-hero .swiper .right-side {
    width: 100%;
    border-radius: 0.5rem;
    height: 100%;
  }
  .home-hero .swiper .left-side {
    width: 100%;
  }
  .home-hero .swiper .left-side .inside {
    position: relative;
    width: 100%;
    height: 100%;
    background-color: #ffffff;
    left: 0;
    border-radius: 0rem;
  }
  .home-hero .swiper .left-side .inside .p-4 {
    align-items: center;
  }
  .home-hero .swiper .left-side .inside .p-4 h1 {
    color: var(--primary) !important;
    text-align: center;
  }
  .hero {
    height: 500px;
    min-height: 500px !important;
  }
  .hero .container {
    height: inherit;
  }
  #section--about .wrapper {
    flex-direction: column;
  }
  #section--about p {
    width: 100% !important;
  }
  .service--item {
    height: 200px;
    min-height: 200px;
  }
  .service--item .digitisation {
    background-size: cover !important;
    background: rgb(0, 0, 0);
    background: linear-gradient(
        0deg,
        rgb(0, 0, 0) 0%,
        rgba(0, 0, 0, 0.85) 35%,
        rgba(80, 80, 80, 0.0372340426) 60%,
        rgba(255, 255, 255, 0) 100%
      ),
      url("./assets/images/services/additional-service.jpg");
  }
  .service--item .microfilm {
    background-size: cover !important;
    background: rgb(0, 0, 0);
    background: linear-gradient(
        0deg,
        rgb(0, 0, 0) 0%,
        rgba(0, 0, 0, 0.85) 35%,
        rgba(80, 80, 80, 0.0372340426) 60%,
        rgba(255, 255, 255, 0) 100%
      ),
      url("./assets/images/services/microfilm-service.png");
  }
  .service--item .disaster-recovery {
    background-size: cover !important;
    background: rgb(0, 0, 0);
    background: linear-gradient(
        0deg,
        rgb(0, 0, 0) 0%,
        rgba(0, 0, 0, 0.85) 35%,
        rgba(80, 80, 80, 0.0372340426) 60%,
        rgba(255, 255, 255, 0) 100%
      ),
      url("assets/images/services/disaster-service.png");
  }
  .service--item .additional-service {
    background-size: cover !important;
    background: rgb(0, 0, 0);
    background: linear-gradient(
        0deg,
        rgb(0, 0, 0) 0%,
        rgba(0, 0, 0, 0.85) 35%,
        rgba(80, 80, 80, 0.0372340426) 60%,
        rgba(255, 255, 255, 0) 100%
      ),
      url("assets/images/services/add-services.png");
  }
  .service--item .service--content-wrapper {
    background-position: center center !important;
  }
  .service--item .service--content-wrapper .service--content {
    padding-right: 1rem;
    padding-left: 1rem;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }
  .service--item .service--content-wrapper .service--content h3 {
    font-size: 1rem;
  }
  .service--item .service--content-wrapper .service--content button {
    font-size: 0.65rem;
  }
  .service--wrapper .jc-center {
    display: flex;
    flex-direction: column;
  }
  #section--testimonals {
    display: none;
  }
  .charity {
    flex-direction: column;
  }
  .needs-priority .content--wrapper {
    width: 100%;
    position: relative;
  }
  .page-bio {
    text-align: left;
    padding: 40px;
  }
  .page-bio p {
    width: 100%;
  }
  .section.meet-team .careers .annoucement {
    font-size: 2rem;
  }
  .section.sdm-holdings {
    padding: 40px 40px 0 40px;
    flex-direction: column;
  }
  .section.sdm-holdings .img {
    margin-bottom: 1.5rem;
  }
  .charity .col-md-6.two {
    padding: 10px;
    order: -1;
  }
  #footer .footer--col.mai,
  #footer .footer--col {
    width: 100% !important;
  }
  .dropdown-menu.show,
  a#basic-nav-dropdown {
    border: none;
    text-align: center;
  }
  .cta {
    font-size: 1rem !important;
    display: flex !important;
    flex-direction: column !important;
    text-align: center;
  }
  .cta .btn--wrapper {
    margin-top: 1rem;
  }
  .service--info {
    text-align: start !important;
  }
  .service--info p {
    width: 100% !important;
  }
  .preservation-cta .row .col-md-6:nth-child(2) {
    order: -1;
    margin-bottom: 2rem;
  }
  .contact--module .top {
    padding: 0 !important;
  }
  .contact--module .contact--options,
  .contact--module .bottom {
    display: none !important;
  }
  .service--selection .type--one,
  .service--selection .type--three {
    width: 100%;
    height: 300px;
  }
  #digitisation .item--description {
    flex-direction: column !important;
  }
  #digitisation .item--description .side--img {
    width: 100% !important;
    justify-content: center;
    display: flex;
  }
  .service-process-container {
    display: none;
  }
  .service--type .card--wrapper {
    display: flex;
    flex-direction: column;
  }
  .service--type .card {
    width: 100%;
    max-width: 100% !important;
    flex-direction: column !important;
    align-items: center;
    text-align: center;
    justify-content: center;
  }
  .service--type .card .heading {
    margin-bottom: 1rem;
  }
  .service--type .card.card:nth-child(2) {
    margin-left: 0 !important;
    margin-top: 40px;
  }
  .card--other-microfilm {
    display: none !important;
  }
  .why-us .row-container {
    display: block !important;
  }
  .why-us .row-container .content--item {
    width: 100% !important;
  }
  #disaster-recovery .content {
    width: 100%;
    padding-left: 0 !important;
  }
  #disaster-recovery .img--wrapper {
    width: 100% !important;
    order: 1;
    margin-top: 2rem;
  }
  #disaster-recovery .section--disaster-help p {
    margin-right: 0;
  }
  #disaster-recovery .section--disaster-help .wrapper {
    display: flex;
    flex-direction: column;
  }
  #disaster-recovery .section--storage p {
    margin-right: 0 !important;
  }
  #disaster-recovery .section--storage .wrapper {
    display: flex;
    flex-direction: column;
  }
  #disaster-recovery .main {
    display: flex;
    flex-direction: column;
  }
  #disaster-recovery .main .content {
    width: 100%;
  }
  #disaster-recovery .btn--wrapper {
    margin-top: 2rem;
  }
  #additional--service .hero--heading h1 {
    font-size: 2.4rem;
  }
  #additional--service nav a,
  #additional--service .navbar a {
    padding-right: 32px;
    padding-left: 32px;
    color: var(--primary);
    text-decoration: none;
    font-weight: 600;
    padding-top: 8px;
    padding-bottom: 8px;
  }
  #footer {
    padding: 35px 10px !important;
  }
  .contact--hero {
    flex-direction: column;
  }
  .map--wrapper {
    flex-direction: column;
  }
  .map--wrapper .card {
    width: 100% !important;
  }
  .map--wrapper .card:first-child {
    margin-bottom: 2rem;
  }
  .map--wrapper .card .mapboxgl-canvas {
    border-radius: 0.5rem;
  }
  #faq .hero {
    height: auto !important;
    min-height: auto !important;
    margin-top: 0;
  }
  #faq .hero .faq-container {
    padding: 20px;
    bottom: 0;
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 40px;
  }
  #faq .hero .faq-container .faq--selection {
    width: 100%;
  }
  #faq .hero .faq-container .faq--content-wrapper {
    width: 100%;
  }
  #faq .hero .faq-container .faq--content-wrapper .fa-chevron-up {
    margin-left: 16px;
    color: #969696;
  }
  #faq .hero .faq-container .faq--content-wrapper h2 {
    font-family: "Figtree", sans-serif;
    font-weight: 700;
  }
  #faq .hero .faq-container ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    overflow-x: auto;
    white-space: nowrap;
  }
  #faq .hero .faq-container li {
    font-size: 1rem !important;
    padding: 0 15px !important;
    color: #969696 !important;
    font-weight: 700;
  }
  #faq .hero .faq-container li.active {
    color: var(--primary) !important;
    padding-bottom: 16px !important;
    border-bottom: 2px solid var(--primary);
    border-left: none !important;
    font-weight: 700;
  }
  #faq .hero .faq-container li .wording {
    display: inline-block;
  }
}
/* @media only screen and (min-width: 767px) and (max-width: 991px) {
} */

@media only screen and (min-width: 767px) and (max-width: 991px) {
  .card--stats .primary-stat {
    font-size: 2rem;
  }
}

/* Styles for medium screens (tablets) */
@media only screen and (min-width: 768px) and (max-width: 1023px) {
  .cta {
    font-size: 1rem !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-around;
  }
  .cta .content {
    padding-bottom: 16px;
  }
  .dropdown-menu.show,
  a#basic-nav-dropdown {
    border: none;
  }
  /* nav {
    position: relative;
    z-index: 10;
  }
  .navbar img {
    height: 60px;
  }
  .navbar .navbar-collapse {
    position: relative;
  }
  .navbar .navbar-nav {
    bottom: -230px;
    left: 0;
    padding: 5%;
    background: #ffffff;
    width: 100%;
    visibility: visible;
    z-index: 9999;
    border-top: 3px solid var(--primary);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    -moz-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    -webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  }
  .navbar .navbar-nav .navbar-collapse {
    transition: ease-in-out 0.2s;
  }
  .logo {
    max-height: 45px;
  } */
  
  img {
    max-height: 275px;
  }

  #london-location img,
  #edinburgh-location img {
    max-height: 350px;
  }

  .logos-slide img {
    height: 40px;
    margin: 0 40px;
  }
  #section--about .top img:first-child {
    max-height: 150px;
    padding-right: 24px;
  }
  #section--about .img-collage:nth-child(2) {
    max-height: 200px;
  }
  #section--about .top {
    display: flex;
    justify-content: flex-end;
  }
  #section--about .bottom {
    display: flex;
    justify-content: flex-end;
  }
  .services-section .service--item {
    min-height: 300px !important;
    height: 300px !important;
  }
  #digitisation .service--type .card {
    display: flex;
    flex-direction: column;
    max-width: 48%;
    padding: 5px;
    align-items: center;
    justify-content: center;
    text-align: center;
  }
  #digitisation .service--type .card img {
    max-height: 50px;
  }
  #digitisation .service--type .card .card--content {
    display: flex;
    width: 90%;
    flex-direction: column;
    margin-top: 16px;
  }
  #digitisation .item--description {
    flex-direction: column !important;
  }
  #digitisation .item--description .side--img {
    width: 100% !important;
    justify-content: center;
    display: flex;
  }
  .section--preservation .img {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  #faq .accordion {
    font-size: 0.8rem;
  }
  #faq .bg {
    background-color: #f1f1f1;
    margin-bottom: 700px;
  }
  #faq .hero .faq-container {
    bottom: -700px;
    padding: 45px;
  }
  #faq .hero .faq-container .faq--selection li {
    font-size: 1.25rem;
  }
  .contact--hero {
    margin: 20px 0 !important;
  }
  .contact--hero .email-us,
  .contact--hero .tel {
    font-size: 1.5rem;
  }
  .locations {
    margin-top: -75px;
    background: #18193f;
    padding-top: 75px;
  }
  .section.meet-team .members-row .content--item {
    padding: 1.25rem 2.5rem;
  }
  .charity .col-md-6.two {
    flex-direction: column !important;
    padding: 15px;
  }
  #additional--service .hero--heading h1 {
    font-size: 3rem;
  }
  .card--support {
    height: auto;
  }
  .card--support .card--item p {
    font-size: 0.8275rem;
  }
  /* nav .navbar-nav {
    align-items: normal;
  }
  nav .navbar a {
    color: #ffffff !important;
    padding-top: 8px;
    padding-bottom: 8px;
  }
  nav .btn--contact {
    margin-left: 32px;
    margin-top: 8px;
    margin-bottom: 8px;
  } */
  #home .home-hero {
    height: 100%;
  }
  #home .home-hero .hero--content {
    height: inherit !important;
    display: flex !important;
    flex-direction: column !important;
  }
  #home .home-hero .hero--content .right-side {
    order: -1 !important; /* Negative order moves it to the start */
  }
  #home .home-hero .swiper .right-side {
    width: 100% !important;
    border-radius: 1.5rem !important;
    height: 100% !important;
  }
  #home .home-hero .swiper .left-side {
    width: 100% !important;
  }
  #home .home-hero .swiper .left-side .inside {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    background-color: #ffffff !important;
    left: 0 !important;
    border-radius: 0rem !important;
  }
  #home .home-hero .swiper .left-side .inside .p-4 {
    align-items: center !important;
  }
  #home .home-hero .swiper .left-side .inside .p-4 h1 {
    color: var(--primary) !important;
    text-align: center !important;
  }
  .hero {
    height: 600px !important;
    min-height: 600px !important;
  }
  .hero .container {
    height: inherit;
  }
}
/* Styles for large screens (laptops) */
@media only screen and (min-width: 1024px) and (max-width: 1439px) {
 
  /* nav {
    position: relative;
    z-index: 10;
  }
  a.navbar-brand {
    margin: 0;
  }
  a.navbar-brand .logo {
    max-height: 55px;
  } */
  
  button.ml-auto.mr-3.btn.btn-btn.btn--contact {
    margin: 0 10px;
  }
  #section--about .top {
    justify-content: end;
  }
  #section--about .top img:first-child {
    max-height: 175px;
    margin-right: 1.5rem;
  }
  #section--about .img--wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  #section--about .img-collage:nth-child(2) {
    max-height: 225px;
  }
  #section--preservation .img {
    text-align: center;
  }
  .needs-priority .content--wrapper {
    width: 135%;
    padding: 5px;
  }
  .section.meet-team .members-row .content--item {
    display: flex;
    flex-direction: column;
    padding: 1.5rem 2.75rem;
    align-items: center;
  }
  #faq .accordion {
    font-size: 0.9rem;
  }
  #faq .bg {
    background-color: #f1f1f1;
  }
  #faq .hero .faq-container {
    padding: 65px;
  }
  #digitisation .service--type .card {
    display: flex;
    flex-direction: column;
    max-width: 48%;
    padding: 5px;
    align-items: center;
    justify-content: center;
    text-align: center;
  }
  #digitisation .service--type .card img {
    max-height: 50px;
  }
  #digitisation .service--type .card .card--content {
    display: flex;
    width: 90%;
    flex-direction: column;
    margin-top: 16px;
  }
}
/* Styles for extra-large screens (desktops/iMacs) */
@media only screen and (min-width: 1440px) {
  /* .logo {
    max-height: 80px !important;
  } */
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  /* nav a,
  .navbar a {
    padding-right: 18px;
    padding-left: 18px;
  }
 */
}


@media only screen and (max-width: 400px) {
  .service--item-desc {
    display: flex;
    flex-direction: column;
    padding-bottom: 2.5rem !important;
  }
  .service--item-desc img {
    width: 100%;
  }
  .service--item-desc .description:nth-child(even) {
    margin-left: 0;
    order: -1;
  }
  .service--item-desc .description:nth-child(odd) {
    margin-right: 0;
  }
  .service--item-desc .description {
    width: 100%;
  }
}

@media only screen and (max-width: 500px) {
  #home .sec--services .card {
    min-height: 250px;
  }
}



/* Core layout */
.careers-section {
  padding: 6rem 1rem;
  background: linear-gradient(180deg, #f2f2f2 0%, #ffffff 100%);
  border-top: 5px solid #e5e5e5;
  border-bottom: 1px solid #e5e7eb;
}

.careers-container {
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}

/* Headings */
.careers-heading {
  font-size: 2rem;
  font-weight: 700;
  color: #111827;
  margin-bottom: 0.75rem;
  line-height: 1.2;
}

.careers-heading span {
  color: var(--primary);
}

.careers-subtitle {
  font-size: 1.1rem;
  color: #4b5563;
  margin-bottom: 2.5rem;
}

/* Card box */
.careers-card {
  background: #ffffff;
  padding: 2.5rem 2rem;
  border-radius: 1.25rem;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
  max-width: 700px;
  margin: 0 auto;
  transition: all 0.3s ease;
}

.careers-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.12);
}

/* Text */
.careers-text {
  color: #374151;
  font-size: 1.05rem;
  margin-bottom: 1rem;
}

.careers-email {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 1.5rem 0;
}

.careers-email a {
  color: var(--primary);
  text-decoration: none;
  transition: color 0.3s ease;
}

.careers-email a:hover {
  color: var(--primary);
}

.careers-note {
  font-size: 0.95rem;
  color: #6b7280;
  line-height: 1.6;
  }
  
  /* Responsive */
  @media (max-width: 768px) {
    .careers-heading {
      font-size: 1.6rem;
    }
    .careers-subtitle {
      font-size: 1rem;
    }
    .careers-card {
      padding: 2rem 1.5rem;
    }
    .logos-slide img {
        height: 20px;
        margin: 0 40px;
    }
  }
    
  /* Group Independent */

#group-info {
  background-color: var(--primary);
}  

.company-brand img {
  height: -webkit-fill-available;
}

button.form-control:focus {
  background-color: var(--secondary);
  
}


/* ===== Utility classes recreated from Tailwind ===== */

/* Spacing */
.py-6 { padding-top: 1.5rem; padding-bottom: 1.5rem; }
@media (min-width: 1024px) {
  .lg\:py-14 {
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
  }
}
.pb-12 { padding-bottom: 3rem; }
.py-0 { padding-top: 0; padding-bottom: 0; }
.p-3 { padding: 0.75rem; }
@media (min-width: 1024px) {
  .lg\:p-8 { padding: 2rem; }
}
.mt-4 { margin-top: 1rem; }
.my-8 { margin-top: 2rem; margin-bottom: 2rem; }
.my-14 { margin-top: 3.5rem; margin-bottom: 3.5rem; }
.py-14 {padding-top: 3.5rem; padding-bottom:3.5rem; }

/* Layout */
.container {
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
}
.mx-auto { margin-left: auto; margin-right: auto; }
.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.block { display: block; }
.w-full { width: 100%; }

/* Grid */
.grid { display: grid; }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.gap-4 { gap: 1rem; }
.lg\:gap-8 { gap: 2rem; }

@media (min-width: 1024px) {
  .lg\:py-14 { padding-top: 3.5rem; padding-bottom: 3.5rem; }
  .lg\:p-8 { padding: 2rem; }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .lg\:gap-8 { gap: 2rem; }
}


/* Text */
.text-center { text-align: center; }
.text-xl { font-size: 1.25rem; line-height: 1.75rem; }
.text-white { color: #ffffff!important; }
.bebas-neue { font-family: "Bebas Neue", sans-serif; }

/* Backgrounds */§
.bg-white { background-color: #ffffff; }

/* Shadows */
.shadow-lg {
  box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1),
              0 4px 6px -4px rgba(0,0,0,0.1);
}

.hidden {
  display: none;
}

/* Custom colours (map your brand palette) */
/* .primary--color { color: #0082c2; }
.secondary--color { color: #171717; } */

/* Card wrapper */
.card {
  border-radius: 0.5rem;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.card:hover {
  transform: translateY(-4px);
}

.btn,
a.btn {
  padding: 6px 20px;
  font-size: 14px;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  justify-content: center;
  border-radius: 25px;
  align-items: center;
  font-weight: 500;
  height: -moz-min-content;
  height: min-content;
  white-space: nowrap!important;
}

.btn--primary {
  border: 2px solid #0082c2;
  background-color: transparent;
  color: #171717;
  padding: 12px 24px;
  gap: 4px;
}
.btn--primary:hover {
  background-color: color(display-p3 0.221 0.503 0.741);
  scale: 1.1;
  color: #ffffff;
}
.btn--primary span {
  display: inline-block;
  transition: color 0.3s;
}

.btn--primary span:hover {
  color: inherit!important;
}

.btn--primary:hover > span {
  color:#ffffff!important;
}

.btn--primary:hover > .primary--color {
  color: #ffffff!important;
}

.my-6 {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}

.y-8 {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

/* ===== Utility / Tailwind-style conversions ===== */

/* Container */
.container {
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
}

/* Center horizontally */
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

/* Section wrapper */
.ukarchiving-section-cta {
  position: relative;
  width: 100%;
  padding: 4rem 0; /* adjust spacing */
  position: relative;
  width: 100%;
  min-height: 625px;
  background-image: url("assets/images/castle-scotland-drone-ukarchiving.webp");
  background-size: cover;
  background-position: center center;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
}

.ukarchiving-section-cta.photography {
  background-image: url("assets/images/edinburgh-castle-cta.jpg")!important;
}

.background-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.1);
}
.content-container {
  position: relative;
  display: flex;
  justify-content: space-between;
  width: 80%;
  height: 100%;
  align-items: center;
}
.left-content {
  flex: 1;
  padding-left: 20px;
}
.white-box {
  background-color: white;
  color: #4b5564;
  padding: 40px;
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
  max-width: 450px;
  position: relative;
}
.box-text {
  font-weight: bold;
  margin-bottom: 15px;
  font-size: 1.5rem !important;
  font-weight: 300;
}
.box-description {
  font-size: 16px;
  line-height: 1.5;
  margin-top: 10px;
}

.service-btn.selected {
  transition: 0.25s ease-in-out all;
  font-weight: 700;
  color: #ffffff;
  background-color: var(--primary);
  border: 2px solid var(--primary) !important;
}

@media screen and (min-width: 1024px) {
  .white-box {
    right: -30px;
  }
}
@media screen and (max-width: 1024px) {
  .content-container {
    flex-direction: column;
    align-items: center;
  }
  .left-content {
    padding: 20px;
    text-align: center;
    display: flex;
    height: -moz-min-content;
    height: min-content;
    justify-content: center;
    align-items: center;
  }
  .mobile-image {
    display: block;
    width: 100%;
    height: auto;
  }
  .chatham-archive-section-cta {
    height: unset;
  }
  /* .background-overlay {
    position: unset;
  } */
}


/* Wrapper card */
/* #stats-card .card {
  background: linear-gradient(135deg, #0082c2 0%, #0b704c 100%);
  box-shadow: 0 6px 20px rgba(0,0,0,0.15);
  text-align: center;
} */

/* Each stat item */
#stats-card .card--item {
  flex-direction: column;
  justify-content: center;
  text-align: center;
}

/* The numbers */
#stats-card .number {
  /* font-family: 'Bebas Neue', sans-serif; */
  font-size: 3.5rem; /* overrides Tailwind’s text-5xl if needed */
  font-weight: 700;
  color: #fff;
  line-height: 1;
  position: relative;
  padding-bottom: 22px;
}


/* The description */
#stats-card .desc {
  font-size: 1rem;
  font-weight: 400;
  color: #e6e6e6;
  line-height: 1.6;
  max-width: 280px;
  margin: 0 auto;
}

#stats-card .card {
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.6) 0, rgba(0, 0, 0, 0) 100%)
      center center/cover,
    url("assets/images/stats-card-background.jpg") center center/cover;
  min-height: 260px;
  /* align-items: flex-start; */
  display: flex;
  flex-direction: row!important;
}
#stats-card .card .card--item {
  display: flex;
  flex-direction: column;
  text-align: center;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  #stats-card .card {
  background-position: center center!important;
  background-size: cover!important;
  background: linear-gradient(0deg, rgba(0, 0, 0, 1) 0, rgba(0, 0, 0, 0.25) 100%)
    center center/cover,
  url("assets/images/stats--card-mobile.jpg") center center/cover;
  display: flex;
  flex-direction: column!important;
}
.ukarchiving-section-cta {
  padding: unset!important
  
} 
}



/* Drone Surveying Service Page */

/* Section background and spacing */
.heritage-section {
  background-color: #f9fafb; 
  padding: 4rem 0; 

}

/* Container width & padding */
.heritage-container {
  max-width: 1200px; 
  margin: 0 auto;
  padding: 0 1.5rem; 
}

/* Heading styling */
.heritage-heading {
  font-size: 1.875rem; 
  line-height: 1.3;
  font-weight: 600;
  margin-bottom: 2.5rem; 
}

/* Responsive grid (2 columns on desktop) */
.heritage-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}

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

/* Lists styling */
.heritage-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.heritage-list li {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1.5rem; 
}

.heritage-list li:last-child {
  margin-bottom: 0;
}

/* Icon (red rectangle) */
.icon {
  display: inline-block;
  width: 2px;
  height: 40px;
  background-color: #00abff; 
  flex-shrink: 0;
  transition: background-color 0.2s ease;
}

/* Text */
.heritage-list p {
  color: #374151; 
  margin: 0;
  line-height: 1.6;
  transition: color 0.2s ease;
}

ul.heritage-list {
  padding-left: 0!important;

}

/* Hover effect */
.heritage-list li:hover .icon {
  background-color: #0082c2 
}

.heritage-list li:hover p {
  color: #111827; 
}


.applications-section {
  padding: 5rem 0;

}

/* Header layout */
.applications-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 4rem;
  margin: 3rem auto;
}

.header-left h2 {
  font-size: 2rem;
  font-weight: 600;
  color: #0f172a;
  margin: 0;
  line-height: 1.3;
}

.header-left .highlight {
  color: color(display-p3 0.221 0.503 0.741);
}

.header-right {
  max-width: 550px;
}

.header-right h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: #0f172a;
  margin-bottom: 0.75rem;
}

.header-right p {
  color: #475569;
  line-height: 1.7;
}

.arrow-down {
  display: flex;
  align-items: center;
  margin-top: 2rem;
  height: 120px; /* control overall arrow height */
}

.arrow-down svg {
  display: block;
}

/* Optional subtle animation */
/* .arrow-down svg {
  animation: arrowPulse 2s ease-in-out infinite;
} */

/* @keyframes arrowPulse {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(6px);
  }
} */

/* Applications grid */
.applications-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

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

/* Box style */
.app-box {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
}

.app-box .icon {
  background-color: color(display-p3 0.221 0.503 0.741);
  color: #fff;
  width: 48px;
  height: 48px;
  border-radius: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.5rem;
  flex-shrink: 0;
  transition: background-color 0.3s ease;
}

.app-box:hover .icon {
  background-color: color(display-p3 0.221 0.503 0.741);
}

.app-box h4 {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0 0 0.25rem;
  color: #1e293b;
  font-family: "Figtree", sans-serif;
}

.app-box p {
  color: #475569;
  margin: 0;
  line-height: 1.6;
  font-size: 0.975rem;
}

.app-box .content {
  padding: 0 20px 20px 20px!important;
}

.service--info {
  max-width: 900px;
  margin: 0 auto;
  padding: 4rem 1.5rem;
  text-align: left;
}

.service--info h2 {
  font-size: 2rem;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
  line-height: 1.3;
  text-align: center;
}

.service--info .primary--color {
  color: color(display-p3 0.221 0.503 0.741);
}

.service--info p {
  font-size: 1rem;
  line-height: 1.8;
  color: #334155;
  margin: 0;
  text-align: center;
  margin: auto;
}

.service--info a {
  color: color(display-p3 0.221 0.503 0.741);
  text-decoration: none;
  font-weight: 600;
}

.service--info a:hover {
  text-decoration: underline;
}

/* Drone Photography Page */

.drone-photography {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (min-width: 1280px) {
  .drone-photography {
    min-height: 456px;
  
  }
}

.left-panel {
  width: 100%;
  margin-bottom: 2rem;
}
.right-panel {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
#service-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-align: left;
}

#service-details {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#service-list button {
  text-align: left;
}

.service-image {
  width: 100%;
  max-width: 90%;
  border-radius: 0.5rem;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  margin-bottom: 1.5rem;
  transition: all 0.3s;
  height: 400px;
}



@media (min-width: 768px) {
    .drone-photography.container {
        flex-direction: row;
    }
    .left-panel {
        width: 33.3333%;
        margin-bottom: 0;
    }
    .right-panel {
        width: 66.6667%;
    }
}
@media (max-width: 767px) {
    #client-priority.my-14 {
      background: unset!important;
    }
    #client-priority .content {
        background-color: rgba(255, 255, 255, 0.92);
        padding: 0!important;
        max-width: unset;
    }
    .logos:after {
        right: 0;
        background: unset!important;
    }
    .logos:before {
        left: 0;
        background: unset!important;
    }
    .white-box {
        padding: 10px;
        background: unset !important;
        position: relative;
        z-index: 0;
        color: white;
    }
    
    .ukarchiving-section-cta .content-container {
        position: relative;
        display: flex;
        justify-content: space-between;
        width: 90%;
        height: 100%;
        align-items: center;
        color: white;
    }
      .ukarchiving-section-cta .white-box::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(255, 255, 255, 0.15);
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
        border-radius: 1rem;
        z-index: -1;
      }
      
      .white-box .box-description, .white-box .box-text {
        color: white!important;
      }
      
      .white-box .box-text {
        font-weight: 600;
      }
}


.glide__arrow--left {
  left: 0!important;
}

.glide__arrow--right {
  right: 0!important;
}



@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
      "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --color-red-100: oklch(93.6% 0.032 17.717);
    --color-red-500: oklch(63.7% 0.237 25.331);
    --color-green-100: oklch(96.2% 0.044 156.743);
    --color-green-500: oklch(72.3% 0.219 149.579);
    --color-green-600: oklch(62.7% 0.194 149.214);
    --color-green-800: oklch(44.8% 0.119 151.328);
    --color-blue-500: oklch(62.3% 0.214 259.815);
    --color-blue-600: oklch(54.6% 0.245 262.881);
    --color-blue-800: oklch(42.4% 0.199 265.638);
    --color-indigo-500: oklch(58.5% 0.233 277.117);
    --color-gray-50: oklch(98.5% 0.002 247.839);
    --color-gray-100: oklch(96.7% 0.003 264.542);
    --color-gray-200: oklch(92.8% 0.006 264.531);
    --color-gray-300: oklch(87.2% 0.01 258.338);
    --color-gray-400: oklch(70.7% 0.022 261.325);
    --color-gray-500: oklch(55.1% 0.027 264.364);
    --color-gray-600: oklch(44.6% 0.03 256.802);
    --color-gray-700: oklch(37.3% 0.034 259.733);
    --color-gray-800: oklch(27.8% 0.033 256.848);
    --color-gray-900: oklch(21% 0.034 264.665);
    --color-black: #000;
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-4xl: 56rem;
    --container-7xl: 80rem;
    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --font-weight-thin: 100;
    --font-weight-light: 300;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    --tracking-tight: -0.025em;
    --leading-tight: 1.25;
    --leading-normal: 1.5;
    --leading-relaxed: 1.625;
    --leading-loose: 2;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --blur-sm: 8px;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
      -o-tab-size: 4;
         tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::-moz-placeholder {
    opacity: 1;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::-moz-placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    -webkit-appearance: button;
       -moz-appearance: button;
            appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .visible {
    visibility: visible;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .top-2 {
    top: calc(var(--spacing) * 2);
  }
  .top-\[-1px\] {
    top: -1px;
  }
  .right-2 {
    right: calc(var(--spacing) * 2);
  }
  .bottom-2 {
    bottom: calc(var(--spacing) * 2);
  }
  .-left-\[10px\] {
    left: calc(10px * -1);
  }
  .left-\[4px\] {
    left: 4px;
  }
  .isolate {
    isolation: isolate;
  }
  .z-10 {
    z-index: 10;
  }
  .z-50 {
    z-index: 50;
  }
  .order-1 {
    order: 1;
  }
  .order-2 {
    order: 2;
  }
  .order-first {
    order: -9999;
  }
  .col-3 {
    grid-column: 3;
  }
  .col-span-full {
    grid-column: 1 / -1;
  }
  .float-left {
    float: left;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .-m-3 {
    margin: calc(var(--spacing) * -3);
  }
  .m-4 {
    margin: calc(var(--spacing) * 4);
  }
  .mx-12 {
    margin-inline: calc(var(--spacing) * 12);
  }
  .mx-auto {
    margin-inline: auto;
  }
  .my-1 {
    margin-block: calc(var(--spacing) * 1);
  }
  .my-4 {
    margin-block: calc(var(--spacing) * 4);
  }
  .my-5 {
    margin-block: calc(var(--spacing) * 5);
  }
  .my-6 {
    margin-block: calc(var(--spacing) * 6);
  }
  .my-8 {
    margin-block: calc(var(--spacing) * 8);
  }
  .my-10 {
    margin-block: calc(var(--spacing) * 10);
  }
  .my-12 {
    margin-block: calc(var(--spacing) * 12);
  }
  .my-14 {
    margin-block: calc(var(--spacing) * 14);
  }
  .my-16 {
    margin-block: calc(var(--spacing) * 16);
  }
  .my-20 {
    margin-block: calc(var(--spacing) * 20);
  }
  .my-auto {
    margin-block: auto;
  }
  .-mt-8 {
    margin-top: calc(var(--spacing) * -8);
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }
  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }
  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }
  .mt-10 {
    margin-top: calc(var(--spacing) * 10);
  }
  .mt-12 {
    margin-top: calc(var(--spacing) * 12);
  }
  .mt-14 {
    margin-top: calc(var(--spacing) * 14);
  }
  .mt-16 {
    margin-top: calc(var(--spacing) * 16);
  }
  .mt-20 {
    margin-top: calc(var(--spacing) * 20);
  }
  .mt-\[-70px\] {
    margin-top: -70px;
  }
  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }
  .mr-3 {
    margin-right: calc(var(--spacing) * 3);
  }
  .mb-0 {
    margin-bottom: calc(var(--spacing) * 0);
  }
  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }
  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }
  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }
  .mb-10 {
    margin-bottom: calc(var(--spacing) * 10);
  }
  .mb-12 {
    margin-bottom: calc(var(--spacing) * 12);
  }
  .mb-14 {
    margin-bottom: calc(var(--spacing) * 14);
  }
  .mb-50 {
    margin-bottom: calc(var(--spacing) * 50);
  }
  .ml-2 {
    margin-left: calc(var(--spacing) * 2);
  }
  .ml-4 {
    margin-left: calc(var(--spacing) * 4);
  }
  .ml-auto {
    margin-left: auto;
  }
  .box-content {
    box-sizing: content-box;
  }
  .line-clamp-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .table {
    display: table;
  }
  .aspect-square {
    aspect-ratio: 1 / 1;
  }
  .size-5 {
    width: calc(var(--spacing) * 5);
    height: calc(var(--spacing) * 5);
  }
  .size-full {
    width: 100%;
    height: 100%;
  }
  .h-0 {
    height: calc(var(--spacing) * 0);
  }
  .h-3\/5 {
    height: calc(3/5 * 100%);
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-6 {
    height: calc(var(--spacing) * 6);
  }
  .h-12 {
    height: calc(var(--spacing) * 12);
  }
  .h-16 {
    height: calc(var(--spacing) * 16);
  }
  .h-20 {
    height: calc(var(--spacing) * 20);
  }
  .h-64 {
    height: calc(var(--spacing) * 64);
  }
  .h-80 {
    height: calc(var(--spacing) * 80);
  }
  .h-\[275px\] {
    height: 275px;
  }
  .h-auto {
    height: auto;
  }
  .h-full {
    height: 100%;
  }
  .max-h-20 {
    max-height: calc(var(--spacing) * 20);
  }
  .max-h-\[340px\] {
    max-height: 340px;
  }
  .w-1\/2 {
    width: calc(1/2 * 100%);
  }
  .w-1\/3 {
    width: calc(1/3 * 100%);
  }
  .w-1\/4 {
    width: calc(1/4 * 100%);
  }
  .w-2\/3 {
    width: calc(2/3 * 100%);
  }
  .w-3\/4 {
    width: calc(3/4 * 100%);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-4\/5 {
    width: calc(4/5 * 100%);
  }
  .w-5\/6 {
    width: calc(5/6 * 100%);
  }
  .w-6 {
    width: calc(var(--spacing) * 6);
  }
  .w-12 {
    width: calc(var(--spacing) * 12);
  }
  .w-100 {
    width: calc(var(--spacing) * 100);
  }
  .w-full {
    width: 100%;
  }
  .w-min {
    width: -moz-min-content;
    width: min-content;
  }
  .max-w-2xl {
    max-width: var(--container-2xl);
  }
  .max-w-4xl {
    max-width: var(--container-4xl);
  }
  .max-w-xl {
    max-width: var(--container-xl);
  }
  .flex-none {
    flex: none;
  }
  .grow {
    flex-grow: 1;
  }
  .border-collapse {
    border-collapse: collapse;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .resize {
    resize: both;
  }
  .list-inside {
    list-style-position: inside;
  }
  .list-outside {
    list-style-position: outside;
  }
  .list-disc {
    list-style-type: disc;
  }
  .list-none {
    list-style-type: none;
  }
  .appearance-none {
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
  }
  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-row {
    flex-direction: row;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-baseline {
    align-items: baseline;
  }
  .items-center {
    align-items: center;
  }
  .items-start {
    align-items: flex-start;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-end {
    justify-content: flex-end;
  }
  .justify-start {
    justify-content: flex-start;
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }
  .gap-8 {
    gap: calc(var(--spacing) * 8);
  }
  .gap-14 {
    gap: calc(var(--spacing) * 14);
  }
  .space-y-1 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-4 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-6 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-8 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .gap-x-3 {
    -moz-column-gap: calc(var(--spacing) * 3);
         column-gap: calc(var(--spacing) * 3);
  }
  .gap-x-8 {
    -moz-column-gap: calc(var(--spacing) * 8);
         column-gap: calc(var(--spacing) * 8);
  }
  .space-x-2 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-4 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 4) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-8 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 8) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .gap-y-2 {
    row-gap: calc(var(--spacing) * 2);
  }
  .gap-y-4 {
    row-gap: calc(var(--spacing) * 4);
  }
  .overflow-auto {
    overflow: auto;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .overflow-x-auto {
    overflow-x: auto;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-full {
    border-radius: calc(infinity * 1px);
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-md {
    border-radius: var(--radius-md);
  }
  .rounded-xl {
    border-radius: var(--radius-xl);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }
  .border-t-4 {
    border-top-style: var(--tw-border-style);
    border-top-width: 4px;
  }
  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
  .border-\[\#0082c26e\] {
    border-color: #0082c26e;
  }
  .border-gray-200 {
    border-color: var(--color-gray-200);
  }
  .border-gray-300 {
    border-color: var(--color-gray-300);
  }
  .border-t-\[\#0082c2\] {
    border-top-color: #0082c2;
  }
  .bg-\[\#0082c2\] {
    background-color: #0082c2;
  }
  .bg-\[\#0082c2\] {
    background-color: #0082c2;
  }
  .bg-\[rgba\(0\,0\,0\,\.03\)\] {
    background-color: rgba(0,0,0,.03);
  }
  .bg-\[rgba\(0\,0\,0\,\.06\)\] {
    background-color: rgba(0,0,0,.06);
  }
  .bg-black {
    background-color: var(--color-black);
  }
  .bg-gray-50 {
    background-color: var(--color-gray-50);
  }
  .bg-gray-200 {
    background-color: var(--color-gray-200);
  }
  .bg-gray-800 {
    background-color: var(--color-gray-800);
  }
  .bg-gray-900 {
    background-color: var(--color-gray-900);
  }
  .bg-green-100 {
    background-color: var(--color-green-100);
  }
  .bg-green-500 {
    background-color: var(--color-green-500);
  }
  .bg-red-100 {
    background-color: var(--color-red-100);
  }
  .bg-red-500 {
    background-color: var(--color-red-500);
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .bg-gradient-to-r {
    --tw-gradient-position: to right in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }
  .bg-\[linear-gradient\(to_right\,_white_0\%\,_rgba\(255\,255\,255\,0\.35\)_30\%\,_rgba\(255\,255\,255\,0\)_45\%\,_rgba\(255\,255\,255\,0\)_100\%\)\] {
    background-image: linear-gradient(to right, white 0%, rgba(255,255,255,0.35) 30%, rgba(255,255,255,0) 45%, rgba(255,255,255,0) 100%);
  }
  .bg-\[linear-gradient\(to_right\,_white_0\%\,_rgba\(255\,255\,255\,0\.45\)_20\%\,_rgba\(255\,255\,255\,0\)_35\%\,_rgba\(255\,255\,255\,0\)_100\%\)\] {
    background-image: linear-gradient(to right, white 0%, rgba(255,255,255,0.45) 20%, rgba(255,255,255,0) 35%, rgba(255,255,255,0) 100%);
  }
  .bg-\[linear-gradient\(to_right\,_white_0\%\,_rgba\(255\,255\,255\,0\.45\)_30\%\,_rgba\(255\,255\,255\,0\)_45\%\,_rgba\(255\,255\,255\,0\)_100\%\)\] {
    background-image: linear-gradient(to right, white 0%, rgba(255,255,255,0.45) 30%, rgba(255,255,255,0) 45%, rgba(255,255,255,0) 100%);
  }
  .from-\[\#8cc64f\] {
    --tw-gradient-from: #8cc64f;
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-green-800 {
    --tw-gradient-to: var(--color-green-800);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .bg-cover {
    background-size: cover;
  }
  .bg-center {
    background-position: center;
  }
  .bg-top {
    background-position: top;
  }
  .object-contain {
    -o-object-fit: contain;
       object-fit: contain;
  }
  .object-cover {
    -o-object-fit: cover;
       object-fit: cover;
  }
  .object-center {
    -o-object-position: center;
       object-position: center;
  }
  .p-2 {
    padding: calc(var(--spacing) * 2);
  }
  .p-3 {
    padding: calc(var(--spacing) * 3);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .p-8 {
    padding: calc(var(--spacing) * 8);
  }
  .p-10 {
    padding: calc(var(--spacing) * 10);
  }
  .p-12 {
    padding: calc(var(--spacing) * 12);
  }
  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }
  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }
  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .px-8 {
    padding-inline: calc(var(--spacing) * 8);
  }
  .px-12 {
    padding-inline: calc(var(--spacing) * 12);
  }
  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }
  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }
  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }
  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }
  .py-10 {
    padding-block: calc(var(--spacing) * 10);
  }
  .py-12 {
    padding-block: calc(var(--spacing) * 12);
  }
  .py-14 {
    padding-block: calc(var(--spacing) * 14);
  }
  .py-16 {
    padding-block: calc(var(--spacing) * 16);
  }
  .py-20 {
    padding-block: calc(var(--spacing) * 20);
  }
  .py-22 {
    padding-block: calc(var(--spacing) * 22);
  }
  .py-24 {
    padding-block: calc(var(--spacing) * 24);
  }
  .pt-1 {
    padding-top: calc(var(--spacing) * 1);
  }
  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }
  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }
  .pt-8 {
    padding-top: calc(var(--spacing) * 8);
  }
  .pt-12 {
    padding-top: calc(var(--spacing) * 12);
  }
  .pt-16 {
    padding-top: calc(var(--spacing) * 16);
  }
  .pt-32 {
    padding-top: calc(var(--spacing) * 32);
  }
  .pr-4 {
    padding-right: calc(var(--spacing) * 4);
  }
  .pr-6 {
    padding-right: calc(var(--spacing) * 6);
  }
  .pr-8 {
    padding-right: calc(var(--spacing) * 8);
  }
  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }
  .pb-3 {
    padding-bottom: calc(var(--spacing) * 3);
  }
  .pb-4 {
    padding-bottom: calc(var(--spacing) * 4);
  }
  .pb-6 {
    padding-bottom: calc(var(--spacing) * 6);
  }
  .pb-8 {
    padding-bottom: calc(var(--spacing) * 8);
  }
  .pb-12 {
    padding-bottom: calc(var(--spacing) * 12);
  }
  .pb-16 {
    padding-bottom: calc(var(--spacing) * 16);
  }
  .pb-24 {
    padding-bottom: calc(var(--spacing) * 24);
  }
  .pb-\[40\%\] {
    padding-bottom: 40%;
  }
  .pb-\[125\%\] {
    padding-bottom: 125%;
  }
  .pl-4 {
    padding-left: calc(var(--spacing) * 4);
  }
  .pl-8 {
    padding-left: calc(var(--spacing) * 8);
  }
  .pl-10 {
    padding-left: calc(var(--spacing) * 10);
  }
  .text-center {
    text-align: center;
  }
  .text-left {
    text-align: left;
  }
  .text-start {
    text-align: start;
  }
  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }
  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--line-height));
  }
  .text-5xl {
    font-size: var(--text-5xl);
    line-height: var(--tw-leading, var(--text-5xl--line-height));
  }
  .text-6xl {
    font-size: var(--text-6xl);
    line-height: var(--tw-leading, var(--text-6xl--line-height));
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-base\/7 {
    font-size: var(--text-base);
    line-height: calc(var(--spacing) * 7);
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .text-sm\/6 {
    font-size: var(--text-sm);
    line-height: calc(var(--spacing) * 6);
  }
  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }
  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
  .leading-\[180\%\] {
    --tw-leading: 180%;
    line-height: 180%;
  }
  .leading-loose {
    --tw-leading: var(--leading-loose);
    line-height: var(--leading-loose);
  }
  .leading-none {
    --tw-leading: 1;
    line-height: 1;
  }
  .leading-normal {
    --tw-leading: var(--leading-normal);
    line-height: var(--leading-normal);
  }
  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  .leading-tight {
    --tw-leading: var(--leading-tight);
    line-height: var(--leading-tight);
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-extrabold {
    --tw-font-weight: var(--font-weight-extrabold);
    font-weight: var(--font-weight-extrabold);
  }
  .font-light {
    --tw-font-weight: var(--font-weight-light);
    font-weight: var(--font-weight-light);
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .font-thin {
    --tw-font-weight: var(--font-weight-thin);
    font-weight: var(--font-weight-thin);
  }
  .tracking-tight {
    --tw-tracking: var(--tracking-tight);
    letter-spacing: var(--tracking-tight);
  }
  .text-pretty {
    text-wrap: pretty;
  }
  .whitespace-nowrap {
    white-space: nowrap;
  }
  .text-\[\#0082c2\] {
    color: #0082c2;
  }
  .text-\[\#dedede7d\] {
    color: #dedede7d;
  }
  .text-\[085039\] {
    color: 085039;
  }
  .text-black {
    color: var(--color-black);
  }
  .text-blue-500 {
    color: var(--color-blue-500);
  }
  .text-blue-600 {
    color: var(--color-blue-600);
  }
  .text-gray-400 {
    color: var(--color-gray-400);
  }
  .text-gray-500 {
    color: var(--color-gray-500);
  }
  .text-gray-600 {
    color: var(--color-gray-600);
  }
  .text-gray-700 {
    color: var(--color-gray-700);
  }
  .text-gray-800 {
    color: var(--color-gray-800);
  }
  .text-gray-900 {
    color: var(--color-gray-900);
  }
  .text-green-600 {
    color: var(--color-green-600);
  }
  .text-red-500 {
    color: var(--color-red-500);
  }
  .text-white {
    color: var(--color-white);
  }
  .lowercase {
    text-transform: lowercase;
  }
  .uppercase {
    text-transform: uppercase;
  }
  .underline {
    text-decoration-line: underline;
  }
  .opacity-0 {
    opacity: 0%;
  }
  .opacity-50 {
    opacity: 50%;
  }
  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-2xl {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / 0.25));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[0px_0px_30px_0px_rgba\(0\,_0\,_0\,_0\.1\)\] {
    --tw-shadow: 0px 0px 30px 0px var(--tw-shadow-color, rgba(0, 0, 0, 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[1px_0px_20px_-8px_\#000000\] {
    --tw-shadow: 1px 0px 20px -8px var(--tw-shadow-color, #000000);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-xl {
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
  .outline-1 {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
  .-outline-offset-1 {
    outline-offset: calc(1px * -1);
  }
  .outline-black\/10 {
    outline-color: color-mix(in srgb, #000 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      outline-color: color-mix(in oklab, var(--color-black) 10%, transparent);
    }
  }
  .filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .backdrop-blur-sm {
    --tw-backdrop-blur: blur(var(--blur-sm));
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .duration-200 {
    --tw-duration: 200ms;
    transition-duration: 200ms;
  }
  .duration-300 {
    --tw-duration: 300ms;
    transition-duration: 300ms;
  }
  .duration-1000 {
    --tw-duration: 1000ms;
    transition-duration: 1000ms;
  }
  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }
  .\[code\:protected\] {
    code: protected;
  }
  .\[file\:protected\] {
    file: protected;
  }
  .\[line\:protected\] {
    line: protected;
  }
  .\[message\:protected\] {
    message: protected;
  }
  .hover\:scale-110 {
    &:hover {
      @media (hover: hover) {
        --tw-scale-x: 110%;
        --tw-scale-y: 110%;
        --tw-scale-z: 110%;
        scale: var(--tw-scale-x) var(--tw-scale-y);
      }
    }
  }
  .hover\:bg-gray-100 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-100);
      }
    }
  }
  .hover\:bg-gray-900 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-900);
      }
    }
  }
  .hover\:text-\[\#0082c2\] {
    &:hover {
      @media (hover: hover) {
        color: #0082c2;
      }
    }
  }
  .hover\:text-blue-800 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-blue-800);
      }
    }
  }
  .hover\:text-gray-900 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-900);
      }
    }
  }
  .hover\:text-indigo-500 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-indigo-500);
      }
    }
  }
  .hover\:underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: underline;
      }
    }
  }
  .focus\:border-blue-500 {
    &:focus {
      border-color: var(--color-blue-500);
    }
  }
  .focus\:border-green-500 {
    &:focus {
      border-color: var(--color-green-500);
    }
  }
  .focus\:ring-2 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-blue-500 {
    &:focus {
      --tw-ring-color: var(--color-blue-500);
    }
  }
  .focus\:ring-offset-2 {
    &:focus {
      --tw-ring-offset-width: 2px;
      --tw-ring-offset-shadow: var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    }
  }
  .focus\:outline-none {
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
    }
  }
  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));	
  }
  
  .max-lg\:mt-16 {
    @media (width < 64rem) {
      margin-top: calc(var(--spacing) * 16);
    }
  }
  .max-sm\:pb-4 {
    @media (width < 40rem) {
      padding-bottom: calc(var(--spacing) * 4);
    }
  }
  .sm\:mb-0 {
    @media (width >= 40rem) {
      margin-bottom: calc(var(--spacing) * 0);
    }
  }
  .sm\:flex {
    @media (width >= 40rem) {
      display: flex;
    }
  }
  .sm\:w-1\/3 {
    @media (width >= 40rem) {
      width: calc(1/3 * 100%);
    }
  }
  .sm\:w-full {
    @media (width >= 40rem) {
      width: 100%;
    }
  }
  .sm\:grid-cols-2 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-4 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .sm\:flex-row {
    @media (width >= 40rem) {
      flex-direction: row;
    }
  }
  .sm\:space-x-6 {
    @media (width >= 40rem) {
      :where(& > :not(:last-child)) {
        --tw-space-x-reverse: 0;
        margin-inline-start: calc(calc(var(--spacing) * 6) * var(--tw-space-x-reverse));
        margin-inline-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-x-reverse)));
      }
    }
  }
  .sm\:px-0 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 0);
    }
  }
  .sm\:py-24 {
    @media (width >= 40rem) {
      padding-block: calc(var(--spacing) * 24);
    }
  }
  .sm\:py-32 {
    @media (width >= 40rem) {
      padding-block: calc(var(--spacing) * 32);
    }
  }
  .sm\:text-5xl {
    @media (width >= 40rem) {
      font-size: var(--text-5xl);
      line-height: var(--tw-leading, var(--text-5xl--line-height));
    }
  }
  .md\:mr-4 {
    @media (width >= 48rem) {
      margin-right: calc(var(--spacing) * 4);
    }
  }
  .md\:mb-0 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 0);
    }
  }
  .md\:w-1\/2 {
    @media (width >= 48rem) {
      width: calc(1/2 * 100%);
    }
  }
  .md\:w-1\/3 {
    @media (width >= 48rem) {
      width: calc(1/3 * 100%)!important;
    }
  }
  .md\:w-2\/3 {
    @media (width >= 48rem) {
      width: calc(2/3 * 100%)!important;
    }
  }
  .md\:w-2\/5 {
    @media (width >= 48rem) {
      width: calc(2/5 * 100%);
    }
  }
  .md\:w-3\/5 {
    @media (width >= 48rem) {
      width: calc(3/5 * 100%);
    }
  }
  .md\:grid-cols-2 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-3 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-4 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .md\:flex-row {
    @media (width >= 48rem) {
      flex-direction: row;
    }
  }
  .md\:gap-x-4 {
    @media (width >= 48rem) {
      -moz-column-gap: calc(var(--spacing) * 4);
           column-gap: calc(var(--spacing) * 4);
    }
  }
  .md\:gap-y-8 {
    @media (width >= 48rem) {
      row-gap: calc(var(--spacing) * 8);
    }
  }
  .md\:pt-16 {
    @media (width >= 48rem) {
      padding-top: calc(var(--spacing) * 16);
    }
  }
  .lg\:order-1 {
    @media (width >= 64rem) {
      order: 1;
    }
  }
  .lg\:order-2 {
    @media (width >= 64rem) {
      order: 2;
    }
  }
  .lg\:col-span-1 {
    @media (width >= 64rem) {
      grid-column: span 1 / span 1;
    }
  }
  .lg\:col-span-2 {
    @media (width >= 64rem) {
      grid-column: span 2 / span 2;
    }
  }
  .lg\:row-span-2 {
    @media (width >= 64rem) {
      grid-row: span 2 / span 2;
    }
  }
  .lg\:container {
    @media (width >= 64rem) {
      width: 100%;
      @media (width >= 40rem) {
        max-width: 40rem;
      }
      @media (width >= 48rem) {
        max-width: 48rem;
      }
      @media (width >= 64rem) {
        max-width: 64rem;
      }
      @media (width >= 80rem) {
        max-width: 80rem;
      }
      @media (width >= 96rem) {
        max-width: 96rem;
      }
    }
  }
  .lg\:mx-0 {
    @media (width >= 64rem) {
      margin-inline: calc(var(--spacing) * 0);
    }
  }
  .lg\:my-12 {
    @media (width >= 64rem) {
      margin-block: calc(var(--spacing) * 12);
    }
  }
  .lg\:-mt-40 {
    @media (width >= 64rem) {
      margin-top: calc(var(--spacing) * -40);
    }
  }
  .lg\:mt-0 {
    @media (width >= 64rem) {
      margin-top: calc(var(--spacing) * 0);
    }
  }
  .lg\:mr-0 {
    @media (width >= 64rem) {
      margin-right: calc(var(--spacing) * 0);
    }
  }
  .lg\:mr-14 {
    @media (width >= 64rem) {
      margin-right: calc(var(--spacing) * 14);
    }
  }
  .lg\:mb-0 {
    @media (width >= 64rem) {
      margin-bottom: calc(var(--spacing) * 0);
    }
  }
  .lg\:-ml-8 {
    @media (width >= 64rem) {
      margin-left: calc(var(--spacing) * -8);
    }
  }
  .lg\:ml-8 {
    @media (width >= 64rem) {
      margin-left: calc(var(--spacing) * 8);
    }
  }
  .lg\:ml-14 {
    @media (width >= 64rem) {
      margin-left: calc(var(--spacing) * 14);
    }
  }
  .lg\:block {
    @media (width >= 64rem) {
      display: block;
    }
  }
  .lg\:contents {
    @media (width >= 64rem) {
      display: contents;
    }
  }
  .lg\:flex {
    @media (width >= 64rem) {
      display: flex;
    }
  }
  .lg\:hidden {
    @media (width >= 64rem) {
      display: none;
    }
  }
  .lg\:h-80 {
    @media (width >= 64rem) {
      height: calc(var(--spacing) * 80);
    }
  }
  .lg\:h-auto {
    @media (width >= 64rem) {
      height: auto;
    }
  }
  .lg\:h-full {
    @media (width >= 64rem) {
      height: 100%;
    }
  }
  .lg\:w-1\/2 {
    @media (width >= 64rem) {
      width: calc(1/2 * 100%);
    }
  }
  .lg\:w-1\/3 {
    @media (width >= 64rem) {
      width: calc(1/3 * 100%);
    }
  }
  .lg\:w-1\/4 {
    @media (width >= 64rem) {
      width: calc(1/4 * 100%);
    }
  }
  .lg\:w-1\/5 {
    @media (width >= 64rem) {
      width: calc(1/5 * 100%);
    }
  }
  .lg\:w-2\/3 {
    @media (width >= 64rem) {
      width: calc(2/3 * 100%);
    }
  }
  .lg\:w-2\/4 {
    @media (width >= 64rem) {
      width: calc(2/4 * 100%);
    }
  }
  .lg\:w-2\/5 {
    @media (width >= 64rem) {
      width: calc(2/5 * 100%);
    }
  }
  .lg\:w-3\/4 {
    @media (width >= 64rem) {
      width: calc(3/4 * 100%);
    }
  }
  .lg\:w-3\/5 {
    @media (width >= 64rem) {
      width: calc(3/5 * 100%);
    }
  }
  .lg\:w-full {
    @media (width >= 64rem) {
      width: 100%;
    }
  }
  .lg\:max-w-7xl {
    @media (width >= 64rem) {
      max-width: var(--container-7xl);
    }
  }
  .lg\:max-w-none {
    @media (width >= 64rem) {
      max-width: none;
    }
  }
  .lg\:flex-none {
    @media (width >= 64rem) {
      flex: none;
    }
  }
  .lg\:shrink {
    @media (width >= 64rem) {
      flex-shrink: 1;
    }
  }
  .lg\:grow {
    @media (width >= 64rem) {
      flex-grow: 1;
    }
  }
  .lg\:grow-0 {
    @media (width >= 64rem) {
      flex-grow: 0;
    }
  }
  .lg\:grid-cols-2 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-3 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-4 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-5 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }
  }
  .lg\:flex-row {
    @media (width >= 64rem) {
      flex-direction: row!important;
    }
  }
  
  /* Base (mobile-first): default flex direction is column */
  .lg\:flex-row {
    display: flex;
    flex-direction: column;
  }
  
  /* Large breakpoint (≥1024px): flex direction switches to row */
  @media (min-width: 1024px) {
    .lg\:flex-row {
      flex-direction: row;
    }
  }

  .lg\:flex-row-reverse {
    @media (width >= 64rem) {
      flex-direction: row-reverse;
    }
  }
  .lg\:items-center {
    @media (width >= 64rem) {
      align-items: center;
    }
  }
  .lg\:justify-between {
    @media (width >= 64rem) {
      justify-content: space-between;
    }
  }
  .lg\:gap-4 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 4);
    }
  }
  .lg\:gap-8 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 8);
    }
  }
  .lg\:gap-x-8 {
    @media (width >= 64rem) {
      -moz-column-gap: calc(var(--spacing) * 8);
           column-gap: calc(var(--spacing) * 8);
    }
  }
  .lg\:gap-y-16 {
    @media (width >= 64rem) {
      row-gap: calc(var(--spacing) * 16);
    }
  }
  .lg\:border-none {
    @media (width >= 64rem) {
      --tw-border-style: none;
      border-style: none;
    }
  }
  .lg\:p-0 {
    @media (width >= 64rem) {
      padding: calc(var(--spacing) * 0);
    }
  }
  .lg\:p-8 {
    @media (width >= 64rem) {
      padding: calc(var(--spacing) * 8);
    }
  }
  .lg\:p-10 {
    @media (width >= 64rem) {
      padding: calc(var(--spacing) * 10);
    }
  }
  .lg\:p-14 {
    @media (width >= 64rem) {
      padding: calc(var(--spacing) * 14);
    }
  }
  .lg\:p-20 {
    @media (width >= 64rem) {
      padding: calc(var(--spacing) * 20);
    }
  }
  .lg\:px-0 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 0);
    }
  }
  .lg\:px-4 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 4);
    }
  }
  .lg\:px-8 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .lg\:px-12 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 12);
    }
  }
  .lg\:px-14 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 14);
    }
  }
  .lg\:px-16 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 16);
    }
  }
  .lg\:py-0 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 0);
    }
  }
  .lg\:py-1 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 1);
    }
  }
  .lg\:py-2 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 2);
    }
  }
  .lg\:py-6 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 6);
    }
  }
  .lg\:py-12 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 12);
    }
  }
  .lg\:py-14 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 14);
    }
  }
  .lg\:pt-0 {
    @media (width >= 64rem) {
      padding-top: calc(var(--spacing) * 0);
    }
  }
  .lg\:pt-16 {
    @media (width >= 64rem) {
      padding-top: calc(var(--spacing) * 16);
    }
  }
  .lg\:pt-32 {
    @media (width >= 64rem) {
      padding-top: calc(var(--spacing) * 32);
    }
  }
  .lg\:pt-44 {
    @media (width >= 64rem) {
      padding-top: calc(var(--spacing) * 44);
    }
  }
  .lg\:pr-4 {
    @media (width >= 64rem) {
      padding-right: calc(var(--spacing) * 4);
    }
  }
  .lg\:pr-6 {
    @media (width >= 64rem) {
      padding-right: calc(var(--spacing) * 6);
    }
  }
  .lg\:pr-8 {
    @media (width >= 64rem) {
      padding-right: calc(var(--spacing) * 8);
    }
  }
  .lg\:pr-14 {
    @media (width >= 64rem) {
      padding-right: calc(var(--spacing) * 14);
    }
  }
  .lg\:pb-0 {
    @media (width >= 64rem) {
      padding-bottom: calc(var(--spacing) * 0);
    }
  }
  .lg\:pb-1 {
    @media (width >= 64rem) {
      padding-bottom: calc(var(--spacing) * 1);
    }
  }
  .lg\:pb-4 {
    @media (width >= 64rem) {
      padding-bottom: calc(var(--spacing) * 4);
    }
  }
  .lg\:pl-4 {
    @media (width >= 64rem) {
      padding-left: calc(var(--spacing) * 4);
    }
  }
  .lg\:pl-10 {
    @media (width >= 64rem) {
      padding-left: calc(var(--spacing) * 10);
    }
  }
  .lg\:pl-14 {
    @media (width >= 64rem) {
      padding-left: calc(var(--spacing) * 14);
    }
  }
  .lg\:text-left {
    @media (width >= 64rem) {
      text-align: left;
    }
  }
  .lg\:text-6xl {
    @media (width >= 64rem) {
      font-size: var(--text-6xl);
      line-height: var(--tw-leading, var(--text-6xl--line-height));
    }
  }
  .lg\:text-base {
    @media (width >= 64rem) {
      font-size: var(--text-base);
      line-height: var(--tw-leading, var(--text-base--line-height));
    }
  }
  .xl\:inset-y-0 {
    @media (width >= 80rem) {
      inset-block: calc(var(--spacing) * 0);
    }
  }
  .xl\:mr-auto {
    @media (width >= 80rem) {
      margin-right: auto;
    }
  }
  .xl\:ml-0 {
    @media (width >= 80rem) {
      margin-left: calc(var(--spacing) * 0);
    }
  }
  .xl\:gap-8 {
    @media (width >= 80rem) {
      gap: calc(var(--spacing) * 8);
    }
  }


@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-space-x-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-gradient-position {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-from {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-via {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-to {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-stops {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-via-stops {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-from-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0%;
}
@property --tw-gradient-via-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 50%;
}
@property --tw-gradient-to-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-tracking {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-duration {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-space-x-reverse: 0;
      --tw-border-style: solid;
      --tw-gradient-position: initial;
      --tw-gradient-from: #0000;
      --tw-gradient-via: #0000;
      --tw-gradient-to: #0000;
      --tw-gradient-stops: initial;
      --tw-gradient-via-stops: initial;
      --tw-gradient-from-position: 0%;
      --tw-gradient-via-position: 50%;
      --tw-gradient-to-position: 100%;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
      --tw-duration: initial;
      --tw-ease: initial;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
    }
  }
}

/* === Container === */
.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
}
@media (min-width: 640px) { .container { max-width: 640px } }
@media (min-width: 768px) { .container { max-width: 768px } }
@media (min-width: 1024px) { .container { max-width: 1024px } }
@media (min-width: 1280px) { .container { max-width: 1280px } }
@media (min-width: 1536px) { .container { max-width: 1536px } }

/* === Display === */
.flex { display: flex }
.hidden { display: none }
.flex-col { flex-direction: column }
.flex-row { flex-direction: row }

/* === Flex utilities === */
.items-center { align-items: center }
.justify-between { justify-content: space-between }

/* === Spacing === */
.m-4 { margin: 1rem }
.mx-auto { margin-left: auto; margin-right: auto }
.ml-auto { margin-left: auto }
.ml-2 { margin-left: 0.5rem }
.ml-4 { margin-left: 1rem }
.mb-4 { margin-bottom: 1rem }
.my-auto { margin-top: auto; margin-bottom: auto }
.p-8 { padding: 2rem }
.px-4 { padding-left: 1rem; padding-right: 1rem }
.py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem }
.py-4 { padding-top: 1rem; padding-bottom: 1rem }
.pb-2 { padding-bottom: 0.5rem }
.pb-8 { padding-bottom: 2rem }

/* === Sizing === */
.w-full { width: 100% }
.w-1\/3 { width: 33.333333% }
.h-16 { height: 4rem }
.h-20 { height: 5rem }
.h-\[275px\] { height: 275px }

/* === Positioning === */
.relative { position: relative }
.absolute { position: absolute }
.sticky { position: sticky }
.top-0 { top: 0 }

/* === Typography === */
.text-lg { font-size: 1.125rem; line-height: 1.75rem }
.font-semibold { font-weight: 600 }
.font-bold { font-weight: 700 }
.font-medium { font-weight: 500 }
.text-gray-800 { color: rgb(31 41 55 / 1) }

/* === Shadows === */
.shadow-md { 
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color),
    0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), 
              var(--tw-ring-shadow, 0 0 #0000), 
              var(--tw-shadow);
}
.shadow-lg {
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1),
    0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color),
    0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000),
              var(--tw-ring-shadow, 0 0 #0000),
              var(--tw-shadow);
}

/* === Borders === */
.border-b { border-bottom-width: 1px }
.border-gray-200 { border-color: rgb(229 231 235 / 1) }

/* === Colors === */
.bg-white { background-color: rgb(255 255 255 / 1) }
.bg-\[rgba\(0,0,0,\.06\)\] { background-color: rgba(0,0,0,.06) }
.bg-\[rgba\(0,0,0,\.03\)\] { background-color: rgba(0,0,0,.03) }

/* === Space utilities === */
.space-x-8 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-x-reverse: 0;
  margin-right: calc(2rem * var(--tw-space-x-reverse));
  margin-left: calc(2rem * calc(1 - var(--tw-space-x-reverse)));
}
.space-y-2 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
}
.space-y-6 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}

/* === Object fit === */
.object-cover { object-fit: cover }





/* Override Bootstrap container widths with Tailwind breakpoints */
.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem; /* px-4 equivalent */
  padding-left: 1rem;
}

@media (min-width: 640px) {
  .container {
    max-width: 640px; /* sm */
  }
}

@media (min-width: 768px) {
  .container {
    max-width: 768px; /* md */
  }
}

@media (min-width: 1024px) {
  .container {
    max-width: 960px; /* lg */
  }
}

@media (min-width: 1280px) {
  .container {
    max-width: 11400px; /* xl */
  }
}

@media (min-width: 1536px) {
  .container {
    max-width: 1380px;
  }
}
/* Tailwind utility replication */

/* Base .grid */
.grid {
  display: grid;
}

/* grid-cols-2 → 2 columns on all screens */
.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr))!important;
}

/* gap-3 → 0.75rem gap */
.gap-3 {
  gap: 0.75rem; /* 12px */
}

/* lg:grid-cols-4 → 4 columns from 1024px and up */
@media (min-width: 1024px) {
  .lg\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr))!important;
  }
}

/* lg:gap-8 → 2rem gap (32px) from 1024px and up */
@media (min-width: 1024px) {
  .lg\:gap-8 {
    gap: 2rem; /* 32px */
  }
}

