/**
 * CMS bridge for Template F (Clarity).
 * Panel colors in app.blade.php :root — primary, secondary, dark, light, text.
 * Maps them to Clarity tokens (--accent-color, --background-color, etc.).
 */

/* ── Global Clarity tokens from CMS palette ── */
body.cms-active-template-templateF {
  --accent-color: var(--primary);
  --background-color: var(--light);
  --default-color: var(--text);
  --heading-color: var(--dark);
  --surface-color: color-mix(in srgb, var(--light), var(--dark) 10%);
  --contrast-color: var(--secondary);

  --nav-color: color-mix(in srgb, var(--text), var(--dark) 25%);
  --nav-hover-color: var(--primary);
  --nav-mobile-background-color: var(--dark);
  --nav-dropdown-background-color: color-mix(in srgb, var(--dark), var(--primary) 18%);
  --nav-dropdown-color: color-mix(in srgb, var(--secondary), var(--text) 40%);
  --nav-dropdown-hover-color: var(--secondary);
}

/* Hero: dark band */
body.cms-active-template-templateF #app .main .hero.section {
  --background-color: var(--dark);
  --heading-color: var(--secondary);
  --default-color: color-mix(in srgb, var(--secondary) 75%, var(--text));
  --surface-color: color-mix(in srgb, var(--dark), var(--primary) 22%);
}

/* Section presets (alternating classes from Vue) */
body.cms-active-template-templateF .light-background {
  --background-color: var(--light);
  --default-color: var(--text);
  --heading-color: var(--dark);
  --surface-color: color-mix(in srgb, var(--light), var(--dark) 12%);
  --contrast-color: var(--secondary);
}

body.cms-active-template-templateF .dark-background {
  --background-color: var(--dark);
  --default-color: color-mix(in srgb, var(--secondary) 70%, var(--text));
  --heading-color: var(--secondary);
  --surface-color: color-mix(in srgb, var(--dark), var(--primary) 16%);
  --contrast-color: var(--secondary);
}

/* Heading tone only (blog matches services without changing surfaces) */
body.cms-active-template-templateF .vf-heading-tone-light {
  --heading-color: var(--dark);
}

body.cms-active-template-templateF .vf-heading-tone-dark {
  --heading-color: var(--secondary);
}

/* Header on scroll */
body.cms-active-template-templateF .header {
  --background-color: color-mix(in srgb, var(--light) 92%, transparent);
}

/* Footer */
body.cms-active-template-templateF .footer.dark-background {
  --background-color: var(--dark);
  --default-color: color-mix(in srgb, var(--secondary) 65%, var(--text));
  --heading-color: var(--secondary);
  --surface-color: color-mix(in srgb, var(--dark), var(--primary) 12%);
}

/* Primary / outline buttons */
body.cms-active-template-templateF .btn-primary {
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--secondary) !important;
}

body.cms-active-template-templateF .btn-primary:hover,
body.cms-active-template-templateF .btn-primary:focus {
  background-color: color-mix(in srgb, var(--primary), var(--dark) 18%) !important;
  border-color: color-mix(in srgb, var(--primary), var(--dark) 18%) !important;
  color: var(--secondary) !important;
}

body.cms-active-template-templateF .hero .hero-buttons .btn.btn-outline,
body.cms-active-template-templateF .btn.btn-outline {
  color: var(--primary) !important;
  border-color: var(--primary) !important;
  background: transparent !important;
}

body.cms-active-template-templateF .hero .hero-buttons .btn.btn-outline:hover,
body.cms-active-template-templateF .btn.btn-outline:hover {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--secondary) !important;
}

body.cms-active-template-templateF .hero.section .hero-buttons .btn.btn-outline {
  color: var(--secondary) !important;
  border-color: color-mix(in srgb, var(--secondary), var(--primary) 35%) !important;
}

body.cms-active-template-templateF .hero.section .hero-buttons .btn.btn-outline:hover {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--secondary) !important;
}

