.post-type-archive-yyh_benefit {
  background:
    radial-gradient(circle at 14% 8%, rgba(37, 99, 235, .14), transparent 310px),
    radial-gradient(circle at 92% 18%, rgba(255, 47, 85, .11), transparent 330px),
    linear-gradient(180deg, #f7fbff 0, #f2f6fb 42%, #ffffff 100%);
}

.post-type-archive-yyh_benefit .float-service {
  display: none;
}

.yyh-benefits-hero {
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(238, 247, 255, .88)),
    radial-gradient(circle at 80% 25%, rgba(255, 47, 85, .18), transparent 300px),
    radial-gradient(circle at 55% 10%, rgba(20, 167, 181, .14), transparent 280px);
}

.yyh-benefits-hero-grid {
  min-height: 190px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(330px, 390px);
  gap: 28px;
  align-items: center;
  padding: 20px 0 20px;
}

.yyh-benefits-hero h1 {
  margin: 10px 0 8px;
  color: #071d33;
  font-size: 42px;
  line-height: 1.08;
}

.yyh-benefits-hero p {
  max-width: 680px;
  margin: 0;
  color: #53687c;
  font-size: 16px;
}

.yyh-benefits-focus {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.yyh-benefits-focus span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  background: rgba(255, 255, 255, .78);
  color: #0b4c8c;
  padding: 0 13px;
  font-size: 14px;
  font-weight: 900;
}

.yyh-benefits-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}

.yyh-benefits-board {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 126px;
  gap: 10px;
  padding: 12px;
  border: 1px solid #ffd2db;
  border-radius: 8px;
  background: rgba(255, 255, 255, .9);
  box-shadow: 0 26px 70px rgba(13, 59, 102, .14);
}

.yyh-benefits-ticket {
  position: relative;
  overflow: hidden;
  min-height: 126px;
  display: grid;
  align-content: end;
  gap: 12px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .16), transparent 40%),
    linear-gradient(135deg, #ff4d5f 0%, #ff2f55 58%, #d91f43 100%);
  color: #fff;
  padding: 18px 20px;
}

.yyh-benefits-ticket:before,
.yyh-benefits-ticket:after {
  content: "";
  position: absolute;
  top: 50%;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .92);
  transform: translateY(-50%);
}

.yyh-benefits-ticket:before {
  left: -17px;
}

.yyh-benefits-ticket:after {
  right: -17px;
}

.yyh-benefits-ticket span {
  position: relative;
  z-index: 1;
  color: rgba(255, 255, 255, .78);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
}

.yyh-benefits-ticket strong {
  position: relative;
  z-index: 1;
  font-size: 28px;
  line-height: 1.1;
}

.yyh-benefits-ticket p {
  position: relative;
  z-index: 1;
  color: rgba(255, 255, 255, .86);
  font-size: 14px;
  line-height: 1.6;
}

.yyh-benefits-summary {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.yyh-benefits-summary div {
  min-height: 58px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 4px;
  border-radius: 8px;
  background: #f7fbff;
}

.yyh-benefits-summary b {
  color: #1f6feb;
  font-size: 28px;
  line-height: 1;
}

.yyh-benefits-summary span {
  color: #53687c;
  font-size: 13px;
  font-weight: 900;
}

.yyh-benefits-board-actions {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.yyh-benefits-board-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 1px solid #dbeafe;
  border-radius: 8px;
  background: #fff;
  color: #0b4c8c;
  font-weight: 900;
}

.yyh-benefits-board-actions a:first-child {
  background: #1f6feb;
  border-color: #1f6feb;
  color: #fff;
}

.yyh-benefits-section {
  padding-top: 18px;
  background: transparent;
}

.yyh-benefits-layout {
  display: block;
}

.yyh-benefits-guide {
  display: none;
  position: static;
  gap: 12px;
  padding: 16px;
  border: 1px solid #dbeafe;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 38px rgba(13, 59, 102, .08);
}

.yyh-benefits-guide > strong {
  color: #071d33;
  font-size: 18px;
  line-height: 1.25;
}

.yyh-benefits-guide ol {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.yyh-benefits-guide li {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 10px;
  color: #53687c;
}

.yyh-benefits-guide li:before {
  content: counter(list-item);
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #e8f2ff;
  color: #1f6feb;
  font-weight: 900;
}

.yyh-benefits-guide b {
  display: block;
  color: #071d33;
}

.yyh-benefits-guide span {
  display: block;
  margin-top: 2px;
  font-size: 13px;
  line-height: 1.55;
}

.yyh-benefits-content {
  min-width: 0;
}

.yyh-benefit-claim-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  gap: 10px;
  align-items: stretch;
  margin-bottom: 10px;
}

.yyh-benefit-claim-row div,
.yyh-benefit-claim-row a {
  min-height: 66px;
  border: 1px solid #dbeafe;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 32px rgba(13, 59, 102, .07);
}

.yyh-benefit-claim-row div {
  display: grid;
  gap: 3px;
  padding: 12px 14px;
}

.yyh-benefit-claim-row span {
  color: #1f6feb;
  font-size: 12px;
  font-weight: 900;
}

.yyh-benefit-claim-row strong {
  color: #071d33;
  font-size: 16px;
  line-height: 1.35;
}

.yyh-benefit-claim-row a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 136px;
  background: #ff5a14;
  border-color: #ff5a14;
  color: #fff;
  padding: 0 16px;
  font-weight: 900;
}

