pspage {
  --ps-bg: #f4f5f6;
  --ps-text: #233742;
  --ps-muted: #66737b;
  --ps-line: #dce7e8;
  --ps-teal: #2bb2a3;
  --ps-red: #e66775;
  --ps-shadow: 0 0 3rem rgb(0 0 0 / .1);
  display: flex;
  flex-direction: column;
  max-width: 1180px;
  margin: 0 auto;
  padding: 3rem 0;
  gap: 3rem;
  color: var(--ps-text);
}

pspage section,
pshero,
pscards,
psoffer,
psband,
pscta,
psdoctor,
psdocslider,
psdocstage,
psdocslide,
psdocphoto,
psdocinfo,
psdoctext,
psdocform,
psdocnav,
psdays,
pstimes,
psgallery,
psread,
psform {
  display: block;
}

pspage > topper.promo {
  align-self: stretch;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  border-radius: 1rem;
  box-shadow: var(--ps-shadow);
}

pspage > topper.promo inner {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  flex-direction: row;
  box-sizing: border-box;
  padding: 0 3rem;
  gap: 0;
}

pspage > topper.promo text {
  max-width: 100%;
  min-width: 0;
  padding: 3rem 0;
}

pspage > topper.promo overlay {
  background-size: contain;
}

pspage > topper.promo desc {
  font-size: 1rem;
  line-height: 1.45;
  font-weight: 500;
}

pspage > indocblock {
  width: 100%;
  overflow: visible;
  border-radius: 10rem 1rem 1rem 10rem;
}

pspage > indocblock inner {
  width: 100%;
  box-sizing: border-box;
  flex-direction: row;
  align-items: stretch;
  padding: 0 3rem 0 0;
  gap: 1.5rem;
}

pspage h1,
pspage h2,
pspage h3,
pspage p {
  margin: 0;
}

pspage hgroup {
  display: block;
  text-align: center;
}

pspage hgroup h2 {
  font-size: 2rem;
  line-height: 1.1;
  text-transform: uppercase;
}

pspage hgroup h2::after {
  content: "";
  display: block;
  width: 4.5rem;
  height: .25rem;
  margin: .75rem auto 0;
  background: var(--ps-teal);
}

pspage hgroup p {
  max-width: 52rem;
  margin: .75rem auto 0;
  color: var(--ps-muted);
  font-size: 1rem;
  line-height: 1.55;
}

pshero {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  padding: 0 3rem;
  overflow: hidden;
  border-radius: 1rem;
  background: #e4f1f0 url("/assets/md/promo.webp") center / cover no-repeat;
}

pscopy {
  display: block;
  position: relative;
}

pscopy h1 {
  font-size: var(--ps-title-size, 3.5rem);
  line-height: .98;
  text-transform: uppercase;
}

pscopy p {
  margin-top: 1.5rem;
  color: #2d3137;
  font-size: 1.25rem;
  line-height: 1.55;
  font-weight: 500;
}

psheroimg {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

psheroimg::before {
  content: "";
  position: absolute;
  inset: -3rem;
  background: url("/assets/md/promo_out_red.svg") center / contain no-repeat;
}

psheroimg img {
  width: 25rem;
  height: 25rem;
  object-fit: cover;
  -webkit-mask: url("/assets/md/promo.svg") 0 0 / 100% 100% no-repeat;
  mask: url("/assets/md/promo.svg") 0 0 / 100% 100% no-repeat;
}

pscards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

pscards article,
psbandcards article,
psgallery article,
psread article {
  display: block;
  padding: 1.5rem;
  border: 1px solid var(--ps-line);
  border-radius: 1rem;
  background: #fff;
  box-shadow: var(--ps-shadow);
}

.ps_hero_cards article {
  padding: 1.5rem;
}

pspage small {
  display: block;
  color: var(--ps-teal);
  font-size: .75rem;
  line-height: 1;
  font-weight: 700;
  text-transform: uppercase;
}

pscards h2,
pscards h3,
psbandcards h3,
psgallery h3 {
  margin-top: .5rem;
  font-size: 1.25rem;
  line-height: 1.2;
  text-transform: uppercase;
}

pscards p,
psbandcards p,
psgallery p,
psread p {
  margin-top: .75rem;
  color: var(--ps-muted);
  font-size: 1rem;
  line-height: 1.58;
}

num {
  display: none;
}

pscards h3,
psbandcards h3,
psgallery aside h3 {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 2.5rem;
  padding-left: 2.75rem;
}

pscards h3::after,
psbandcards h3::after,
psgallery aside h3::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

pscards h3::after,
psbandcards h3::after,
psgallery aside h3::after {
  left: 0;
  width: 1.75rem;
  height: 1.75rem;
  background: var(--ps-icon) center / contain no-repeat;
}

pscards article:nth-child(1) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 21s-7-4-7-10V5l7-3 7 3v6c0 6-7 10-7 10z'/%3E%3Cpath d='M9 12h6M12 9v6'/%3E%3C/svg%3E");
}

