/* Local home page utilities. Replaces the Tailwind CDN runtime for reliable iOS rendering. */
#content,
#content * {
  box-sizing: border-box;
}

#content {
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

#content :where(h1, h2, h3, p) {
  margin-top: 0;
  margin-bottom: 0;
}

#content a {
  text-decoration: none;
}

#content .relative { position: relative; }
#content .absolute { position: absolute; }
#content .inset-0 { inset: 0; }
#content .top-6 { top: 1.5rem; }
#content .right-6 { right: 1.5rem; }
#content .bottom-4 { bottom: 1rem; }
#content .left-4 { left: 1rem; }
#content .right-4 { right: 1rem; }
#content .z-10 { z-index: 10; }

#content .block { display: block; }
#content .inline-block { display: inline-block; }
#content .flex { display: flex; }
#content .inline-flex { display: inline-flex; }
#content .grid { display: grid; }
#content .hidden { display: none; }

#content .flex-col { flex-direction: column; }
#content .flex-wrap { flex-wrap: wrap; }
#content .flex-1 { flex: 1 1 0%; }
#content .flex-shrink-0 { flex-shrink: 0; }
#content .shrink-0 { flex-shrink: 0; }
#content .items-start { align-items: flex-start; }
#content .items-center { align-items: center; }
#content .items-end { align-items: flex-end; }
#content .items-stretch { align-items: stretch; }
#content .justify-center { justify-content: center; }
#content .justify-between { justify-content: space-between; }

#content .grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
#content .gap-2 { gap: 0.5rem; }
#content .gap-3 { gap: 0.75rem; }
#content .gap-4 { gap: 1rem; }
#content .gap-5 { gap: 1.25rem; }
#content .gap-6 { gap: 1.5rem; }
#content .gap-8 { gap: 2rem; }
#content .gap-10 { gap: 2.5rem; }

#content .mx-auto { margin-left: auto; margin-right: auto; }
#content .my-4 { margin-top: 1rem; margin-bottom: 1rem; }
#content .-mt-24 { margin-top: -6rem; }
#content .mt-3 { margin-top: 0.75rem; }
#content .mt-4 { margin-top: 1rem; }
#content .mt-6 { margin-top: 1.5rem; }
#content .mt-8 { margin-top: 2rem; }
#content .mb-1 { margin-bottom: 0.25rem; }
#content .mb-2 { margin-bottom: 0.5rem; }
#content .mb-3 { margin-bottom: 0.75rem; }
#content .mb-4 { margin-bottom: 1rem; }
#content .mb-5 { margin-bottom: 1.25rem; }
#content .mb-6 { margin-bottom: 1.5rem; }
#content .mb-8 { margin-bottom: 2rem; }
#content .mb-10 { margin-bottom: 2.5rem; }
#content .mb-12 { margin-bottom: 3rem; }
#content .mb-16 { margin-bottom: 4rem; }

#content .p-3 { padding: 0.75rem; }
#content .p-4 { padding: 1rem; }
#content .p-5 { padding: 1.25rem; }
#content .p-6 { padding: 1.5rem; }
#content .p-7 { padding: 1.75rem; }
#content .p-8 { padding: 2rem; }
#content .px-3 { padding-left: 0.75rem; padding-right: 0.75rem; }
#content .px-4 { padding-left: 1rem; padding-right: 1rem; }
#content .px-5 { padding-left: 1.25rem; padding-right: 1.25rem; }
#content .px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
#content .px-7 { padding-left: 1.75rem; padding-right: 1.75rem; }
#content .px-8 { padding-left: 2rem; padding-right: 2rem; }
#content .py-1\.5 { padding-top: 0.375rem; padding-bottom: 0.375rem; }
#content .py-2 { padding-top: 0.5rem; padding-bottom: 0.5rem; }
#content .py-2\.5 { padding-top: 0.625rem; padding-bottom: 0.625rem; }
#content .py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
#content .py-16 { padding-top: 4rem; padding-bottom: 4rem; }
#content .py-20 { padding-top: 5rem; padding-bottom: 5rem; }

