@import "../../../../themes/recast2025/style.css";

/* Free Tools Widget Styles */

.free-tools {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  font-family: var(--font-family-body);
}

.free-tools__container {
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}

/* Layout Grid */
.free-tools__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: start;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.free-tools__column--primary {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.free-tools__column--secondary {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
}

/* Responsive Behavior */
/* Desktop HD */
@media (min-width: 1601px) {  
  .free-tools__column--primary {
    gap: 0;
  }
}

/* Desktop */
@media (min-width: 1201px) and (max-width: 1600px) {
  /* .free-tools__container {
    padding: 0 var(--margins-base-hori);
  } */
  
  .free-tools__column--primary {
    gap: 0;
  }
}

/* Tablet */
@media (min-width: 601px) and (max-width: 1200px) {
  .free-tools {
    /* padding: var(--margins-base-vert) 0; */
  }
  
  /* .free-tools__container {
    padding: 0 var(--margins-base-hori);
  } */
  
  .free-tools__layout {
    gap: var(--gap-base);
  }
  
  .free-tools__column--primary {
    gap: 0;
  }
}

/* Mobile - Stack columns */
@media (max-width: 992px) {
  .free-tools {
    /* padding: var(--margins-base-vert) 0; */
  }
  
  /* .free-tools__container {
    padding: 0 var(--margins-base-hori);
  } */
  
  .free-tools__layout {
    grid-template-columns: 1fr;
    gap: var(--gap-base);
  }
  
  .free-tools__column--primary {
    gap: 0;
  }
  
  /* Ensure embed section stacks below FAQ on mobile */
  .free-tools__column--primary {
    order: 1;
  }
  
  .free-tools__column--secondary {
    order: 2;
  }
}

/* Component Styling Overrides */
/* Ensure components work well within the layout */
.free-tools .freetools-carousel,
.free-tools .freetools-faq,
.free-tools .freetools-embed {
  width: 100%;
  max-width: 100%;
  isolation: isolate;
  box-sizing: border-box;
}

/* Base spacing for sections */
.free-tools .freetools-carousel {
  padding: var(--margins-base-vert) var(--margins-base-hori) !important;
}

.free-tools .freetools-faq {
  padding: var(--margins-base-vert) var(--margins-base-hori) !important;
}

.free-tools .freetools-embed {
  padding: var(--margins-base-vert) var(--margins-base-hori) !important;
}

/* Remove any default margins from components to prevent layout issues */
.free-tools .freetools-carousel__container,
.free-tools .freetools-faq__container,
.free-tools .freetools-embed__wrapper {
  margin: 0;
  position: relative;
}

/* Typography Classes - Using theme variables */
.free-tools .heading-l {
  font-size: var(--size-heading-l);
  font-family: var(--font-family-headings);
  font-weight: 600;
  line-height: 1.2;
  color: var(--neutrals-black);
}

.free-tools .body-s {
  font-size: var(--size-body-s);
  font-family: var(--font-family-body);
  font-weight: 400;
  line-height: 1.5;
  color: var(--neutrals-black);
}

.free-tools .body-xs {
  font-size: var(--size-body-xs);
  font-family: var(--font-family-body);
  font-weight: 400;
  line-height: 1.6;
  color: var(--neutrals-black);
}

/* Blue highlight spans */
.free-tools span {
  color: var(--primary-recast-blue);
}

/* Ensure proper spacing and alignment */
.free-tools .freetools-carousel__header,
.free-tools .faq-section__header,
.free-tools .freetools-embed__header {
  text-align: left;
}

/* Responsive Typography */
/* Desktop HD */
@media (min-width: 1601px) {
  .free-tools .heading-l {
    font-size: var(--size-heading-l);
  }
  
  .free-tools .body-s {
    font-size: var(--size-body-s);
  }
  
  .free-tools .body-xs {
    font-size: var(--size-body-xs);
  }
}

/* Desktop */
@media (min-width: 1201px) and (max-width: 1600px) {
  .free-tools .heading-l {
    font-size: var(--size-heading-l);
  }
  
  .free-tools .body-s {
    font-size: var(--size-body-s);
  }
  
  .free-tools .body-xs {
    font-size: var(--size-body-xs);
  }
}

/* Tablet */
@media (min-width: 601px) and (max-width: 1200px) {
  .free-tools .heading-l {
    font-size: var(--size-heading-l);
  }
  
  .free-tools .body-s {
    font-size: var(--size-body-s);
  }
  
  .free-tools .body-xs {
    font-size: var(--size-body-xs);
  }
}

/* Mobile */
@media (max-width: 600px) {
  .free-tools .heading-l {
    font-size: var(--size-heading-m);
  }
  
  .free-tools .body-s {
    font-size: var(--size-body-xs);
  }
  
  .free-tools .body-xs {
    font-size: var(--size-body-sub);
  }
}

/* Prevent scroll anchoring issues */
.free-tools {
  overflow-anchor: none;
}

/* Essential Component Styles */
/* These styles are needed because the individual widget CSS files aren't loading */

/* Carousel Component Styles */
.free-tools .freetools-carousel {
  display: flex;
  width: 100%;
  min-height: 400px;
  flex-direction: column;
  align-items: center;
  background: var(--primary-royal-blue);
  position: relative;
  contain: layout style;
}

.free-tools .freetools-carousel__container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: var(--gap-base);
  align-self: stretch;
  position: relative;
}