/* Links & accents */
body.cms-active-template-templateF #app .main a:not(.btn):not(.nav-link) {
  color: var(--primary);
}

body.cms-active-template-templateF #app .main a:not(.btn):not(.nav-link):hover {
  color: color-mix(in srgb, var(--primary), var(--dark) 20%);
}

body.cms-active-template-templateF #app .main .section-title h2,
body.cms-active-template-templateF #app .main h1,
body.cms-active-template-templateF #app .main h2,
body.cms-active-template-templateF #app .main h3,
body.cms-active-template-templateF #app .main h4,
body.cms-active-template-templateF #app .main h5 {
  color: var(--heading-color);
}

body.cms-active-template-templateF #app .main .about .content h2,
body.cms-active-template-templateF #app .main .about .content h2 * {
  color: var(--text) !important;
}

/* Blog headings — match Services (section title, cards, CTA) */
body.cms-active-template-templateF #app .main .portfolio .section-title h2,
body.cms-active-template-templateF #app .main .portfolio .section-title h2 *,
body.cms-active-template-templateF #app .main .portfolio .portfolio-wrapper .portfolio-content h3,
body.cms-active-template-templateF #app .main .portfolio .portfolio-cta h4 {
  color: var(--heading-color) !important;
}

body.cms-active-template-templateF #app .main .services .section-title h2,
body.cms-active-template-templateF #app .main .services .section-title h2 *,
body.cms-active-template-templateF #app .main .services .service-card h4,
body.cms-active-template-templateF #app .main .services .service-card h4 a,
body.cms-active-template-templateF #app .main .services .service-card h4 span {
  color: var(--heading-color) !important;
}

body.cms-active-template-templateF #app .main p,
body.cms-active-template-templateF #app .main .section-title p {
  color: var(--default-color);
}

body.cms-active-template-templateF #app .main .stat-number,
body.cms-active-template-templateF #app .main .purecounter {
  color: var(--primary);
}

/* Cards & surfaces */
body.cms-active-template-templateF #app .main .service-card,
body.cms-active-template-templateF #app .main .portfolio-wrapper,
body.cms-active-template-templateF #app .main .feature-card,
body.cms-active-template-templateF #app .main .leader-card,
body.cms-active-template-templateF #app .main .testimonial-card {
  background: var(--surface-color);
}

body.cms-active-template-templateF #app .main .services .service-icon {
  background-color: color-mix(in srgb, var(--primary), transparent 88%);
}

body.cms-active-template-templateF #app .main .services .service-icon i {
  color: var(--primary);
}

body.cms-active-template-templateF #app .main .services .service-badge {
  background: linear-gradient(
    135deg,
    var(--primary),
    color-mix(in srgb, var(--primary), var(--dark) 25%)
  );
  box-shadow: 0 4px 15px color-mix(in srgb, var(--primary), transparent 65%);
}

/* Swiper */
body.cms-active-template-templateF .swiper-pagination-bullet-active {
  background: var(--primary) !important;
}

/* AOS visibility (CMS) */
body.cms-active-template-templateF #app .main [data-aos] {
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto !important;
}

body.cms-active-template-templateF #app .main .text-center.py-5 {
  color: var(--default-color);
}

body.cms-active-template-templateF #app .main .vf-empty-page {
  color: var(--default-color);
  padding: 4rem 1rem;
  text-align: center;
}

/* Bootstrap Icons vs Font Awesome */
body.cms-active-template-templateF .bi::before,
body.cms-active-template-templateF [class^="bi-"]::before,
body.cms-active-template-templateF [class*=" bi-"]::before {
  font-family: bootstrap-icons !important;
  font-style: normal;
  font-weight: normal !important;
  display: inline-block;
  line-height: 1;
}

body.cms-active-template-templateF #app .main .fa::before,
body.cms-active-template-templateF #app .main .fas::before,
body.cms-active-template-templateF #app .main .far::before,
body.cms-active-template-templateF #app .main .fab::before {
  font-family: "Font Awesome 5 Free", "Font Awesome 5 Brands" !important;
}