#content .h-8 { height: 2rem; }
#content .h-2\.5 { height: 0.625rem; }
#content .h-10 { height: 2.5rem; }
#content .h-11 { height: 2.75rem; }
#content .h-12 { height: 3rem; }
#content .h-full { height: 100%; }
#content .w-2\.5 { width: 0.625rem; }
#content .w-7 { width: 1.75rem; }
#content .w-8 { width: 2rem; }
#content .w-10 { width: 2.5rem; }
#content .w-11 { width: 2.75rem; }
#content .w-12 { width: 3rem; }
#content .w-full { width: 100%; }
#content [class~="h-[400px]"] { height: 400px; }
#content [class~="aspect-[4/3]"] { aspect-ratio: 4 / 3; }
#content [class~="min-h-[260px]"] { min-height: 260px; }
#content [class~="min-h-[300px]"] { min-height: 300px; }

#content .max-w-xl { max-width: 36rem; }
#content .max-w-2xl { max-width: 42rem; }
#content .max-w-3xl { max-width: 48rem; }
#content .max-w-6xl { max-width: 72rem; }

#content .overflow-hidden { overflow: hidden; }
#content .object-cover { object-fit: cover; }
#content .whitespace-nowrap { white-space: nowrap; }

#content .rounded-md { border-radius: 0.375rem; }
#content .rounded-lg { border-radius: 0.5rem; }
#content .rounded-xl { border-radius: 0.75rem; }
#content .rounded-2xl { border-radius: 1rem; }
#content .rounded-3xl { border-radius: 1.5rem; }
#content .rounded-full { border-radius: 9999px; }

#content .border { border-width: 1px; border-style: solid; }
#content .border-2 { border-width: 2px; border-style: solid; }
#content .border-t { border-top-width: 1px; border-top-style: solid; }
#content .border-b-4 { border-bottom-width: 4px; border-bottom-style: solid; }
#content .border-slate-100 { border-color: #f1f5f9; }
#content .border-slate-200 { border-color: #e2e8f0; }
#content .border-amber-200 { border-color: #fde68a; }
#content .border-brand-cyan { border-color: #008b94; }
#content .border-black\/20 { border-color: rgba(0, 0, 0, 0.2); }

#content .bg-white { background-color: #fff; }
#content .bg-brand-lightBg { background-color: #f4f7f8; }
#content .bg-brand-cyan { background-color: #008b94; }
#content .bg-brand-pink { background-color: #e1005e; }
#content .bg-slate-50 { background-color: #f8fafc; }
#content .bg-slate-300 { background-color: #cbd5e1; }
#content .bg-slate-800 { background-color: #1e293b; }
#content .bg-slate-900 { background-color: #0f172a; }
#content .bg-sky-100 { background-color: #e0f2fe; }
#content .bg-teal-100 { background-color: #ccfbf1; }
#content .bg-emerald-50 { background-color: #ecfdf5; }
#content .bg-emerald-600 { background-color: #059669; }
#content .bg-amber-50 { background-color: #fffbeb; }
#content .bg-brand-cyan\/10 { background-color: rgba(0, 139, 148, 0.1); }
#content .bg-brand-cyan\/20 { background-color: rgba(0, 139, 148, 0.2); }
#content .bg-brand-pink\/10 { background-color: rgba(225, 0, 94, 0.1); }
#content .bg-white\/10 { background-color: rgba(255, 255, 255, 0.1); }
#content .bg-white\/90 { background-color: rgba(255, 255, 255, 0.9); }

#content .bg-gradient-to-r { background-image: linear-gradient(to right, var(--tw-gradient-from), var(--tw-gradient-to)); }
#content .bg-gradient-to-tr { background-image: linear-gradient(to top right, var(--tw-gradient-from), var(--tw-gradient-to)); }
#content .bg-gradient-to-br { background-image: linear-gradient(to bottom right, var(--tw-gradient-from), var(--tw-gradient-to)); }
#content .from-white { --tw-gradient-from: #fff; }
#content .from-brand-cyan { --tw-gradient-from: #008b94; }
#content .from-cyan-400 { --tw-gradient-from: #22d3ee; }
#content .to-brand-cyan { --tw-gradient-to: #008b94; }
#content .to-brand-cyanDark { --tw-gradient-to: #006d75; }
#content .to-emerald-300 { --tw-gradient-to: #6ee7b7; }

