/*
  TruTidy Landing Styles
  - Mobile-first, accessible, WCAG AA contrast
  - Componentized (BEM-like) classes
  - No external dependencies
*/

:root {
  --green-900: #0b3d2e;
  --green-700: #136a4a;
  --green-500: #198754;
  --mint: #f2fbf6;
  --ink: #0f172a;

  --bg: #ffffff;
  --text: var(--ink);
  --muted: #475569;
  --border: #e2e8f0;

  --container: 1120px;
  --radius: 16px; /* rounded-2xl vibe */
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 8px 24px rgba(15, 23, 42, 0.12);
  --shadow-lg: 0 20px 40px rgba(15, 23, 42, 0.18);

  --space-1: .25rem;
  --space-2: .5rem;
  --space-3: .75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  /* Runtime-updated header height for layout math */
  --header-h: 100px;
}

/* Base / Reset */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color: var(--text);
  background: var(--bg);
  line-height: 1.5;
}
img { max-width: 100%; display: block; }
svg { display: block; }
a { color: var(--green-700); text-decoration: none; }
a:hover { text-decoration: underline; }

.container {
  width: min(100% - 2rem, var(--container));
  margin-inline: auto;
}

.skip-link {
  position: absolute;
  left: -999px; top: -999px;
}
.skip-link:focus {
  left: 1rem; top: 1rem; z-index: 1000;
  background: var(--mint);
  padding: .5rem .75rem;
  border-radius: .5rem;
  box-shadow: var(--shadow-sm);
}

/* Header */
.header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.9);
  backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--border);
}
.header__inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.6rem 0 0 0;
  gap: .50rem;
}
.logo { display: flex; align-items: center; gap: .5rem; color: var(--text); font-weight: 700; }
.logo__icon,
.logo__image {
  border-radius: .5rem;
  box-shadow: var(--shadow-sm);
  max-height: 150px;
  width: auto;
  height: auto;
}
.logo__text { font-size: 1rem; }

.nav { display: none; gap: 1rem; }
.nav__link { color: var(--muted); font-weight: 500; }
.nav__link:hover { color: var(--green-700); }

.header__cta { display: flex; gap: .5rem; align-items: center; }
.header__call { display: none; }
.header__call .icon-phone { margin-right: .4rem; }
.header__call .text--desktop { display: none; }
.header__call .text--mobile { display: inline; }
@media (min-width: 700px) {
  .header__call { display: inline-flex; }
  .header__call .text--desktop { display: inline; }
  .header__call .text--mobile { display: none; }
}

@media (min-width: 900px) {
  .nav { display: flex; }
  .logo__text { font-size: 1.1rem; }
}

/* Footer logo */
.footer__logo-image {
  max-width: 420px;
  height: auto;
}