pscards article:nth-child(2) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='10.5' cy='10.5' r='5.5'/%3E%3Cpath d='m15 15 5 5M10.5 8v5M8 10.5h5'/%3E%3C/svg%3E");
}

pscards article:nth-child(3) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 4h8M9 4v6l-4 7a2 2 0 0 0 1.7 3h10.6A2 2 0 0 0 19 17l-4-7V4'/%3E%3Cpath d='M7 15h10'/%3E%3C/svg%3E");
}

pscards article:nth-child(4) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 3h8l3 3v15H5V6z'/%3E%3Cpath d='M15 3v4h4M8 13h8M8 17h5M9 9h3'/%3E%3C/svg%3E");
}

pscards article:nth-child(5) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 19h16M5 15l4-4 3 3 7-8'/%3E%3Cpath d='M17 6h2v2'/%3E%3C/svg%3E");
}

pscards article:nth-child(6) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 21s-7-4-7-10V5l7-3 7 3v6c0 6-7 10-7 10z'/%3E%3Cpath d='m9 12 2 2 4-5'/%3E%3C/svg%3E");
}

psbandcards article:nth-child(1),
psgallery aside article:nth-child(1) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 13h4l2-6 4 12 3-9 2 3h3'/%3E%3C/svg%3E");
}

psbandcards article:nth-child(2),
psgallery aside article:nth-child(2) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 3 22 20H2z'/%3E%3Cpath d='M12 9v5M12 17h.01'/%3E%3C/svg%3E");
}

psbandcards article:nth-child(3),
psgallery aside article:nth-child(3) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3Cpath d='M5 6v12'/%3E%3C/svg%3E");
}

psgallery aside article:nth-child(1) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 5h8a4 4 0 0 1 4 4v3a4 4 0 0 1-4 4h-3l-4 4v-4H8a4 4 0 0 1-4-4V9a4 4 0 0 1 4-4z'/%3E%3Cpath d='M8 10h8M8 13h5'/%3E%3C/svg%3E");
}

psgallery aside article:nth-child(2) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10 3h4v7l5 8a2 2 0 0 1-1.7 3H6.7A2 2 0 0 1 5 18l5-8z'/%3E%3Cpath d='M8 16h8M9 3h6'/%3E%3C/svg%3E");
}

psgallery aside article:nth-child(3) {
  --ps-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%232bb2a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 4h8v4H8zM6 8h12v12H6z'/%3E%3Cpath d='M12 11v6M9 14h6'/%3E%3C/svg%3E");
}

psoffer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  padding: 1.5rem;
  border-radius: 1rem;
  background: #fff;
  box-shadow: var(--ps-shadow);
}

psoffer h2 {
  font-size: 1rem;
  line-height: 1.15;
  text-transform: uppercase;
}

oldprice {
  display: inline-flex;
  align-items: center;
  color: #a8b0b5;
  font-size: 1rem;
  line-height: 1;
  white-space: nowrap;
  text-decoration: line-through;
}

newprice {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  min-width: 9.25rem;
  min-height: 2.9rem;
  padding: .5rem .95rem;
  border-radius: 1rem;
  background: var(--ps-red);
  color: #fff;
  font-size: 1.45rem;
  line-height: 1;
  white-space: nowrap;
  font-weight: 800;
}

psoffer small {
  max-width: 28rem;
  color: #7a858b;
  font-weight: 500;
  text-transform: none;
}

psband {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1.35fr;
  gap: 1.25rem;
  min-height: 22rem;
  overflow: hidden;
  border: 1px solid var(--ps-line);
  border-radius: 1rem;
  background: #fff;
  box-shadow: var(--ps-shadow);
}

psband > img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .36;
}

psbandtext {
  display: block;
  position: relative;
  align-self: center;
  padding: 2.25rem;
}