#content .text-center { text-align: center; }
#content .text-xs { font-size: 0.75rem; line-height: 1rem; }
#content .text-sm { font-size: 0.875rem; line-height: 1.25rem; }
#content .text-lg { font-size: 1.125rem; line-height: 1.75rem; }
#content .text-xl { font-size: 1.25rem; line-height: 1.75rem; }
#content .text-2xl { font-size: 1.5rem; line-height: 2rem; }
#content .text-3xl { font-size: 1.875rem; line-height: 2.25rem; }
#content .text-5xl { font-size: 3rem; line-height: 1; }
#content .text-6xl { font-size: 3.75rem; line-height: 1; }
#content .text-7xl { font-size: 4.5rem; line-height: 1; }
#content [class~="text-[10px]"] { font-size: 10px; line-height: 1rem; }

#content .font-normal { font-weight: 400; }
#content .font-medium { font-weight: 500; }
#content .font-semibold { font-weight: 600; }
#content .font-bold { font-weight: 700; }
#content .font-black { font-weight: 900; }
#content .italic { font-style: italic; }
#content .uppercase { text-transform: uppercase; }
#content .leading-tight { line-height: 1.25; }
#content .leading-snug { line-height: 1.375; }
#content .leading-relaxed { line-height: 1.625; }
#content .tracking-tighter { letter-spacing: -0.05em; }
#content .tracking-wide { letter-spacing: 0.025em; }
#content .tracking-wider { letter-spacing: 0.05em; }
#content .tracking-widest { letter-spacing: 0.1em; }

#content .text-white { color: #fff; }
#content .text-brand-cyan { color: #008b94; }
#content .text-brand-pink { color: #e1005e; }
#content .text-slate-300 { color: #cbd5e1; }
#content .text-slate-500 { color: #64748b; }
#content .text-slate-600 { color: #475569; }
#content .text-slate-700 { color: #334155; }
#content .text-slate-800 { color: #1e293b; }
#content .text-slate-900 { color: #0f172a; }
#content .text-amber-400 { color: #fbbf24; }
#content .text-amber-600 { color: #d97706; }
#content .text-emerald-600 { color: #059669; }
#content .text-brand-cyan\/15 { color: rgba(0, 139, 148, 0.15); }
#content .text-brand-pink\/10 { color: rgba(225, 0, 94, 0.1); }
#content .text-emerald-500\/10 { color: rgba(16, 185, 129, 0.1); }
#content .text-white\/75 { color: rgba(255, 255, 255, 0.75); }
#content .text-white\/80 { color: rgba(255, 255, 255, 0.8); }
#content .text-white\/90 { color: rgba(255, 255, 255, 0.9); }

#content .opacity-20 { opacity: 0.2; }
#content .opacity-80 { opacity: 0.8; }
#content .opacity-90 { opacity: 0.9; }

#content .shadow-sm { box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06); }
#content .shadow-md { box-shadow: 0 4px 6px rgba(15, 23, 42, 0.12); }
#content .shadow-lg { box-shadow: 0 10px 15px rgba(15, 23, 42, 0.12); }
#content .shadow-xl { box-shadow: 0 20px 25px rgba(15, 23, 42, 0.14); }
#content .shadow-pink-200 { box-shadow: 0 10px 15px rgba(251, 207, 232, 0.8); }
#content .drop-shadow-md { filter: drop-shadow(0 4px 3px rgba(0, 0, 0, 0.18)); }
#content .drop-shadow-lg { filter: drop-shadow(0 10px 8px rgba(0, 0, 0, 0.18)); }
#content .backdrop-blur-sm {
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}
#content .ring-4 { box-shadow: 0 0 0 4px var(--tw-ring-color, rgba(255, 255, 255, 0.75)); }
#content .ring-white { --tw-ring-color: #fff; }
#content .ring-brand-lightBg { --tw-ring-color: #f4f7f8; }

#content .transition,
#content .transition-all {
  transition-property: color, background-color, border-color, box-shadow, opacity, transform;
  transition-duration: 180ms;
  transition-timing-function: ease;
}
#content .transition-transform { transition-property: transform; }
#content .duration-500 { transition-duration: 500ms; }
#content .ease-out { transition-timing-function: cubic-bezier(0, 0, 0.2, 1); }

