@import "https://rsms.me/inter/inter.css";
/* [next]/internal/font/google/inter_a74e9378.module.css [app-client] (css) */
@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/5476f68d60460930-s.0wxq9webf.ew4.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Inter Fallback;
  src: local(Arial);
  ascent-override: 90.44%;
  descent-override: 22.52%;
  line-gap-override: 0.0%;
  size-adjust: 107.12%;
}

.inter_a74e9378-module__elCoYG__className {
  font-family: Inter, Inter Fallback;
  font-style: normal;
}

.inter_a74e9378-module__elCoYG__variable {
  --font-inter: "Inter", "Inter Fallback";
}

/* [project]/src/app/globals.css [app-client] (css) */
@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-border-style: solid;
    }
  }
}

@layer theme {
  :root, :host {
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --default-font-family: "Inter", system-ui, sans-serif;
    --default-mono-font-family: var(--font-mono);
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    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;
    -webkit-text-decoration: inherit;
    -webkit-text-decoration: 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 {
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
    position: relative;
  }

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.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 {
    vertical-align: middle;
    display: block;
  }

  img, video {
    max-width: 100%;
    height: auto;
  }

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :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;
  }

  ::placeholder {
    opacity: 1;
  }

  @supports (not ((-webkit-appearance: -apple-pay-button))) or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentColor;
    }

    @supports (color: color-mix(in lab, red, red)) {
      ::placeholder {
        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 {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-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"]) {
    appearance: button;
  }

  ::file-selector-button {
    appearance: button;
  }

  ::-webkit-inner-spin-button {
    height: auto;
  }

  ::-webkit-outer-spin-button {
    height: auto;
  }

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}

@layer components;

@layer utilities {
  .relative {
    position: relative;
  }

  .static {
    position: static;
  }

  .block {
    display: block;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .inline {
    display: inline;
  }

  .inline-block {
    display: inline-block;
  }

  .inline-flex {
    display: inline-flex;
  }

  .h-full {
    height: 100%;
  }

  .min-h-full {
    min-height: 100%;
  }

  .flex-1 {
    flex: 1;
  }

  .transform {
    transform: var(--tw-rotate-x, ) var(--tw-rotate-y, ) var(--tw-rotate-z, ) var(--tw-skew-x, ) var(--tw-skew-y, );
  }

  .flex-col {
    flex-direction: column;
  }

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .uppercase {
    text-transform: uppercase;
  }

  .antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}

:root {
  --bg: #fff;
  --bg-alt: #f8f9fa;
  --bg-dark: #000;
  --text: #000;
  --text-2: #333;
  --text-3: #666;
  --text-4: #a0a0a0;
  --border: #e5e5e5;
  --border-dark: #1f1f1f;
  --green: #22c55e;
  --green-soft: #ecfdf3;
  --green-border: #bbf7d0;
  --orange: #f97316;
  --orange-soft: #fff7ed;
  --orange-border: #fed7aa;
}

.accent-clinic {
  --accent: #16a34a;
  --accent-soft: #ecfdf3;
  --accent-border: #bbf7d0;
}

.accent-safe {
  --accent: #f97316;
  --accent-soft: #fff7ed;
  --accent-border: #fed7aa;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  font-feature-settings: "cv11", "ss01", "ss03";
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  letter-spacing: -.01em;
  margin: 0;
  padding: 0;
  font-family: Inter, system-ui, -apple-system, sans-serif;
  line-height: 1.5;
}

.btn {
  letter-spacing: -.01em;
  white-space: nowrap;
  cursor: pointer;
  border: 1px solid #0000;
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  height: 44px;
  padding: 0 20px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: opacity .15s, background .15s, transform .1s;
  display: inline-flex;
}

.btn-primary {
  color: #fff;
  background: #000;
}

.btn-primary:hover {
  opacity: .85;
}

.btn-outline {
  color: #000;
  border-color: var(--border);
  background: none;
}

.btn-outline:hover {
  background: #fafafa;
}

.btn-light {
  color: #000;
  background: #fff;
}

.btn-light:hover {
  opacity: .9;
}

.btn-ghost-dark {
  color: #fff;
  background: none;
  border-color: #2a2a2a;
}

.btn-ghost-dark:hover {
  background: #0f0f0f;
  border-color: #3a3a3a;
}

.btn-sm {
  height: 38px;
  padding: 0 16px;
  font-size: 13px;
}

.btn-lg {
  height: 52px;
  padding: 0 26px;
  font-size: 15px;
}

.btn-block {
  width: 100%;
}

.site-header {
  z-index: 50;
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--border);
  background: #ffffffd9;
  position: sticky;
  top: 0;
}

.site-header-inner {
  justify-content: space-between;
  align-items: center;
  max-width: 1280px;
  height: 68px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
}

.nav-links {
  gap: 32px;
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
}

.nav-links a {
  color: var(--text-2);
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: color .15s;
}

.nav-links a:hover, .nav-links a.active {
  color: var(--text);
}

.nav-dropdown-wrapper {
  position: relative;
}

.nav-dropdown-wrapper:after {
  content: "";
  pointer-events: none;
  height: 12px;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
}

.nav-dropdown-wrapper:hover:after {
  pointer-events: auto;
}

.nav-dropdown-trigger {
  color: var(--text-2);
  cursor: pointer;
  background: none;
  border: none;
  align-items: center;
  gap: 4px;
  padding: 0;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  transition: color .15s;
  display: inline-flex;
}

.nav-dropdown-trigger:hover {
  color: var(--text);
}

.nav-dropdown-trigger .chevron {
  font-size: 10px;
  transition: transform .2s;
}

.nav-dropdown-wrapper:hover .chevron, .nav-dropdown-wrapper.open .chevron {
  transform: rotate(180deg);
}

.nav-dropdown {
  border: 1px solid var(--border);
  opacity: 0;
  pointer-events: none;
  z-index: 100;
  background: #fff;
  border-radius: 12px;
  min-width: 220px;
  padding: 8px;
  transition: opacity .15s, transform .15s;
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translate(-50%)translateY(4px);
  box-shadow: 0 12px 32px #00000014;
}

.nav-dropdown-wrapper:hover .nav-dropdown, .nav-dropdown-wrapper.open .nav-dropdown {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%)translateY(0);
}