.free-tools .freetools-carousel__header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--gap-s);
  align-self: stretch;
}

.free-tools .freetools-carousel__eyebrow {
  color: var(--neutrals-white);
  font-family: var(--font-family-body);
  font-size: var(--size-body-sub);
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  letter-spacing: 0.84px;
  text-transform: uppercase;
}

.free-tools .freetools-carousel__title {
  color: var(--neutrals-white);
  font-family: var(--font-family-headings);
  font-size: var(--size-heading-xl);
  font-style: normal;
  font-weight: 400;
  line-height: 116.667%;
  margin: 0;
}

.free-tools .freetools-carousel__bar {
  width: 64px;
  height: 4px;
  background: var(--secondary-orange);
}

.free-tools .freetools-carousel__description {
  color: var(--neutrals-white);
  font-family: var(--font-family-body);
  font-size: var(--size-body-m);
  font-style: normal;
  font-weight: 400;
  line-height: 133.333%;
}

.free-tools .freetools-carousel__wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gap-m);
  align-self: stretch;
}

.free-tools .freetools-carousel__slider-container {
  display: flex;
  align-items: center;
  align-self: stretch;
  position: relative;
}

.free-tools .freetools-carousel__swiper {
  display: flex;
  width: 100%;
  aspect-ratio: 4 / 3;
  height: auto;
  align-self: stretch;
  position: relative;
  overflow: hidden;
}

.free-tools .swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}

.free-tools .swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: flex;
  justify-content: center;
}

.free-tools .freetools-carousel__slide {
  display: flex;
  height: 100%;
  justify-content: center;
  align-items: center;
  align-self: stretch;
  background: var(--neutrals-grey-1);
  position: relative;
  width: 100%;
}

.free-tools .freetools-carousel__slide-image {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.free-tools .freetools-carousel__slide-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Carousel Navigation */
.free-tools .freetools-carousel__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
}

.free-tools .freetools-carousel__nav--prev {
  left: 16px;
}

.free-tools .freetools-carousel__nav--next {
  right: 16px;
}