psbandtext h2 {
  max-width: 24rem;
  font-size: 2rem;
  line-height: 1.1;
  text-transform: uppercase;
}

psbandtext p {
  max-width: 26rem;
  margin-top: 1rem;
  color: var(--ps-muted);
  font-size: 1rem;
  line-height: 1.58;
}

psbandcards {
  display: grid;
  position: relative;
  align-self: center;
  gap: 1rem;
  padding: 2.25rem 2.25rem 2.25rem 0;
}

psbandcards article {
  background: rgb(255 255 255 / .9);
}

pscta {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  align-items: center;
  gap: 2rem;
  padding: 2.25rem;
  border-radius: 1rem;
  background: var(--ps-red);
  color: #fff;
  box-shadow: var(--ps-shadow);
}

pscta > aside:last-child {
  display: grid;
  justify-items: end;
  align-content: center;
  text-align: right;
}

pscta small,
psdoctor small {
  color: inherit;
}

pscta h2 {
  margin-top: .75rem;
  font-size: 1.5rem;
  line-height: 1.15;
  text-transform: uppercase;
}

pscta p {
  margin-top: 1rem;
  font-size: 1rem;
  line-height: 1.55;
}

pscta a,
psdoctor a,
psform button {
  display: inline-grid;
  min-height: 3rem;
  place-items: center;
  padding: 0 1.75rem;
  border: 0;
  background: #fff;
  color: var(--ps-red);
  font-weight: 800;
  text-decoration: none;
  text-transform: uppercase;
  cursor: pointer;
}

phone {
  display: block;
  margin-top: 1.25rem;
  font-size: 1rem;
}

phone b {
  display: block;
  margin-top: .25rem;
  font-size: 1.25rem;
  text-decoration: underline;
}

psdoctor {
  display: grid;
  grid-template-columns: 15rem 1fr;
  gap: 2rem;
  align-items: center;
  padding: 2rem;
  border-radius: 1rem;
  background: var(--ps-teal);
  color: #fff;
  box-shadow: var(--ps-shadow);
}

psdoctor > img {
  width: 15rem;
  height: 15rem;
  object-fit: cover;
  border-radius: 1rem;
  background: #d8f1ed;
}

psdoctor article {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 1rem;
}

psdoctor h2 {
  margin-top: 1rem;
  font-size: 1.5rem;
  line-height: 1.15;
  text-transform: uppercase;
}

spec {
  display: inline-block;
  margin-top: .75rem;
  padding: .5rem .75rem;
  border: 1px solid rgb(255 255 255 / .45);
  border-radius: 1rem;
}

psdoctor p {
  margin-top: 1rem;
}

psdoctor span {
  margin-left: 1rem;
}

psdoctor a {
  background: #fff;
  color: var(--ps-teal);
}

psdocslider {
  --ps-doc-nav: 50%;
  position: relative;
  padding: 1.5rem 0;
}

psdocstage {
  display: grid;
}

psdocslide {
  grid-area: 1 / 1;
  display: grid;
  grid-template-columns: 20% 30% 50%;
  align-items: stretch;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s ease, visibility .2s ease;
}

psdocslide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

psdocphoto {
  height: 100%;
  min-height: 18rem;
  box-sizing: border-box;
  border: .125rem dotted var(--ps-teal);
  border-right: 0;
  border-radius: 1rem 0 0 1rem;
  background-color: #fff;
  background-position: top center;
  background-size: 100% auto;
  background-repeat: no-repeat;
}

psdocinfo {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  min-height: 18rem;
  box-sizing: border-box;
  padding: 1.5rem 2rem;
  background: var(--ps-teal);
  color: #fff;
}

psdoctext {
  display: grid;
  gap: .75rem;
  width: 100%;
  min-width: 0;
}

psdoctext h2 {
  font-size: 1.5rem;
  line-height: 1.1;
}

psdoctext p {
  color: inherit;
  font-size: 1rem;
  line-height: 1.25;
}

psdoctext p span {
  font-weight: 600;
}

psdoctext .specline {
  display: flex;
  align-items: center;
  gap: .5rem;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  padding: .5rem .75rem;
  background: #fff;
  color: var(--ps-teal);
}