.nav-dropdown-item {
  color: var(--text);
  border-radius: 8px;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  text-decoration: none;
  transition: background .15s;
  display: flex;
}

.nav-dropdown-item:hover {
  background: var(--bg-alt);
}

.nav-dropdown-item .product-dot {
  border-radius: 50%;
  flex-shrink: 0;
  width: 8px;
  height: 8px;
}

.nav-dropdown-item .product-dot.clinic {
  background: #16a34a;
}

.nav-dropdown-item .product-dot.safe {
  background: #f97316;
}

.nav-dropdown-item .product-info {
  flex-direction: column;
  display: flex;
}

.nav-dropdown-item .product-name {
  font-size: 14px;
  font-weight: 600;
}

.nav-dropdown-item .product-desc {
  color: var(--text-3);
  font-size: 12px;
}

.hamburger {
  border: 1px solid var(--border);
  cursor: pointer;
  background: #fff;
  border-radius: 8px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
  width: 40px;
  height: 40px;
  padding: 0;
  display: none;
}

.hamburger span {
  background: #000;
  width: 16px;
  height: 1.5px;
  display: block;
}

.site-footer {
  color: #fff;
  background: #000;
  padding: 64px 40px 32px;
}

.site-footer-inner {
  max-width: 1280px;
  margin: 0 auto;
}

.footer-grid {
  border-bottom: 1px solid #1f1f1f;
  grid-template-columns: 1.5fr 1fr 1.5fr;
  gap: 64px;
  padding-bottom: 48px;
  display: grid;
}

