.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  font-size: 0.9375rem;
  font-weight: 700;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background var(--transition), color var(--transition), transform var(--transition), box-shadow var(--transition);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  user-select: none;
  -webkit-user-select: none;
}

.btn--primary {
  background: var(--color-brand);
  color: #fff;
  box-shadow: var(--shadow-brand);
}

.btn--primary:hover {
  background: var(--color-brand-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(var(--color-brand-rgb), 0.4);
}

.btn--primary:active {
  transform: translate3d(0, 0, 0) scale(0.97);
  box-shadow: 0 2px 10px rgba(var(--color-brand-rgb), 0.32);
  background: var(--color-brand-dark);
  transition-duration: 0.1s;
}

.btn--outline {
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255, 255, 255, 0.5);
}

.btn--outline:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: #fff;
}

.btn--outline:active {
  transform: scale(0.97);
  background: rgba(255, 255, 255, 0.18);
  transition-duration: 0.1s;
}

.btn--dark {
  background: var(--color-navy);
  color: #fff;
}

.btn--dark:hover {
  background: var(--color-navy-soft);
  transform: translateY(-2px);
}

.btn--dark:active {
  transform: translate3d(0, 0, 0) scale(0.97);
  background: var(--color-navy);
  box-shadow: none;
  transition-duration: 0.1s;
}

.btn--sm {
  padding: 8px 14px;
  font-size: 0.8125rem;
  border-radius: var(--radius-full);
  min-height: 36px;
}

.btn--sm:active {
  transform: scale(0.96);
}

.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: 0.65;
  pointer-events: none;
  transform: none;
  box-shadow: none;
}

.feature-card {
  background: var(--color-bg-white);
  border-radius: var(--radius-md);
  padding: clamp(24px, 4vw, 36px);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  transition: transform var(--transition), box-shadow var(--transition);
}

.feature-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.feature-card__icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(var(--color-brand-rgb), 0.12), rgba(var(--color-brand-rgb), 0.04));
  border-radius: var(--radius-md);
  color: var(--color-brand);
  margin-bottom: 20px;
}

.feature-card__icon svg {
  width: 28px;
  height: 28px;
}

.feature-card__title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-navy);
  margin-bottom: 10px;
}

.feature-card__text {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  line-height: 1.6;
}

.service-card {
  position: relative;
  background: var(--color-bg-white);
  border-radius: var(--radius-md);
  padding: clamp(24px, 3vw, 32px) clamp(20px, 3vw, 28px);
  text-align: center;
  align-items: center;
  border: 1px solid var(--color-border);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: rgba(var(--color-brand-rgb), 0.35);
}

.service-card__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-white);
  border-radius: var(--radius-sm);
  color: var(--color-brand);
  box-shadow: var(--shadow-sm);
}

.service-card__icon svg {
  width: 22px;
  height: 22px;
}

.service-card__title {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-navy);
  line-height: 1.35;
}

.service-card--kids {
  border-color: rgba(var(--color-brand-rgb), 0.45);
  background: linear-gradient(160deg, #fff8f0 0%, #fff 55%);
  overflow: visible;
}

.mobile-menu__cta {
  display: block;
  width: 100%;
  text-align: center;
  margin-bottom: 24px;
}

.mobile-menu {
  display: none;
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 99;
  background: var(--color-bg-white);
  padding: 24px var(--container-gutter);
  padding-bottom: calc(24px + env(safe-area-inset-bottom, 0px));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transform: translate3d(100%, 0, 0);
  transition: transform var(--transition), visibility 0s linear 0.3s;
  visibility: hidden;
  pointer-events: none;
}

.mobile-menu.is-open {
  transform: translate3d(0, 0, 0);
  visibility: visible;
  pointer-events: auto;
  transition: transform var(--transition), visibility 0s linear 0s;
}

.mobile-menu__links {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 32px;
}

.mobile-menu__link {
  display: block;
  padding: 16px 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-navy);
  border-bottom: 1px solid var(--color-border);
}

.mobile-menu__phone {
  display: block;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-brand);
  margin-bottom: 24px;
}

.mobile-menu__socials {
  display: flex;
  gap: 12px;
}

.mobile-menu__social {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: var(--color-bg-soft);
  color: var(--color-navy);
}

.mobile-menu__social svg {
  width: 22px;
  height: 22px;
}

body.menu-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
}