psdoctext .specline spmain {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

psdoctext .specline spdrop {
  margin-left: auto;
}

psdoctext .specline spdropbtn {
  display: block;
  border: 1px solid rgb(43 178 163 / .35);
  padding: .25rem .5rem;
  color: var(--ps-teal);
  font-size: .875rem;
  line-height: 1;
}

psdoctext .specline spdroppanel {
  display: none;
}

psdocform {
  height: 100%;
  min-height: 18rem;
  box-sizing: border-box;
  padding: 1.5rem 2rem 1.5rem 3rem;
  border: .125rem dotted var(--ps-teal);
  border-left: .125rem dotted var(--ps-teal);
  border-radius: 0 1rem 1rem 0;
  background: #fff;
  display: flex;
  align-items: center;
}

psdocform h2 {
  color: var(--ps-teal);
  font-size: 1.1rem;
  line-height: 1.2;
  font-weight: 600;
  text-align: center;
}

psdocform form {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
}

psdocform fieldset {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 0;
  padding: 0;
  border: 0;
}

psdocform input {
  box-sizing: border-box;
  width: 100%;
  min-height: 2.5rem;
  border: 1px solid rgb(43 178 163 / .55);
  border-radius: 0;
  padding: 0 .75rem;
  color: var(--ps-text);
  font: inherit;
  text-align: left;
}

psdocform .psdocappo {
  display: grid;
  width: 100%;
  gap: 1rem;
  align-content: center;
}

psdocform .psdocappo[hidden],
psdocform .psdocappo appobody [hidden],
psdocform .psdocappo appobody[hidden],
psdocform .psdocappo selects[hidden],
psdocform .psdocappo appoempty[hidden],
psdocform .psdocappo appoloading[hidden],
psdocform .psdocappo appoform[hidden],
psdocform .psdocappo appocontrols[hidden],
psdocform .psdocappo appocaptcha[hidden],
psdocform .psdocappo appostatus[hidden] {
  display: none !important;
}

psdocform .psdocappo appobody {
  display: grid;
  row-gap: 1rem;
}

psdocform .psdocappo appoline {
  display: none;
}

psdocform .psdocappo selects {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .5rem;
}

psdocform .psdocappo selects select {
  box-sizing: border-box;
  width: 100%;
  min-height: 2.25rem;
  border: 1px solid rgb(43 178 163 / .55);
  border-radius: 0;
  padding: 0 2rem 0 .75rem;
  color: var(--ps-text);
  background: #fff;
  font: inherit;
  text-align: left;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4.25 6.25 8 10l3.75-3.75' fill='none' stroke='%23405661' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: .95rem .95rem;
  background-position: right .65rem center;
}

psdocform .psdocappo selects select[data-single-option="1"],
psdocform .psdocappo selects select:disabled[data-single-option="1"] {
  padding-right: .75rem;
  background-image: none;
  cursor: default;
}

psdocform .psdocappo appoempty,
psdocform .psdocappo appoloading {
  margin: 0;
  color: var(--ps-muted);
  font-size: .875rem;
  line-height: 1.35;
}

psdocform .psdocappo appoform {
  display: grid;
  row-gap: 1rem;
  align-content: center;
}

psdocform .psdocappo appoform > form {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: .5rem;
  row-gap: 1rem;
}

psdocform .psdocappo appocontrols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: .5rem;
  row-gap: 1rem;
  align-items: stretch;
}

psdocform .psdocappo appocaptcha {
  min-width: 0;
  display: grid;
  grid-column: 1 / span 2;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
  gap: .5rem;
}

psdocform .psdocappo appocaptcha img[data-validator] {
  width: 100%;
  max-width: 100%;
  height: 2.5rem;
  object-fit: cover;
  justify-self: start;
  border: 1px solid rgb(43 178 163 / .35);
  background: #fff;
}

psdocform .psdocappo appocaptcha input {
  box-sizing: border-box;
  width: 100%;
  min-height: 2.5rem;
  border: 1px solid rgb(43 178 163 / .55);
  padding: 0 .75rem;
  text-align: left;
}

psdocform .psdocappo appocaptcha span {
  grid-column: 1 / -1;
  color: var(--ps-muted);
  font-size: .875rem;
  line-height: 1.3;
}

psdocform .psdocappo button[data-infoclinica-send],
psdocform .psdocappo form[data-infoclinica-code-form] button {
  min-height: 2.5rem;
  border: 0;
  border-radius: 0;
  padding: 0 1rem;
  background: var(--ps-red);
  color: #fff;
  font: inherit;
  font-size: .82rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .01em;
  cursor: pointer;
}