.footer-col h4 {
  color: #a0a0a0;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: 0 0 16px;
  font-size: 13px;
  font-weight: 500;
}

.footer-col ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.footer-col li {
  margin-bottom: 10px;
}

.footer-col a {
  color: #d4d4d4;
  font-size: 14px;
  text-decoration: none;
  transition: color .15s;
}

.footer-col a:hover {
  color: #fff;
}

.footer-desc {
  color: #a0a0a0;
  max-width: 320px;
  margin: 16px 0 0;
  font-size: 14px;
  line-height: 1.6;
}

.footer-bottom {
  color: #888;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
  padding-top: 24px;
  font-size: 12.5px;
  display: flex;
}

.footer-bottom a {
  color: #888;
  text-decoration: none;
}

.footer-bottom a:hover {
  color: #fff;
}

.footer-legal-links {
  gap: 20px;
  display: flex;
}

.section {
  padding: 96px 40px;
}

.section.alt {
  background: var(--bg-alt);
}

.section.dark {
  color: #fff;
  background: #000;
}

.section-inner {
  max-width: 1280px;
  margin: 0 auto;
}

.eyebrow {
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 16px;
  font-size: 12px;
  font-weight: 500;
  display: inline-block;
}

.section.dark .eyebrow {
  color: #a0a0a0;
}

h1.display, h2.display, h3.display {
  letter-spacing: -.03em;
  text-wrap: balance;
  margin: 0;
  font-weight: 600;
  line-height: 1.05;
}

h1.display {
  font-size: 60px;
}

h2.display {
  font-size: 44px;
}

h3.display {
  font-size: 28px;
}

.lead {
  color: var(--text-3);
  text-wrap: pretty;
  max-width: 560px;
  margin: 20px 0 0;
  font-size: 19px;
  line-height: 1.55;
}

.section.dark .lead {
  color: #a0a0a0;
}

.hero {
  padding: 88px 40px 96px;
}

.hero-home {
  background-color: #fff;
  background-image: radial-gradient(58% 52%, #fff 15%, #ffffffd9 40%, #0000 68%), radial-gradient(circle, #00000021 1.5px, #0000 1.5px), radial-gradient(55% 50% at 3% 5%, #16a34a2e 0%, #0000 65%), radial-gradient(50% 45% at 97% 95%, #f9731629 0%, #0000 65%), radial-gradient(38% 32% at 95% 5%, #16a34a1a 0%, #0000 62%), radial-gradient(32% 28% at 5% 95%, #f9731614 0%, #0000 62%);
  background-size: 100% 100%, 26px 26px, 100% 100%, 100% 100%, 100% 100%, 100% 100%;
  position: relative;
  overflow: hidden;
}

.hero-grid {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 64px;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
}

.hero-cta-row {
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 36px;
  display: flex;
}

.hero-meta {
  color: var(--text-3);
  flex-wrap: wrap;
  gap: 24px;
  margin-top: 32px;
  font-size: 13px;
  display: flex;
}

.hero-meta-item {
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.hero-meta-dot {
  background: var(--green);
  border-radius: 50%;
  width: 6px;
  height: 6px;
}

.features-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 56px;
}

.features-head .lead {
  margin: 16px auto 0;
}

.feature-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  display: grid;
}

.feature-card {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 12px;
  padding: 28px;
  transition: box-shadow .2s, transform .2s, border-color .2s;
}

.feature-card:hover {
  border-color: #d4d4d4;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px #0000000f;
}

.feature-card .icon {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  margin-bottom: 20px;
  display: flex;
}

.feature-card h3 {
  letter-spacing: -.01em;
  margin: 0 0 8px;
  font-size: 17px;
  font-weight: 600;
}

.feature-card p {
  color: var(--text-3);
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
}

.cta-block {
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}