.yyh-benefits-picks {
  display: none;
  grid-template-columns: minmax(190px, .34fr) minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  margin-bottom: 10px;
  border: 1px solid #dbeafe;
  border-radius: 8px;
  background: #fff;
  padding: 14px;
  box-shadow: 0 18px 42px rgba(13, 59, 102, .08);
}

.yyh-benefits-picks strong {
  display: block;
  color: #071d33;
  font-size: 18px;
}

.yyh-benefits-picks span {
  display: block;
  margin-top: 3px;
  color: #53687c;
  font-size: 14px;
}

.yyh-benefits-picks nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.yyh-benefits-picks a {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  background: #f7fbff;
  color: #0b4c8c;
  padding: 0 14px;
  font-weight: 900;
}

.post-type-archive-yyh_benefit .archive-filter {
  grid-template-columns: 1.1fr repeat(3, minmax(150px, 1fr)) auto;
  border-radius: 8px;
  margin-bottom: 10px;
  padding: 12px;
  box-shadow: 0 18px 42px rgba(13, 59, 102, .08);
}

.post-type-archive-yyh_benefit .archive-count {
  margin: 0 0 10px;
  color: #53687c;
  font-weight: 800;
}

.post-type-archive-yyh_benefit .archive-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.yyh-benefit-archive-card {
  min-height: 210px;
  border-color: #dbeafe;
  border-radius: 8px;
  box-shadow: 0 16px 34px rgba(13, 59, 102, .08);
}

.yyh-benefit-archive-card div {
  position: relative;
  min-height: 96px;
  display: grid;
  align-content: center;
  padding: 18px 16px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .16), transparent 42%),
    linear-gradient(135deg, #08233f, #0b5fc7);
}

.yyh-benefit-archive-card div:after {
  content: "";
  position: absolute;
  right: -28px;
  bottom: -34px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  border: 18px solid rgba(255, 255, 255, .14);
}

.post-type-archive-yyh_benefit .yyh-benefits-hero {
  background:
    linear-gradient(90deg, rgba(8, 35, 63, .88), rgba(11, 95, 199, .78)),
    radial-gradient(circle at 82% 28%, rgba(255, 255, 255, .18), transparent 300px);
}

.post-type-archive-yyh_benefit .yyh-benefits-hero h1,
.post-type-archive-yyh_benefit .yyh-benefits-hero p {
  color: #fff;
}

.post-type-archive-yyh_benefit .yyh-benefits-focus span {
  border-color: rgba(255, 255, 255, .24);
  background: rgba(255, 255, 255, .12);
  color: #fff;
}

.post-type-archive-yyh_benefit .yyh-benefits-ticket {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .12), transparent 45%),
    linear-gradient(135deg, #08233f, #0b5fc7);
}

.post-type-archive-yyh_benefit .yyh-benefits-board {
  border-color: rgba(255, 255, 255, .28);
}