/* Buttons */
.btn {
  --bgc: var(--green-700);
  --c: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  gap: .5rem;
  padding: .6rem 1rem;
  font-weight: 600; border-radius: .75rem;
  background: var(--bgc); color: var(--c);
  border: 1px solid transparent; box-shadow: var(--shadow-sm);
  cursor: pointer;
}
.btn:hover { filter: brightness(1.03); }
.btn:focus-visible { outline: 2px solid var(--green-500); outline-offset: 2px; }
.btn--primary { --bgc: var(--green-700); --c: #fff; }
.btn--dark { --bgc: var(--green-900); --c: #fff; }
.btn--light { --bgc: var(--mint); --c: var(--green-900); border-color: var(--green-700); }
.btn--outline { --bgc: #fff; --c: var(--green-700); border-color: var(--green-700); }
.btn--ghost { --bgc: #fff; --c: var(--green-700); border-color: var(--border); }
.btn--sm { padding: .45rem .75rem; font-size: .9rem; }

.nowrap { white-space: nowrap; }

/* Hero */
.hero { position: relative; overflow: clip; min-height: calc(100vh - var(--header-h)); min-height: calc(100svh - var(--header-h)); }
.hero__bg { position: absolute; inset: 0; overflow: hidden; }
.hero__img { width: 100%; height: 100%; object-fit: cover; }
.hero__video { width: 100%; height: 100%; object-fit: cover; transform: scale(1.02); }
.hero__overlay { position: absolute; inset: 0; background:
  radial-gradient(80% 60% at 20% 40%, rgba(0,0,0,.45) 0%, rgba(0,0,0,.18) 45%, rgba(0,0,0,0) 70%),
  linear-gradient(180deg, rgba(11,61,46,0.40), rgba(11,61,46,0.10)); }
.hero__inner { position: relative; display: grid; gap: 1.25rem; padding: clamp(1rem, 3vh, 1.75rem) 0 clamp(1.75rem, 6vh, 2.5rem); }
.hero__content { color: #fff; text-shadow: 0 1px 2px rgba(0,0,0,.25); max-width: 40rem; }
.hero__title { font-size: clamp(1.8rem, 3.4vw + 1rem, 3rem); line-height: 1.12; margin: 0 0 .35rem; font-weight: 800; }
.hero__subtitle { margin: 0 0 .9rem; color: #e6ffef; max-width: 60ch; }
.hero__actions { display: flex; gap: .5rem; flex-wrap: wrap; }
.hero__panel { background: rgba(8,32,24,.58); border: 1px solid rgba(255,255,255,.22); border-radius: var(--radius); padding: clamp(.9rem, 1.4vw, 1.25rem); box-shadow: 0 12px 30px rgba(0,0,0,.35); backdrop-filter: saturate(160%) blur(6px); }

/* Lift the quote card over the video while keeping it clean */
.hero .form-card { background: rgba(255,255,255,.92); border: 1px solid rgba(255,255,255,.7); box-shadow: 0 15px 40px rgba(0,0,0,.22); backdrop-filter: saturate(140%) blur(6px); }

.form-card { background: #fff; border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: 1rem; }
.form-card__title { margin: 0 0 .5rem; }

@media (min-width: 900px) {
  .hero__inner { grid-template-columns: 1.2fr 1fr; align-items: center; min-height: inherit; }
  .form-card { margin-left: auto; }
  .hero__panel { padding: 1.1rem 1.25rem; }
}

/* Chips */
.chips { list-style: none; padding: 0; margin: .5rem 0 .75rem; display: flex; gap: .5rem; flex-wrap: wrap; }
.chip { background: rgba(242,251,246,.9); color: var(--green-900); border: 1px solid #c7ebd7; padding: .35rem .6rem; border-radius: 999px; font-weight: 600; font-size: .85rem; }

/* Sections */
.section { padding: var(--space-10) 0; }
.section--tight { padding: var(--space-8) 0; }
.section--alt { background: var(--mint); }
.section__title { margin: 0 0 .25rem; font-size: clamp(1.25rem, 2vw + .9rem, 1.8rem); }
.section__subtitle { margin: 0 0 1rem; color: var(--muted); }

/* Cards & grids */
.card { border: 1px solid var(--border); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow-md); overflow: hidden; }
.grid { display: grid; gap: 1rem; }
.grid--cards { grid-template-columns: 1fr; }

@media (min-width: 700px) {
  .grid--cards { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1000px) {
  .grid--cards { grid-template-columns: repeat(3, 1fr); }
}

/* Services */
.service__img { width: 100%; height: auto; display: block; }
.service__body { padding: .9rem; display: grid; gap: .5rem; }
.service__title { margin: 0; }
.service__bullets { margin: 0; padding-left: 1rem; }

/* Features */
.grid--features { grid-template-columns: 1fr; }
.feature { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem; box-shadow: var(--shadow-sm); }
.feature__title { margin: 0 0 .25rem; }

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

/* Areas */
.areas { display: flex; align-items: flex-start; gap: .75rem; }
.areas__icon { color: var(--green-700); margin-top: .2rem; }
.areas__list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: .5rem; }
.areas__list li { background: #fff; border: 1px solid var(--border); border-radius: 999px; padding: .35rem .6rem; }
.areas__note { color: var(--muted); margin-top: .75rem; }

/* Carousel */
.carousel { position: relative; }
.carousel__track { display: grid; grid-auto-flow: column; grid-auto-columns: 100%; overflow: hidden; scroll-behavior: smooth; }
.testimonial { position: relative; padding: 1.25rem 1.25rem 1.25rem 3rem; background: #fff; border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-sm); margin: 0; }
.testimonial::before { content: "\201C"; position: absolute; left: .8rem; top: .4rem; font-size: 2.4rem; line-height: 1; color: var(--green-700); opacity: .15; font-weight: 900; }
.testimonial blockquote { margin: .4rem 0 .6rem; font-size: clamp(1rem, 1.2vw + .9rem, 1.25rem); color: var(--ink); }
.testimonial figcaption { color: var(--muted); }
.testimonial .stars { color: #f59e0b; font-weight: 700; letter-spacing: .06em; }

/* Logos row */
.logos { display: grid; gap: 1rem; grid-template-columns: 1fr; align-items: center; text-align: center; }
.logos__item { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); padding: .75rem; box-shadow: var(--shadow-sm); }
.logos__item img { margin-inline: auto; filter: grayscale(100%); }

/* Gallery */
.grid--gallery { grid-template-columns: repeat(2, 1fr); }
.gallery__item { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); }
.gallery__item figcaption { padding: .5rem .75rem; color: var(--muted); }
@media (min-width: 900px) {
  .grid--gallery { grid-template-columns: repeat(3, 1fr); }
  .logos { grid-template-columns: repeat(3, minmax(0,1fr)); }
}

/* Forms */
.form { display: grid; gap: .75rem; }
.form__row { display: grid; gap: .35rem; }
.form__row--grid2 { grid-template-columns: 1fr; gap: .5rem; }
@media (min-width: 600px) {
  .form__row--grid2 { grid-template-columns: repeat(2, 1fr); }
}
label { font-weight: 600; }
input, select, textarea {
  width: 100%; border: 1px solid var(--border); border-radius: .6rem; padding: .55rem .7rem; font: inherit; background: #fff;
}
input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 2px solid var(--green-500); outline-offset: 1px; }
.form__error { color: #b91c1c; min-height: 1em; font-size: .9rem; }
.form__privacy { color: var(--muted); font-size: .9rem; margin: 0; }
.form__actions { display: flex; gap: .5rem; justify-content: flex-end; }

/* CTA band */
.cta { background: var(--green-700); color: #fff; padding: var(--space-10) 0; }
.cta__inner { display: grid; gap: .75rem; align-items: center; }
.cta__title { margin: 0; font-size: clamp(1.2rem, 2vw + 1rem, 1.8rem); }
.btn--dark:hover, .btn--light:hover { filter: brightness(1.05); }

/* Footer */
.footer { background: var(--green-900); color: #e6ffef; }
.footer a { color: #e6ffef; }
.footer__grid { display: grid; gap: 1rem; grid-template-columns: 1fr; padding: var(--space-10) 0; }
.footer__title { margin: 0 0 .5rem; }
.footer__nap { list-style: none; padding: 0; margin: .5rem 0 0; display: grid; gap: .25rem; }
.footer__links ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .25rem; }
.footer__legal { border-top: 1px solid rgba(255,255,255,.15); padding: .75rem 0; font-size: .9rem; color: #d1fae5; }
.legal { padding: var(--space-8) 0; background: #0f2a20; color: #e6ffef; scroll-margin-top: calc(var(--header-h) + 16px); }
.legal--alt { background: #0d241b; }
/* Legal headings spacing */
.legal__title { margin: 0 0 .75rem; }

/* Modal */
.modal { position: fixed; inset: 0; display: none; }
.modal[aria-hidden="false"] { display: block; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(15, 23, 42, .55); }
.modal__dialog { position: relative; z-index: 1; background: #fff; width: min(92vw, 720px); margin: 10vh auto; padding: 1rem; border-radius: var(--radius); box-shadow: var(--shadow-lg); }
.modal__close { position: absolute; right: .5rem; top: .5rem; border: none; background: transparent; font-size: 1.6rem; line-height: 1; cursor: pointer; color: var(--muted); }
.progress { height: 6px; background: #e5e7eb; border-radius: 999px; overflow: hidden; margin-bottom: .75rem; }
.progress__bar { height: 100%; background: var(--green-700); width: 50%; }
.form--modal .form__actions { justify-content: space-between; }

/* Toasts */
.toasts { position: fixed; bottom: 1rem; left: 50%; transform: translateX(-50%); display: grid; gap: .5rem; z-index: 100; }
.toast { background: #111827; color: #fff; padding: .6rem .8rem; border-radius: .6rem; box-shadow: var(--shadow-md); }
.toast--error { background: #991b1b; }
.toast--success { background: #065f46; }

/* Consent */
.consent { position: fixed; inset: auto 0 0 0; background: rgba(0,0,0,.4); padding: .75rem; z-index: 60; }
.consent__inner { background: #fff; border-radius: .75rem; box-shadow: var(--shadow-lg); width: min(100%, 680px); margin: 0 auto; padding: .75rem; display: grid; gap: .5rem; align-items: center; grid-template-columns: 1fr; }
.consent__actions { display: flex; gap: .5rem; justify-content: end; }
@media (min-width: 700px) {
  .consent__inner { grid-template-columns: 1fr auto; }
}

/* Accordion (Modern) */
.accordion { display: grid; gap: .75rem; }
.accordion__item { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-sm); overflow: hidden; }
.accordion__btn { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: .75rem; padding: 1rem; background: #fff; color: var(--ink); border: 0; cursor: pointer; font: inherit; font-weight: 600; text-align: left; }
.accordion__btn:hover { background: #fafafa; }
.accordion__btn:focus-visible { outline: 2px solid var(--green-500); outline-offset: 2px; }
.accordion__btn[aria-expanded="true"] { background: var(--mint); }
.accordion__label { flex: 1; }
.accordion__chev { transition: transform .2s ease; color: var(--green-700); }
.accordion__btn[aria-expanded="true"] .accordion__chev { transform: rotate(180deg); }
.accordion__panel { padding: 0 1rem 1rem; color: var(--muted); }

/* Scroll animations */
[data-animate] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s ease, transform .6s ease;
  transition-delay: var(--animate-delay, 0s);
  will-change: opacity, transform;
}
[data-animate].is-visible {
  opacity: 1;
  transform: none;
}
[data-animate="fade"] { transform: none; }
[data-animate="fade-up"] { transform: translateY(24px); }
[data-animate="fade-down"] { transform: translateY(-24px); }
[data-animate="fade-left"] { transform: translateX(24px); }
[data-animate="fade-right"] { transform: translateX(-24px); }
@media (prefers-reduced-motion: reduce) {
  [data-animate] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* On very small screens, always show animated elements (avoids any IntersectionObserver quirks on mobile) */
@media (max-width: 640px) {
  [data-animate] {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* Utilities */
.card + .card { margin-top: .75rem; }