.cta-block h2 {
  color: #fff;
  letter-spacing: -.03em;
  margin: 0;
  font-size: 48px;
  font-weight: 600;
  line-height: 1.05;
}

.cta-block p {
  color: #a0a0a0;
  margin: 20px 0 36px;
  font-size: 18px;
}

.cta-row {
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  display: flex;
}

.page-hero {
  padding: 88px 40px;
}

.page-hero-grid {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 80px;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
}

.page-hero h1 {
  font-size: 56px;
}

.page-hero p {
  color: var(--text-3);
  margin-top: 20px;
  font-size: 17px;
  line-height: 1.6;
}

.values-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  display: grid;
}

.value-card {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 12px;
  padding: 32px;
}

.value-card .icon {
  border: 1px solid var(--border);
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  margin-bottom: 20px;
  display: flex;
}

.value-card h3 {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 600;
}

.value-card p {
  color: var(--text-3);
  margin: 0;
  font-size: 14.5px;
  line-height: 1.55;
}

.team-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  display: grid;
}

.team-card {
  border: 1px solid var(--border);
  text-align: center;
  background: #fff;
  border-radius: 12px;
  padding: 32px;
}

.team-avatar {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  width: 88px;
  height: 88px;
  color: var(--text-3);
  letter-spacing: -.02em;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  margin: 0 auto 16px;
  font-size: 24px;
  font-weight: 500;
  display: flex;
}

.team-card h3 {
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 600;
}

.team-card .role {
  color: var(--text-3);
  margin: 0;
  font-size: 13.5px;
}

.contact-grid {
  grid-template-columns: 1fr 1fr;
  align-items: start;
  gap: 80px;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
}

.contact-info-block {
  gap: 18px;
  margin-top: 36px;
  display: grid;
}

.contact-info-row {
  align-items: flex-start;
  gap: 14px;
  display: flex;
}

.contact-info-row .icon {
  border: 1px solid var(--border);
  border-radius: 8px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  display: flex;
}

.contact-info-row .label {
  color: var(--text-3);
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 2px;
  font-size: 12px;
}

.contact-info-row .value {
  color: var(--text);
  font-size: 15px;
  font-weight: 500;
}

.form-card {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 14px;
  padding: 36px;
}

.form-row {
  gap: 6px;
  margin-bottom: 18px;
  display: grid;
}

.form-row label {
  color: var(--text-2);
  font-size: 13px;
  font-weight: 500;
}

.form-row label .req {
  color: var(--text);
}

.form-row input, .form-row textarea {
  border: 1px solid var(--border);
  color: var(--text);
  background: #fff;
  border-radius: 8px;
  outline: none;
  padding: 12px 14px;
  font-family: inherit;
  font-size: 14.5px;
  transition: border-color .15s, box-shadow .15s;
}

.form-row input:focus, .form-row textarea:focus {
  border-color: #000;
  box-shadow: 0 0 0 3px #0000000f;
}

.form-row textarea {
  resize: vertical;
  min-height: 120px;
}

.form-success {
  background: var(--green-soft);
  border: 1px solid var(--green-border);
  border-radius: 12px;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 18px;
  padding: 20px;
  display: flex;
}

.form-success .check-icon {
  background: var(--green);
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 28px;
  height: 28px;
  display: flex;
}

.form-success h4 {
  color: #166534;
  margin: 0 0 4px;
  font-size: 14.5px;
  font-weight: 600;
}

.form-success p {
  color: #166534;
  margin: 0;
  font-size: 13.5px;
  line-height: 1.5;
}

.dash {
  aspect-ratio: 4 / 3;
  border: 1px solid var(--border);
  width: 100%;
  color: var(--text);
  background: #fff;
  border-radius: 14px;
  grid-template-columns: 168px 1fr;
  font-size: 11px;
  display: grid;
  overflow: hidden;
  box-shadow: 0 24px 60px -20px #0000002e, 0 0 0 1px #00000005;
}