body.cms-active-template-templateF #app .main .fab::before {
  font-family: "Font Awesome 5 Brands" !important;
}

/* Team hex grid: allow name/role meta to expand row height (prevents overlap) */
body.cms-active-template-templateF #app .main .team .team-grid {
  row-gap: 2rem;
}

body.cms-active-template-templateF #app .main .team .team-grid .member-hexagon {
  height: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

body.cms-active-template-templateF #app .main .team .team-grid .member-hexagon .hexagon-inner {
  width: 160px;
  height: 160px;
  flex-shrink: 0;
}

body.cms-active-template-templateF #app .main .team .team-grid .member-hexagon .vf-member-meta {
  width: 100%;
  margin-top: 1rem;
  position: relative;
  z-index: 1;
}

/* =================================================================
   Responsive — mobile / tablet / desktop (CMS dynamic sections)
   Breakpoints: tablet ≤991.98px, mobile ≤767.98px, small ≤575.98px
================================================================= */

body.cms-active-template-templateF #app .main {
  overflow-x: clip;
}

/* ── Tablet (≤991.98px) ── */
@media (max-width: 991.98px) {
  body.cms-active-template-templateF #app .main section,
  body.cms-active-template-templateF #app .main .section {
    padding: 48px 0;
  }

  body.cms-active-template-templateF #app .main .section-title {
    padding-bottom: 40px;
  }

  body.cms-active-template-templateF #app .main .section-title h2 {
    font-size: clamp(1.5rem, 4vw, 2rem);
  }

  /* Hero */
  body.cms-active-template-templateF #app .main .hero.section {
    padding: 88px 0 64px;
  }

  body.cms-active-template-templateF #app .main .hero .hero-content h1 {
    font-size: clamp(2rem, 5vw, 2.75rem);
  }

  body.cms-active-template-templateF #app .main .hero .hero-content p {
    font-size: 1.05rem;
  }

  body.cms-active-template-templateF #app .main .vf-hero-row {
    row-gap: 1.5rem;
  }

  /* About */
  body.cms-active-template-templateF #app .main .about .content h2 {
    font-size: clamp(1.5rem, 4vw, 2rem);
  }

  body.cms-active-template-templateF #app .main .about .image-composition {
    margin-top: 0.5rem;
  }

  /* Offer / Why us */
  body.cms-active-template-templateF #app .main .why-us .feature-content h3 {
    font-size: clamp(1.5rem, 4vw, 2rem);
  }

  /* Video */
  body.cms-active-template-templateF #app .main .vf-video-section {
    padding: 72px 0;
  }

  /* Team */
  body.cms-active-template-templateF #app .main .team .team-intro {
    margin-bottom: 1.5rem;
  }

  body.cms-active-template-templateF #app .main .team .join-team-cta {
    text-align: center;
  }

  /* Contact */
  body.cms-active-template-templateF #app .main .contact .row.align-items-center > [class*="col-lg-7"] {
    margin-top: 2rem;
  }
}