psdocform .psdocappo button[data-infoclinica-send] {
  grid-column: 3;
  width: 100%;
}

psdocform .psdocappo appocaptcha button.captcha-reset {
  display: none !important;
}

psdocform .psdocappo button[data-infoclinica-send]:disabled {
  opacity: .5;
  cursor: default;
}

psdocform .psdocappo form[data-infoclinica-code-form] {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .5rem;
}

psdocform .psdocappo form[data-infoclinica-code-form][hidden] {
  display: none !important;
}

psdocform .psdocappo appostatus {
  color: var(--ps-muted);
  font-size: .8125rem;
  line-height: 1.35;
}

psdocform .psdocappo appostatus:empty {
  display: none;
}

psdocform .psdocappo appostatus.error {
  color: #c94a5a;
}

psdocform .psdocappo appostatus.success {
  color: #1b8b67;
}

psdays,
pstimes {
  display: flex;
  flex-wrap: wrap;
  gap: .375rem;
  justify-content: flex-start;
}

psdays button,
pstimes button {
  min-height: 1.75rem;
  border: 1px solid rgb(43 178 163 / .55);
  border-radius: 0;
  background: #fff;
  color: var(--ps-teal);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
}

psdays button {
  min-width: 1.75rem;
  padding: 0 .5rem;
}

psdays button:not(.is-active) {
  border-color: #d8d8d8;
  background: #e2e2e2;
  color: #aaa;
}

pstimes button {
  min-width: 3.75rem;
  padding: 0 .5rem;
}

.psdocsubmit {
  justify-self: start;
  min-width: 12rem;
  min-height: 2.5rem;
  border: 0;
  border-radius: 0;
  background: var(--ps-red);
  color: #fff;
  font: inherit;
  font-weight: 800;
  text-transform: uppercase;
  cursor: pointer;
}

psprivacy {
  position: relative;
  justify-self: start;
  max-width: 28rem;
  margin: 0;
  color: var(--ps-muted);
  font-size: .625rem;
  line-height: 1.35;
  text-align: left;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: .125rem;
  text-transform: none;
  cursor: help;
}

psprivacy span {
  position: absolute;
  left: 50%;
  bottom: calc(100% + .5rem);
  width: min(24rem, 80vw);
  box-sizing: border-box;
  padding: .75rem 1rem;
  border: 1px solid var(--ps-line);
  border-radius: 1rem;
  background: #fff;
  color: var(--ps-muted);
  font-size: .8125rem;
  line-height: 1.45;
  box-shadow: var(--ps-shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(.25rem);
  transition: opacity .15s ease, transform .15s ease, visibility .15s ease;
  pointer-events: none;
}

psprivacy:hover span,
psprivacy:focus span {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

psdocnav {
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--ps-doc-nav);
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 4.5rem;
  transform: translateX(-50%);
  pointer-events: none;
}

psdocnav i {
  flex: 1;
  width: .125rem;
  background: repeating-linear-gradient(to bottom, var(--ps-teal) 0 .125rem, transparent .125rem .25rem);
}

psdocnav button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.75rem;
  height: 3.75rem;
  border: .125rem solid var(--ps-teal);
  border-radius: 50%;
  background: #fff;
  color: var(--ps-teal);
  cursor: pointer;
  pointer-events: auto;
}

psdocnav svg {
  display: block;
  width: 1.75rem;
  height: 1.75rem;
}

psdocnav path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

psgallery {
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  align-items: stretch;
  gap: 1.25rem;
}

psslider {
  display: block;
  position: relative;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  border-radius: 1rem;
  background: #dce7e8;
}

psslides {
  position: absolute;
  inset: 0;
  display: flex;
  height: 100%;
  transition: transform .35s ease;
}

psslides img {
  display: block;
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 1rem;
}

psread > img {
  display: block;
  width: 100%;
  min-height: 28rem;
  object-fit: cover;
  border-radius: 1rem;
}

psarrows {
  position: absolute;
  inset: 50% 1rem auto;
  display: flex;
  justify-content: space-between;
  pointer-events: none;
  transform: translateY(-50%);
}

psarrows button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.25rem;
  height: 3.25rem;
  border: 0;
  border-radius: 50%;
  background: rgb(255 255 255 / .9);
  color: var(--ps-teal);
  cursor: pointer;
  pointer-events: auto;
  box-shadow: var(--ps-shadow);
}