.dash-side {
  color: #d4d4d4;
  background: #0a0a0a;
  flex-direction: column;
  gap: 4px;
  padding: 16px 12px;
  display: flex;
}

.dash-logo {
  color: #fff;
  letter-spacing: -.02em;
  align-items: center;
  gap: 8px;
  padding: 6px 8px 14px;
  font-size: 13px;
  font-weight: 600;
  display: flex;
}

.dash-logo-mark {
  color: #000;
  background: #fff;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  width: 22px;
  height: 22px;
  font-size: 11px;
  font-weight: 700;
  display: flex;
}

.dash-side-section {
  color: #6b6b6b;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 12px 8px 6px;
  font-size: 9.5px;
}

.dash-nav {
  color: #b5b5b5;
  border-radius: 6px;
  align-items: center;
  gap: 8px;
  padding: 7px 8px;
  font-size: 11.5px;
  display: flex;
}

.dash-nav.active {
  color: #fff;
  background: #1a1a1a;
}

.dash-nav .dot {
  opacity: .7;
  border: 1px solid;
  border-radius: 3px;
  width: 12px;
  height: 12px;
}

.dash-nav .badge {
  color: #000;
  background: #22c55e;
  border-radius: 4px;
  margin-left: auto;
  padding: 1px 5px;
  font-size: 9px;
  font-weight: 600;
}

.dash-main {
  flex-direction: column;
  min-width: 0;
  display: flex;
}

.dash-topbar {
  border-bottom: 1px solid var(--border);
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  display: flex;
}

.dash-search {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  color: var(--text-3);
  border-radius: 6px;
  align-items: center;
  gap: 6px;
  width: 180px;
  padding: 5px 10px;
  font-size: 11px;
  display: flex;
}

.dash-topbar-actions {
  align-items: center;
  gap: 8px;
  display: flex;
}

.dash-avatar {
  width: 24px;
  height: 24px;
  color: var(--text-2);
  background: #e5e5e5;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-size: 9.5px;
  font-weight: 600;
  display: flex;
}

.dash-iconbtn {
  border: 1px solid var(--border);
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  width: 26px;
  height: 26px;
  display: flex;
  position: relative;
}

.dash-iconbtn .bell-dot {
  background: var(--green);
  border-radius: 50%;
  width: 5px;
  height: 5px;
  position: absolute;
  top: 4px;
  right: 4px;
}

.dash-body {
  flex: 1;
  grid-template-columns: 1fr 200px;
  gap: 16px;
  padding: 16px;
  display: grid;
  overflow: hidden;
}

.dash-stats {
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 14px;
  display: grid;
}

.dash-stat {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
}

.dash-stat .label {
  color: var(--text-3);
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: 9.5px;
}

.dash-stat .num {
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
  margin-top: 4px;
  font-size: 20px;
  font-weight: 600;
}

.dash-stat .delta {
  color: var(--green);
  margin-top: 2px;
  font-size: 10px;
  font-weight: 500;
}

.dash-stat .delta.neutral {
  color: var(--text-3);
}

.dash-cal {
  border: 1px solid var(--border);
  border-radius: 8px;
  flex-direction: column;
  min-height: 0;
  padding: 12px;
  display: flex;
}

.dash-cal-head {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
  display: flex;
}

.dash-cal-title {
  font-size: 12px;
  font-weight: 600;
}

.dash-cal-nav {
  gap: 4px;
  display: flex;
}

.dash-cal-nav span {
  border: 1px solid var(--border);
  width: 18px;
  height: 18px;
  color: var(--text-3);
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  font-size: 9px;
  display: inline-flex;
}

.dash-cal-grid {
  flex: 1;
  grid-template-columns: 32px repeat(5, 1fr);
  gap: 0;
  font-size: 9.5px;
  display: grid;
}

.dash-cal-grid .cal-h {
  color: var(--text-3);
  border-bottom: 1px solid var(--border);
  text-align: center;
  padding: 4px 6px;
  font-weight: 500;
}