/* ── Mobile (≤767.98px) ── */
@media (max-width: 767.98px) {
  body.cms-active-template-templateF #app .main section,
  body.cms-active-template-templateF #app .main .section {
    padding: 40px 0;
  }

  body.cms-active-template-templateF #app .main .section-title {
    padding-bottom: 32px;
  }

  body.cms-active-template-templateF #app .main .section-title h2 {
    font-size: clamp(1.35rem, 5vw, 1.75rem);
  }

  body.cms-active-template-templateF #app .main .section-title p {
    font-size: 0.95rem;
  }

  /* Hero */
  body.cms-active-template-templateF #app .main .hero.section {
    padding: 72px 0 48px;
  }

  body.cms-active-template-templateF #app .main .hero .hero-content h1 {
    font-size: clamp(1.75rem, 7vw, 2.25rem);
    margin-bottom: 1rem;
  }

  body.cms-active-template-templateF #app .main .hero .hero-content p {
    font-size: 1rem;
    margin-bottom: 1.25rem;
  }

  body.cms-active-template-templateF #app .main .hero .hero-buttons {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
  }

  body.cms-active-template-templateF #app .main .hero .hero-buttons .btn {
    width: 100%;
    text-align: center;
    padding: 12px 24px;
  }

  body.cms-active-template-templateF #app .main .vf-hero-carousel-nav {
    justify-content: center;
  }

  body.cms-active-template-templateF #app .main .vf-hero-facts-wrap {
    margin-top: 1.5rem !important;
  }

  /* About */
  body.cms-active-template-templateF #app .main .about .content {
    text-align: center;
  }

  body.cms-active-template-templateF #app .main .about .content .features-list li {
    justify-content: center;
    text-align: left;
  }

  body.cms-active-template-templateF #app .main .about .image-composition {
    padding: 0.5rem 0 0;
    margin-top: 1rem;
  }

  body.cms-active-template-templateF #app .main .about .image-composition .image-secondary {
    position: relative;
    width: 72%;
    margin: -1.5rem auto 0 0;
    left: auto;
    bottom: auto;
  }

  body.cms-active-template-templateF #app .main .about .image-composition .stats-card {
    position: relative;
    top: auto;
    right: auto;
    width: 100%;
    margin-top: 1.25rem;
    justify-content: center;
  }

  /* Services & Menu carousels */
  body.cms-active-template-templateF #app .main .services .services-cta {
    padding: 32px 20px;
  }

  body.cms-active-template-templateF #app .main #menu .nav-pills {
    flex-direction: column;
    align-items: stretch !important;
    gap: 0.5rem !important;
  }

  body.cms-active-template-templateF #app .main #menu .nav-pills .nav-item {
    width: 100%;
  }

  body.cms-active-template-templateF #app .main #menu .nav-pills .nav-link {
    width: 100%;
    text-align: center;
  }

  /* Portfolio / Blog */
  body.cms-active-template-templateF #app .main .portfolio .portfolio-cta {
    margin-top: 40px;
    padding: 28px 20px;
  }

  body.cms-active-template-templateF #app .main .portfolio .portfolio-cta .cta-buttons {
    flex-direction: column;
    align-items: stretch;
  }

  body.cms-active-template-templateF #app .main .portfolio .portfolio-cta .cta-buttons .btn {
    width: 100%;
  }

  /* Offer / Why us */
  body.cms-active-template-templateF #app .main .why-us .feature-showcase {
    margin-bottom: 1.5rem;
  }

  body.cms-active-template-templateF #app .main .why-us .feature-content .cta-wrapper {
    flex-direction: column;
  }

  body.cms-active-template-templateF #app .main .why-us .feature-content .cta-wrapper .btn {
    width: 100%;
    text-align: center;
  }

  /* Video */
  body.cms-active-template-templateF #app .main .vf-video-section {
    padding: 56px 0;
    background-position: center;
  }

  body.cms-active-template-templateF #app .main .vf-video-section h2 {
    font-size: clamp(1.35rem, 5vw, 1.75rem);
    margin-bottom: 1.25rem !important;
  }

  /* Facts */
  body.cms-active-template-templateF #app .main .vf-fact-slide-card .stat-number {
    font-size: clamp(1.5rem, 5vw, 2rem);
  }

  /* Team */
  body.cms-active-template-templateF #app .main .team .team-grid {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    max-width: 100%;
    padding-bottom: 0.5rem;
  }

  body.cms-active-template-templateF #app .main .team .team-grid .member-hexagon {
    width: 100%;
    max-width: 280px;
    margin-left: auto;
    margin-right: auto;
  }

  body.cms-active-template-templateF #app .main .team .team-grid .member-hexagon:nth-child(even) {
    margin-top: 0;
  }

  body.cms-active-template-templateF #app .main .team .team-grid .member-hexagon .hexagon-inner {
    width: clamp(160px, 42vw, 200px);
    height: clamp(160px, 42vw, 200px);
  }

  body.cms-active-template-templateF #app .main .team .vf-member-meta {
    margin-top: 1rem;
    padding-bottom: 0.25rem;
  }

  body.cms-active-template-templateF #app .main .team .team-carousel-wrapper {
    margin-top: 2.5rem;
    padding-top: 0.5rem;
  }

  body.cms-active-template-templateF #app .main .team .team-carousel-wrapper .carousel-title {
    margin-top: 0;
    margin-bottom: 1.25rem;
  }

  body.cms-active-template-templateF #app .main .team .team-carousel-wrapper .leadership-slider .swiper-slide {
    padding: 8px;
  }

  body.cms-active-template-templateF #app .main .team .join-team-cta .cta-content .cta-actions .btn {
    width: 100%;
    max-width: 280px;
  }

  /* Testimonials */
  body.cms-active-template-templateF #app .main .testimonials .testimonial-card {
    min-height: 0;
  }

  /* Newsletter */
  body.cms-active-template-templateF #app .main #newsletter form.row {
    flex-direction: column;
    align-items: stretch !important;
  }

  body.cms-active-template-templateF #app .main #newsletter form .col-md-6,
  body.cms-active-template-templateF #app .main #newsletter form .col-auto {
    width: 100%;
    max-width: 100%;
  }

  body.cms-active-template-templateF #app .main #newsletter form .btn {
    width: 100%;
  }

  /* Contact */
  body.cms-active-template-templateF #app .main .contact .contact-form-card {
    padding: 28px 20px;
  }

  body.cms-active-template-templateF #app .main .contact .contact-info-area .method-card {
    flex-direction: row;
    align-items: flex-start;
  }

  body.cms-active-template-templateF #app .main .contact .contact-info-area .method-card .card-content p,
  body.cms-active-template-templateF #app .main .contact .contact-info-area .method-card .card-content a {
    word-break: break-word;
  }

  body.cms-active-template-templateF #app .main .contact iframe,
  body.cms-active-template-templateF #app .main .contact .mt-4 iframe {
    width: 100% !important;
    max-width: 100%;
    min-height: 220px;
  }

  /* Swiper pagination tap targets */
  body.cms-active-template-templateF #app .main .vf-section-carousel .swiper-pagination-bullet,
  body.cms-active-template-templateF #app .main .vf-swiper .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
  }
}