.free-tools .freetools-carousel__arrow {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  border-radius: 0;
  border: 2px solid transparent;
  background: var(--primary-royal-blue);
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.free-tools .freetools-carousel__arrow:focus {
  background: var(--primary-royal-blue);
}

.free-tools .freetools-carousel__arrow:hover {
  background: rgba(3, 114, 255, 0.4);
}

.free-tools .freetools-carousel__arrow svg {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.free-tools .freetools-carousel__pagination {
  display: flex;
  align-items: center;
  gap: var(--gap-s);
  position: relative;
  align-self: flex-start;
  bottom: 0px !important;
}

.free-tools .freetools-carousel__pagination .swiper-pagination-bullet {
  width: 4px;
  height: 4px;
  aspect-ratio: 1/1;
  background: transparent;
  border: 2px solid var(--neutrals-white);
  border-radius: 0;
  margin: 0;
  opacity: 1;
  transition: background-color 0.3s ease;
}

.free-tools .freetools-carousel__pagination .swiper-pagination-bullet-active {
  width: 12px;
  height: 12px;
  background: var(--secondary-orange);
  border: none;
}

.free-tools .freetools-carousel__pagination .swiper-pagination-bullet-active::after {
  display: none;
}






/* FAQ Component Styles */
.free-tools .freetools-faq {
  background-color: var(--neutrals-grey-1);
}

.free-tools .freetools-faq__container {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.free-tools .freetools-faq__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gap-m);
  text-align: center;
  max-width: 600px;
  margin-bottom: var(--gap-base);
}

.free-tools .freetools-faq__title {
  margin: 0;
  color: var(--neutrals-black, #161f5b);
  letter-spacing: calc(var(--size-heading-l, 48px) * 0.02);
}

.free-tools .freetools-faq__title span {
  color: var(--primary-recast-blue, #0372ff);
}

.free-tools .freetools-faq__subtitle {
  margin: 0;
  color: var(--neutrals-black, #161f5b);
  font-weight: 300;
}

.free-tools .freetools-faq__list {
  width: 100%;
  max-width: var(--global-maxwidth-maxwidth-m, 1200px);
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
}

.free-tools .freetools-faq__item {
  border: var(--stroke-width, 2px) solid var(--neutrals-grey-1, #e1e9f9);
  background: var(--neutrals-white, #ffffff);
  transition: border-color 0.3s ease;
}

.free-tools .freetools-faq__item:not(:last-child) {
  border-bottom: 0px;
}

.free-tools .freetools-faq__item:first-child {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.free-tools .freetools-faq__item:last-child {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.free-tools .freetools-faq__item:hover {
  border-color: var(--neutrals-grey-2, #b2b5e5);
  background: var(--neutrals-grey-1);
  margin: 0px 0 -2px 0;
  border-bottom: var(--neutrals-grey-2) 2px solid;
  z-index: 3;
}

.free-tools .freetools-faq__item:last-child:hover {
  margin: 0;
}

.free-tools .freetools-faq__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-s, 16px);
  padding: var(--gap-s, 16px);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: all 0.3s ease;
  background: transparent !important;
}

.free-tools .freetools-faq__question-text {
  color: var(--neutrals-black, #161f5b);
  font-weight: 500;
  letter-spacing: 0.6px;
  flex: 1;
  text-wrap: wrap;
}

/* FAQ Icon */
.free-tools .freetools-faq__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--primary-recast-blue, #0372ff);
  transition: transform 0.3s ease;
  flex-shrink: 0;
}

.free-tools .freetools-faq__item.is-active .freetools-faq__icon {
  transform: rotate(180deg);
}

.free-tools .freetools-faq__icon svg {
  width: 24px;
  height: 24px;
}

.free-tools .freetools-faq__answer {
  height: 0;
  overflow: hidden;
  opacity: 0;
  box-sizing: border-box;
}

.free-tools .freetools-faq__answer-content {
  padding: 0 28px 8px 12px;
}

.free-tools .freetools-faq__answer-content p {
  margin: 0;
  color: var(--neutrals-black, #161f5b);
  line-height: 1.4;
}

.free-tools .freetools-faq__item.is-active .freetools-faq__answer {
  overflow: visible;
}

/* Bottom CTA */
.free-tools .freetools-faq__cta {
  display: flex;
  justify-content: center;
  margin-top: calc(var(--gap-m, 24px) + 10px);
}

.free-tools .freetools-faq__cta a {
  color: var(--button-ghost-text, #1F289C);
  text-align: center;
  font-feature-settings: 'liga' off, 'clig' off;
  font-family: var(--font-family-headings, "Host Grotesk");
  font-size: var(--button-font-size, 20px);
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
}

/* Embed Component Styles */
.free-tools .freetools-embed__wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gap-base);
}

.free-tools .freetools-embed__header {
  text-align: center;
}

.free-tools .freetools-embed__title {
  color: var(--neutrals-black);
  text-align: center;
  font-family: var(--font-family-headings);
  font-size: var(--size-heading-l);
  font-style: normal;
  font-weight: 600;
  line-height: 116.667%;
  margin: 0;
}

.free-tools .freetools-embed__embed-container {
  width: 100%;
  min-height: 500px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.free-tools .freetools-embed__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gap-s);
  color: var(--neutrals-grey-3);
}

.free-tools .freetools-embed__embed-content {
  width: 100%;
}

.free-tools .freetools-embed__embed-content iframe {
  width: 100%;
  min-height: 500px;
  border: none;
}