.dash-cal-grid .cal-h.today {
  color: var(--text);
}

.dash-cal-grid .cal-h.today .day-num {
  color: #fff;
  background: #000;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 16px;
  height: 16px;
  margin-left: 3px;
  font-size: 9px;
  display: inline-flex;
}

.dash-cal-grid .cal-time {
  border-bottom: 1px dashed var(--border);
  color: var(--text-4);
  text-align: right;
  padding: 3px 4px;
  font-size: 8.5px;
}

.dash-cal-grid .cal-cell {
  border-bottom: 1px dashed var(--border);
  border-left: 1px solid var(--border);
  min-height: 22px;
  padding: 2px;
  position: relative;
}

.cal-event {
  color: var(--text-2);
  background: #f2f2f2;
  border-left: 2px solid #000;
  border-radius: 3px;
  margin-bottom: 1px;
  padding: 2px 4px;
  font-size: 8.5px;
  line-height: 1.2;
}

.cal-event.green {
  border-left-color: var(--green);
  color: #166534;
  background: #ecfdf3;
}

.cal-event .name {
  color: var(--text);
  font-weight: 600;
  display: block;
}

.cal-event.green .name {
  color: #166534;
}

.dash-patient {
  border: 1px solid var(--border);
  border-radius: 8px;
  flex-direction: column;
  gap: 10px;
  min-height: 0;
  padding: 12px;
  display: flex;
}

.dash-patient-head {
  align-items: center;
  gap: 8px;
  display: flex;
}

.dash-patient-avatar {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  width: 32px;
  height: 32px;
  color: var(--text-2);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-size: 11px;
  font-weight: 600;
  display: flex;
}

.dash-patient-name {
  font-size: 12px;
  font-weight: 600;
}

.dash-patient-meta {
  color: var(--text-3);
  font-size: 9.5px;
}

.dash-patient-row {
  border-top: 1px dashed var(--border);
  justify-content: space-between;
  padding: 5px 0;
  font-size: 10px;
  display: flex;
}

.dash-patient-row .k {
  color: var(--text-3);
}

.dash-patient-row .v {
  font-weight: 500;
}

.dash-patient-tag {
  background: var(--green-soft);
  color: #166534;
  border-radius: 999px;
  align-self: flex-start;
  padding: 2px 7px;
  font-size: 9.5px;
  font-weight: 500;
  display: inline-flex;
}

.dash-patient-actions {
  gap: 6px;
  margin-top: auto;
  padding-top: 6px;
  display: flex;
}

.dash-patient-actions span {
  border: 1px solid var(--border);
  text-align: center;
  color: var(--text-2);
  border-radius: 5px;
  flex: 1;
  padding: 4px 7px;
  font-size: 9.5px;
}

.dash-patient-actions span.primary {
  color: #fff;
  background: #000;
  border-color: #000;
}

.mobile-menu {
  border-top: 1px solid var(--border);
  background: #fff;
  padding: 12px 20px 20px;
}

.mobile-menu ul {
  margin: 0 0 16px;
  padding: 0;
  list-style: none;
}

.mobile-menu li a {
  color: var(--text);
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
  font-size: 16px;
  font-weight: 500;
  text-decoration: none;
  display: block;
}

.register-grid {
  grid-template-columns: 1fr 1fr;
  align-items: start;
  gap: 80px;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
}

.register-benefits {
  gap: 14px;
  margin-top: 36px;
  display: grid;
}

.register-benefit {
  color: var(--text-2);
  align-items: center;
  gap: 12px;
  font-size: 14px;
  display: flex;
}

.register-benefit-icon {
  border: 1px solid var(--border);
  border-radius: 8px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  display: flex;
}

.form-row-grid {
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  display: grid;
}

.password-toggle {
  cursor: pointer;
  color: var(--text-3);
  background: none;
  border: none;
  align-items: center;
  padding: 4px;
  display: flex;
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
}