/* ── Small mobile (≤575.98px) ── */
@media (max-width: 575.98px) {
  body.cms-active-template-templateF #app .main section,
  body.cms-active-template-templateF #app .main .section {
    padding: 32px 0;
  }

  body.cms-active-template-templateF #app .main .hero.section {
    padding: 64px 0 40px;
  }

  body.cms-active-template-templateF #app .main .hero .hero-bg-elements .bg-shape.shape-1 {
    width: 180px;
    height: 180px;
    top: -90px;
    right: -90px;
  }

  body.cms-active-template-templateF #app .main .hero .hero-bg-elements .bg-shape.shape-2 {
    width: 120px;
    height: 120px;
    bottom: -60px;
    left: -60px;
  }

  body.cms-active-template-templateF #app .main .about .content .btn-primary {
    display: block;
    width: 100%;
    text-align: center;
  }

  body.cms-active-template-templateF #app .main .services .service-card,
  body.cms-active-template-templateF #app .main .why-us .feature-card {
    padding: 24px 18px;
  }

  body.cms-active-template-templateF #app .main .vf-hero-nav-btn {
    width: 44px;
    height: 44px;
  }

  body.cms-active-template-templateF #app .main .vf-video-modal-backdrop {
    padding: 12px;
  }

  body.cms-active-template-templateF #app .main .contact .contact-form-card .php-email-form .row > [class*="col-md-6"] {
    width: 100%;
  }
}

/* ── Desktop refinements (≥992px) ── */
@media (min-width: 992px) {
  body.cms-active-template-templateF #app .main .vf-hero-row {
    min-height: 0;
  }

  body.cms-active-template-templateF #app .main .vf-hero-content-col,
  body.cms-active-template-templateF #app .main .vf-hero-visual-col {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}