#content .hover\:bg-slate-100:hover { background-color: #f1f5f9; }
#content .hover\:bg-brand-cyanDark:hover { background-color: #006d75; }
#content .hover\:bg-brand-pinkHover:hover { background-color: #c40052; }
#content .hover\:shadow-md:hover { box-shadow: 0 4px 6px rgba(15, 23, 42, 0.12); }
#content .hover\:bg-slate-400:hover { background-color: #94a3b8; }
#content .group:hover .group-hover\:shadow-lg { box-shadow: 0 10px 15px rgba(15, 23, 42, 0.12); }
#content .active\:scale-95:active { transform: scale(0.95); }

#content .testimonial-marquee {
  position: relative;
}

#content .testimonial-marquee::before,
#content .testimonial-marquee::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 56px;
  z-index: 2;
  pointer-events: none;
}

#content .testimonial-marquee::before {
  left: 0;
  background: linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, 0) 100%);
}

#content .testimonial-marquee::after {
  right: 0;
  background: linear-gradient(270deg, #fff 0%, rgba(255, 255, 255, 0) 100%);
}

#content .testimonial-marquee-track {
  width: max-content;
  animation: testimonial-marquee var(--testimonial-duration, 36s) linear infinite;
  will-change: transform;
}

#content .testimonial-marquee .testimonial-card {
  width: calc(100vw - 2rem);
}

#content .testimonial-marquee:hover .testimonial-marquee-track {
  animation-play-state: paused;
}

#content .testimonial-marquee-track.testimonial-marquee-boost {
  animation-duration: 8s;
}

@keyframes testimonial-marquee {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(calc(-1 * var(--testimonial-shift, 1200px)));
  }
}

@media (prefers-reduced-motion: reduce) {
  #content .testimonial-marquee-track {
    animation: none;
  }
}

@media (min-width: 640px) {
  #content .sm\:flex-row { flex-direction: row; }
  #content .sm\:items-center { align-items: center; }
  #content .sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  #content .sm\:w-auto { width: auto; }
}

@media (min-width: 768px) {
  #content .md\:block { display: block; }
  #content .md\:flex-row { flex-direction: row; }
  #content .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  #content .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  #content [class~="md:grid-cols-[1fr_auto]"] { grid-template-columns: 1fr auto; }
  #content .md\:p-6 { padding: 1.5rem; }
  #content .md\:p-7 { padding: 1.75rem; }
  #content .md\:p-8 { padding: 2rem; }
  #content .md\:p-12 { padding: 3rem; }
  #content .md\:text-4xl { font-size: 2.25rem; line-height: 2.5rem; }
  #content .md\:text-5xl { font-size: 3rem; line-height: 1; }
  #content [class~="md:text-[1.7rem]"] { font-size: 1.7rem; }
  #content .md\:w-1\/2 { width: 50%; }
  #content .md\:w-auto { width: auto; }
  #content [class~="md:w-[calc(50%-10px)]"] { width: calc(50% - 10px); }
  #content .testimonial-marquee .testimonial-card {
    width: calc((min(100vw - 2rem, 72rem) - 20px) / 2);
  }
}

@media (min-width: 1024px) {
  #content .lg\:flex-row { flex-direction: row; }
  #content .lg\:items-end { align-items: flex-end; }
  #content .lg\:justify-between { justify-content: space-between; }
  #content .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  #content [class~="lg:grid-cols-[0.9fr_1.1fr]"] { grid-template-columns: 0.9fr 1.1fr; }
  #content [class~="lg:grid-cols-[1fr_1.2fr]"] { grid-template-columns: 1fr 1.2fr; }
  #content .lg\:w-1\/3 { width: 33.333333%; }
  #content .lg\:w-2\/3 { width: 66.666667%; }
  #content [class~="lg:w-[calc(33.333%-14px)]"] { width: calc(33.333% - 14px); }
  #content .testimonial-marquee .testimonial-card {
    width: calc((min(100vw - 2rem, 72rem) - 40px) / 3);
  }
}