.password-toggle:hover {
  color: var(--text);
}

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

.verify-card {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 14px;
  flex-direction: column;
  align-items: center;
  padding: 48px 40px;
  display: flex;
}

.verify-card h2 {
  letter-spacing: -.02em;
  margin: 20px 0 8px;
  font-size: 24px;
  font-weight: 600;
}

.verify-card p {
  color: var(--text-3);
  max-width: 380px;
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
}

.verify-check {
  background: var(--green);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 56px;
  height: 56px;
  display: flex;
}

.verify-error-icon {
  background: #ef4444;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 56px;
  height: 56px;
  display: flex;
}

.verify-spinner {
  border: 3px solid var(--border);
  border-top-color: #000;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  animation: .8s linear infinite spin;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.page-hero-content {
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}

.faq-list {
  gap: 0;
  max-width: 780px;
  margin: 0 auto;
  display: grid;
}

.faq-item {
  border-bottom: 1px solid var(--border);
  padding: 0;
}

.faq-item:first-child {
  border-top: 1px solid var(--border);
}

.faq-question {
  cursor: pointer;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 20px 0;
  list-style: none;
  display: flex;
}

.faq-question::-webkit-details-marker {
  display: none;
}

.faq-question h2 {
  letter-spacing: -.01em;
  color: var(--text);
  margin: 0;
  font-size: 17px;
  font-weight: 600;
}

.faq-toggle {
  color: var(--text-3);
  flex-shrink: 0;
  font-size: 20px;
  font-weight: 300;
  transition: transform .2s;
}

.faq-item[open] .faq-toggle {
  transform: rotate(45deg);
}

.faq-answer {
  padding: 0 0 20px;
}

.faq-answer p {
  color: var(--text-2);
  margin: 0;
  font-size: 15px;
  line-height: 1.7;
}

.product-cards {
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 48px;
  display: grid;
}

.product-card {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 16px;
  padding: 36px;
  transition: box-shadow .2s, border-color .2s, transform .2s;
}

.product-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px #0000000f;
}

.product-card.clinic {
  border-top: 3px solid #16a34a;
}

.product-card.safe {
  border-top: 3px solid #f97316;
}

.product-card .product-badge {
  letter-spacing: .04em;
  text-transform: uppercase;
  align-items: center;
  gap: 6px;
  margin-bottom: 16px;
  font-size: 12px;
  font-weight: 600;
  display: inline-flex;
}

.product-card.clinic .product-badge {
  color: #16a34a;
}

.product-card.safe .product-badge {
  color: #f97316;
}

.product-card h3 {
  letter-spacing: -.02em;
  margin: 0 0 12px;
  font-size: 24px;
  font-weight: 600;
}

.product-card p {
  color: var(--text-3);
  margin: 0 0 24px;
  font-size: 15px;
  line-height: 1.6;
}

.product-card .btn-product-clinic {
  color: #fff;
  background: #16a34a;
}

.product-card .btn-product-clinic:hover {
  opacity: .85;
}

.product-card .btn-product-safe {
  color: #fff;
  background: #f97316;
}

.product-card .btn-product-safe:hover {
  opacity: .85;
}

.dash-safe {
  aspect-ratio: 4 / 3;
  border: 1px solid var(--border);
  width: 100%;
  color: var(--text);
  background: #fff;
  border-radius: 14px;
  grid-template-columns: 168px 1fr;
  font-size: 11px;
  display: grid;
  overflow: hidden;
  box-shadow: 0 24px 60px -20px #0000002e, 0 0 0 1px #00000005;
}

.dash-safe .dash-nav .badge {
  color: #fff;
  background: #f97316;
}

.cal-event.orange {
  color: #9a3412;
  background: #fff7ed;
  border-left-color: #f97316;
}

.cal-event.orange .name {
  color: #9a3412;
}