.post-type-archive-yyh_benefit .yyh-benefits-hero-actions .btn.secondary,
.post-type-archive-yyh_benefit .yyh-benefits-board-actions a {
  border-color: rgba(255, 255, 255, .32);
}

.yyh-benefit-archive-card span {
  position: relative;
  z-index: 1;
  width: 36px;
  height: 36px;
  margin-bottom: 10px;
}

.yyh-benefit-archive-card strong {
  position: relative;
  z-index: 1;
  font-size: 18px;
  line-height: 1.25;
}

.yyh-benefit-archive-card p {
  min-height: 42px;
  padding: 0 16px;
  color: #4b5f74;
}

.yyh-benefit-archive-card em {
  justify-self: start;
  margin: 0 16px 16px;
}

@media (max-width: 1120px) {
  .yyh-benefits-hero-grid,
  .yyh-benefits-layout {
    grid-template-columns: 1fr;
  }

  .yyh-benefits-guide {
    position: static;
  }

  .post-type-archive-yyh_benefit .archive-filter {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .post-type-archive-yyh_benefit .filter-actions {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .yyh-benefits-hero-grid {
    min-height: auto;
    padding: 22px 0;
    gap: 16px;
  }

  .yyh-benefits-hero h1 {
    font-size: 34px;
  }

  .yyh-benefits-board {
    grid-template-columns: 1fr;
    padding: 10px;
  }

  .yyh-benefits-ticket {
    min-height: 92px;
    padding: 14px 16px;
  }

  .yyh-benefits-ticket strong {
    font-size: 24px;
  }

  .yyh-benefits-ticket p {
    font-size: 13px;
    line-height: 1.5;
  }

  .yyh-benefits-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .yyh-benefits-summary div {
    min-height: 62px;
  }

  .yyh-benefits-summary b {
    font-size: 24px;
  }

  .yyh-benefits-board-actions a {
    min-height: 42px;
  }

  .post-type-archive-yyh_benefit .archive-grid,
  .yyh-benefits-picks,
  .yyh-benefit-claim-row {
    grid-template-columns: 1fr;
  }

  .post-type-archive-yyh_benefit .archive-filter {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .post-type-archive-yyh_benefit .filter-actions {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .yyh-benefits-picks nav {
    justify-content: flex-start;
  }
}

.post-type-archive-yyh_benefit {
  background:
    radial-gradient(circle at 12% 6%, rgba(11, 93, 204, .08), transparent 280px),
    linear-gradient(180deg, #f7f5fb 0, #f5f3fa 52%, #ffffff 100%);
}

.post-type-archive-yyh_benefit .yyh-benefits-hero {
  border-bottom: 0;
  padding: 46px 0 30px;
  background: transparent;
}

.post-type-archive-yyh_benefit .yyh-benefits-hero-grid {
  min-height: 350px;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .58fr);
  gap: 28px;
  border-radius: 12px;
  overflow: hidden;
  padding: 62px;
  background:
    linear-gradient(90deg, rgba(6, 31, 58, .96), rgba(10, 66, 126, .88)),
    radial-gradient(circle at 82% 20%, rgba(88, 166, 255, .3), transparent 320px);
  box-shadow: 0 28px 70px rgba(6, 31, 58, .18);
}

.post-type-archive-yyh_benefit .yyh-benefits-hero-grid:after {
  content: "";
  align-self: stretch;
  border-radius: 10px;
  background:
    radial-gradient(circle at 50% 45%, rgba(255, 255, 255, .18), transparent 92px),
    linear-gradient(135deg, rgba(255, 255, 255, .16), rgba(255, 255, 255, .04));
  border: 1px solid rgba(255, 255, 255, .16);
}

.post-type-archive-yyh_benefit .yyh-benefits-hero-grid > .yyh-benefits-board {
  display: none;
}

.post-type-archive-yyh_benefit .eyebrow {
  border-color: rgba(255, 255, 255, .28);
  background: #e3a824;
  color: #fff;
}

.post-type-archive-yyh_benefit .yyh-benefits-hero h1 {
  margin-top: 18px;
  font-size: 42px;
  color: #fff;
}

.post-type-archive-yyh_benefit .yyh-benefits-hero p {
  max-width: 620px;
  color: rgba(255, 255, 255, .9);
  font-size: 17px;
  line-height: 1.75;
}

.post-type-archive-yyh_benefit .yyh-benefits-focus span {
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .24);
  color: #fff;
}

.post-type-archive-yyh_benefit .yyh-benefits-hero-actions .btn.primary {
  background: #fff;
  color: #0b5dcc;
  box-shadow: none;
}

.post-type-archive-yyh_benefit .yyh-benefits-hero-actions .btn.secondary {
  background: rgba(255, 255, 255, .14);
  border-color: rgba(255, 255, 255, .28);
  color: #fff;
}

.post-type-archive-yyh_benefit .yyh-benefits-section {
  padding-top: 22px;
}

.post-type-archive-yyh_benefit .archive-filter {
  grid-template-columns: minmax(0, 1.1fr) repeat(3, minmax(150px, 1fr)) auto;
  border: 1px solid #e6e1f0;
  border-radius: 12px;
  padding: 22px 28px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(7, 29, 51, .05);
}

.yyh-benefit-claim-row {
  display: none;
}

.post-type-archive-yyh_benefit .archive-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px 34px;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card,
.post-type-archive-yyh_benefit .yyh-benefit-archive-card {
  position: relative;
  min-height: 310px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 0;
  overflow: visible;
  border: 1px solid #e2e7f0 !important;
  border-radius: 12px;
  background: #fff !important;
  box-shadow: 0 18px 38px rgba(7, 29, 51, .08);
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card:before,
.post-type-archive-yyh_benefit .yyh-clinic-benefit-card:after {
  content: "";
  position: absolute;
  left: 50%;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #f5f3fa;
  transform: translateX(-50%);
  z-index: 2;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card:before {
  top: -9px;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card:after {
  bottom: -9px;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card div {
  min-height: 128px;
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 30px 28px 16px;
  background: #fff !important;
  color: #071d33;
  text-align: left;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card div:after {
  display: none;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card span {
  display: block;
  width: auto;
  height: auto;
  margin: 0;
  border-radius: 0;
  background: transparent;
  color: #0b5dcc !important;
  font-size: 34px;
  line-height: 1;
  text-align: left;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card strong {
  color: #071d33 !important;
  font-size: 20px;
  line-height: 1.45;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card p {
  min-height: 74px;
  margin: 0 28px;
  padding: 18px 0;
  border-top: 1px dashed #d6e1ef;
  border-bottom: 1px dashed #d6e1ef;
  color: #405770;
  font-size: 14px;
  line-height: 1.8;
  -webkit-line-clamp: 3;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card em {
  justify-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  margin: 18px 28px 28px;
  border-radius: 8px;
  background: #0b5dcc;
  color: #fff;
  font-size: 15px;
}

.post-type-archive-yyh_benefit .yyh-clinic-benefit-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 26px 56px rgba(7, 29, 51, .14);
}

@media (max-width: 1120px) {
  .post-type-archive-yyh_benefit .yyh-benefits-hero-grid {
    grid-template-columns: 1fr;
    padding: 40px;
  }

  .post-type-archive-yyh_benefit .yyh-benefits-hero-grid:after {
    min-height: 150px;
  }

  .post-type-archive-yyh_benefit .archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .post-type-archive-yyh_benefit .yyh-benefits-hero {
    padding: 20px 0 14px;
  }

  .post-type-archive-yyh_benefit .yyh-benefits-hero-grid {
    padding: 24px;
    border-radius: 10px;
  }

  .post-type-archive-yyh_benefit .yyh-benefits-hero-grid:after {
    display: none;
  }

  .post-type-archive-yyh_benefit .yyh-benefits-hero h1 {
    font-size: 30px;
  }

  .post-type-archive-yyh_benefit .archive-filter,
  .post-type-archive-yyh_benefit .archive-grid {
    grid-template-columns: 1fr;
  }

  .post-type-archive-yyh_benefit .archive-filter {
    padding: 16px;
  }

  .post-type-archive-yyh_benefit .yyh-clinic-benefit-card {
    min-height: 0;
  }
}