psarrows svg {
  display: block;
  width: 1.75rem;
  height: 1.75rem;
}

psarrows path {
  fill: none;
  stroke: currentColor;
  stroke-width: 2.25;
  stroke-linecap: round;
  stroke-linejoin: round;
}

psgallery aside {
  display: grid;
  align-content: stretch;
  gap: 1rem;
}

psread {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

psread article {
  padding: 3rem;
}

psread article h2 {
  margin-bottom: 1rem;
  font-size: 2rem;
  line-height: 1.1;
  text-transform: uppercase;
}

psform {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 0;
  overflow: hidden;
  border-radius: 1rem;
  background: linear-gradient(90deg, rgb(255 255 255 / 0) 0%, rgb(43 178 163 / .82) 55%), url("/ban/checkup/00547-1162692656.webp") left center / cover no-repeat;
  box-shadow: var(--ps-shadow);
}

psform aside {
  display: block;
  min-height: 23rem;
}

psform form {
  display: grid;
  gap: 1rem;
  padding: 2.25rem;
}

psform h2 {
  color: #fff;
  font-size: 2rem;
  line-height: 1.1;
  text-transform: uppercase;
}

psform input {
  width: 100%;
  box-sizing: border-box;
  min-height: 2.75rem;
  border: 0;
  padding: 0 1rem;
  background: #fff;
  color: var(--ps-text);
  font: inherit;
}

psform fieldset {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  margin: 0;
  padding: 0;
  border: 0;
}

psform small {
  padding: .75rem;
  background: rgb(255 255 255 / .22);
  color: rgb(255 255 255 / .86);
  font-size: .75rem;
  line-height: 1.35;
  text-transform: none;
}

psform button {
  width: 12rem;
  border-radius: 1rem;
  background: var(--ps-teal);
  color: #fff;
}

@media (max-width: 980px) {
  pspage {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 1.25rem 1rem 2rem;
  }

  pspage > topper.promo inner {
    padding: 0;
    min-width: 0;
  }

  pspage > topper.promo text {
    box-sizing: border-box;
    min-width: 0;
    max-width: 100%;
    padding: 2rem;
    gap: 2rem;
  }

  pspage > topper.promo text h1 {
    font-size: clamp(1.5rem, 7vw, var(--ps-title-size-mob, 2.5rem)) !important;
  }

  pspage > topper.promo desc {
    max-height: 8.75rem;
    overflow: hidden;
  }

  pspage > topper.promo mobpagesimg {
    height: 15rem;
  }

  pshero,
  psband,
  pscta,
  psdoctor,
  psgallery,
  psread,
  psform {
    grid-template-columns: 1fr;
  }

  pscopy h1 {
    font-size: var(--ps-title-size-mob, 2.5rem);
  }

  pshero {
    padding: 2rem 1.25rem 0;
  }

  psheroimg,
  psheroimg img {
    position: relative;
    inset: auto;
    width: 100%;
    height: 17rem;
    min-height: 0;
  }

  psheroimg::before {
    inset: 0;
    width: 100%;
  }

  pscards {
    grid-template-columns: 1fr;
  }

  psoffer {
    display: grid;
    justify-items: start;
  }

  psbandcards {
    padding: 0 1.25rem 1.25rem;
  }

  psband,
  psbandtext,
  psbandcards,
  psbandcards article,
  psread,
  psread article,
  psread > img {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  psread article {
    padding: 1.5rem;
  }

  psread article h2 {
    font-size: clamp(1.9rem, 8vw, 2.4rem);
    line-height: 1.08;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  psdoctor article {
    grid-template-columns: 1fr;
  }

  psdocslider {
    display: grid;
    gap: .875rem;
    padding: 0;
  }

  psdocslide {
    grid-template-columns: 1fr;
    grid-template-rows: 16rem auto auto;
    min-height: 0;
    border-radius: 1rem;
    overflow: hidden;
  }

  psdocphoto {
    min-height: 16rem;
    height: 16rem;
    border-right: .125rem dotted var(--ps-teal);
    border-bottom: 0;
    border-radius: 1rem 1rem 0 0;
    background-size: auto 108%;
    background-position: center top;
  }

  psdocinfo {
    justify-items: center;
    padding: 1.25rem 1.25rem 1rem;
    text-align: center;
    min-height: var(--ps-docinfo-mobile-h, 0);
    height: var(--ps-docinfo-mobile-h, auto);
    margin-top: 0;
    overflow: hidden;
  }

  psdoctext {
    justify-items: center;
    align-content: center;
    height: 100%;
  }

  psdoctext h2 {
    max-width: 20rem;
    font-size: 1.5rem;
  }

  psdocform {
    padding: 1.25rem;
    border: .125rem dotted var(--ps-teal);
    border-top: 0;
    border-radius: 0 0 1rem 1rem;
  }

  psdocform h2 {
    font-size: 1.05rem;
    line-height: 1.15;
    white-space: nowrap;
    text-align: center;
  }

  psdocform fieldset {
    grid-template-columns: 1fr;
  }

  psdocform .psdocappo appobody {
    row-gap: .75rem;
  }

  psdocform .psdocappo selects,
  psdocform .psdocappo appoform > form,
  psdocform .psdocappo form[data-infoclinica-code-form] {
    grid-template-columns: 1fr;
  }

  psdocform .psdocappo appocontrols {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  psdocform .psdocappo appocaptcha {
    grid-column: 1 / -1;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  psdocform .psdocappo appocaptcha input,
  psdocform .psdocappo appocaptcha img[data-validator] { grid-column: auto; }

  psdocform .psdocappo button[data-infoclinica-send] {
    grid-column: 1 / -1;
    width: 100%;
  }

  psdocform .psdocappo psprivacy {
    justify-self: center;
    text-align: center;
  }

  psdocnav {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(16rem - 1.625rem);
    bottom: auto;
    transform: none;
    pointer-events: none;
    margin: 0;
    width: 100%;
    height: 3.25rem;
  }

  psdocnav i {
    display: none;
  }

  psdocnav button {
    width: 3.25rem;
    height: 3.25rem;
    position: absolute;
    top: 0;
    pointer-events: auto;
    border-width: .125rem;
    background: #fff;
    border-radius: 50%;
    padding: 0;
  }

  psdocnav button[data-ps-docprev] {
    left: 0;
    justify-content: center;
  }

  psdocnav button[data-ps-docnext] {
    right: 0;
    justify-content: center;
  }

  pspage > indocblock {
    margin-top: 5rem;
    overflow: visible;
    border-radius: 1rem;
  }

  pspage > indocblock inner {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 0 1.5rem 1.5rem;
    gap: 1rem;
  }

  pspage > indocblock docimg {
    position: relative;
    top: auto;
    bottom: auto;
    width: min(75%, 22rem);
    aspect-ratio: 1;
    height: auto;
    margin: -5rem auto 0;
    flex: none;
    border-radius: 50%;
    background-size: contain;
  }

  pspage > indocblock item {
    width: 100%;
    max-width: 24rem;
    padding: 0 !important;
    align-items: center;
    text-align: center;
  }

  pspage > indocblock item:nth-of-type(1) {
    padding-left: 0 !important;
  }

  pspage > indocblock item.indoc p:nth-of-type(1) {
    max-width: 18rem;
    font-size: 1.5rem;
    line-height: 1.1;
  }

  pspage > indocblock item.indoc p.specline {
    justify-content: center;
  }

  pspage > indocblock item call,
  pspage > indocblock item call a {
    width: 100%;
  }

  pspage > indocblock a.callus {
    display: grid;
    justify-items: center;
    gap: .5rem;
    text-align: center;
  }

  psdoctor span {
    display: block;
    margin: .5rem 0 0;
  }

  psgallery figure img,
  psread > img {
    min-height: 18rem;
  }

  psform aside {
    display: none;
  }

  psform fieldset {
    grid-template-columns: 1fr;
  }

  psslider {
    height: 18rem;
    min-height: 18rem;
  }
}


.ps_hero_cards--price article p {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: .9rem;
  padding: .45rem .95rem;
  border-radius: .85rem;
  background: var(--ps-red);
  color: #fff;
  font-size: 1.15rem;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: .01em;
}

.ps_hero_cards--price article h2 {
  margin-top: .55rem;
}


.ps_hero_cards--price article oldprice {
  margin-top: .7rem;
  margin-bottom: .35rem;
}


.ps_hero_cards--price article {
  display: flex;
  flex-direction: column;
}

.ps_hero_cards--price article pricewrap {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin-top: .9rem;
}

.ps_hero_cards--price article oldprice {
  margin: 0;
}

.ps_hero_cards--price article p {
  margin-top: 0;
}