.dash-patient-tag.orange {
  background: var(--orange-soft);
  color: #9a3412;
}

.dash-stat .delta.orange {
  color: #f97316;
}

.product-card-photo {
  border-radius: 10px;
  height: 190px;
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
}

.photo-context-inner {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 64px;
  display: grid;
}

.photo-context-img {
  border-radius: 16px;
  height: 420px;
  position: relative;
  overflow: hidden;
}

.photo-context-text {
  flex-direction: column;
  gap: 16px;
  display: flex;
}

.photo-context-text h2 {
  letter-spacing: -.03em;
  margin: 0;
  font-size: 38px;
  font-weight: 600;
  line-height: 1.15;
}

.photo-context-text p {
  color: var(--text-3);
  margin: 0;
  font-size: 16px;
  line-height: 1.65;
}

.company-photo-wrap {
  border-radius: 20px;
  height: 420px;
  position: relative;
  overflow: hidden;
}

.company-photo-caption {
  -webkit-backdrop-filter: blur(12px);
  color: var(--text);
  background: #ffffffe0;
  border: 1px solid #ffffff80;
  border-radius: 8px;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 500;
  position: absolute;
  bottom: 20px;
  left: 20px;
}

.why-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 48px;
  display: grid;
}

.why-card {
  text-align: center;
  padding: 28px 20px;
}

.why-card .icon {
  border: 1px solid var(--border);
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  margin: 0 auto 16px;
  display: flex;
}

.why-card h4 {
  margin: 0 0 6px;
  font-size: 15px;
  font-weight: 600;
}

.why-card p {
  color: var(--text-3);
  margin: 0;
  font-size: 13.5px;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .site-header-inner {
    height: 60px;
    padding: 0 20px;
  }

  .nav-links, .header-cta {
    display: none;
  }

  .hamburger {
    display: inline-flex;
  }

  .section, .hero, .page-hero {
    padding: 56px 20px;
  }

  .hero-grid, .page-hero-grid, .contact-grid, .register-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .form-row-grid {
    grid-template-columns: 1fr;
  }

  .verify-card {
    padding: 36px 24px;
  }

  h1.display {
    font-size: 36px;
  }

  h2.display {
    font-size: 30px;
  }

  .page-hero h1 {
    font-size: 36px;
  }

  .lead {
    font-size: 16px;
  }

  .feature-grid, .values-grid, .team-grid {
    grid-template-columns: 1fr;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .site-footer {
    padding: 48px 20px 28px;
  }

  .footer-bottom {
    flex-direction: column;
    gap: 8px;
  }

  .cta-block h2 {
    font-size: 32px;
  }

  .form-card {
    padding: 24px;
  }

  .hero-cta-row {
    flex-direction: column;
    width: 100%;
  }

  .hero-cta-row .btn {
    width: 100%;
  }

  .cta-row {
    flex-direction: column;
  }

  .cta-row .btn {
    width: 100%;
  }

  .dash, .dash-safe {
    display: none;
  }

  .product-cards {
    grid-template-columns: 1fr;
  }

  .product-card-photo {
    height: 160px;
  }

  .why-grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }

  .photo-context-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .photo-context-img {
    height: 240px;
  }

  .photo-context-text h2 {
    font-size: 26px;
  }

  .company-photo-wrap {
    height: 260px;
  }

  .nav-dropdown-wrapper {
    display: none;
  }

  .mobile-products {
    padding: 0 0 8px;
  }

  .mobile-products a {
    color: var(--text-2);
    align-items: center;
    gap: 10px;
    padding: 10px 0;
    font-size: 15px;
    font-weight: 500;
    text-decoration: none;
    display: flex;
  }

  .mobile-products .product-dot {
    border-radius: 50%;
    width: 8px;
    height: 8px;
  }
}

@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-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

/*# sourceMappingURL=%5Broot-of-the-server%5D__0~62yvv._.css.map*/