@charset "UTF-8";
/* ==================================================
 top.css
================================================== */
/* ==================================================
 カラー変数
-------------------------------------------------- */
/* ==================================================
 ブレイクポイント
-------------------------------------------------- */
/* ==================================================
 Animation 関連
-------------------------------------------------- */
/* ==================================================
 フォント（width, margin, padding でも使用可）
-------------------------------------------------- */
/* --------------------------------------------------
 clamp() フォントサイズ計算関数
	@param $min    - 最小フォントサイズ（px単位の数値）
	@param $max    - 最大フォントサイズ（px単位の数値）
	@param $vp-min - 最小ビューポート幅（デフォルト: 375）
	@param $vp-max - 最大ビューポート幅（デフォルト: 1200）
	@param $root   - ルートフォントサイズ（デフォルト: 16）
-------------------------------------------------- */
/* ==================================================
 体裁
-------------------------------------------------- */
/* ==================================================
 ミックスイン
-------------------------------------------------- */
/* --------------------------------------------------
 メディアクエリ ミックスイン
-------------------------------------------------- */
/* --------------------------------------------------
 コンテナ ミックスイン
-------------------------------------------------- */
/* --------------------------------------------------
 透明度 ミックスイン
-------------------------------------------------- */
/* --------------------------------------------------
 ボックスシャドウ ミックスイン
-------------------------------------------------- */
/* --------------------------------------------------
 その他 ミックスイン
-------------------------------------------------- */
@layer top {
  /* ==================================================
   1.0 - トップページ
  -------------------------------------------------- */
  /* ------------------------------------------------
   1.1 - ヒーロー
  ------------------------------------------------ */
  .hero {
    position: relative;
    overflow: hidden;
    padding-block: clamp(4.5rem, 2.9090909091rem + 6.7878787879vw, 8rem) clamp(3.75rem, 3.4659090909rem + 1.2121212121vw, 4.375rem);
    min-height: 360px;
  }
  @media (min-width: 1024px) {
    .hero {
      min-height: 640px;
    }
  }
  .hero .hero__inner {
    width: 100%;
    max-width: 1280px;
    margin-inline: auto;
    padding-inline: 20px;
  }
  @media (min-width: 768px) {
    .hero .hero__inner {
      padding-inline: 24px;
    }
  }
  @media (min-width: 1024px) {
    .hero .hero__inner {
      padding-inline: 30px;
    }
  }
  .hero .hero__inner {
    position: relative;
  }
  .hero .hero__content {
    position: relative;
    z-index: 2;
    text-align: center;
  }
  @media (min-width: 768px) {
    .hero .hero__content {
      position: absolute;
      bottom: 0;
      left: 40px;
      text-align: left;
    }
  }
  @media (min-width: 1024px) {
    .hero .hero__content {
      left: 40px;
    }
  }
  @media (min-width: 1280px) {
    .hero .hero__content {
      left: 30px;
    }
  }
  .hero .hero__catch {
    font-size: clamp(1.25rem, 0.9090909091rem + 1.4545454545vw, 2rem);
    font-weight: 600;
    line-height: 1.85;
  }
  .hero .hero__visual {
    z-index: 1;
    margin: 40px -12% 30px;
  }
  @media (min-width: 520px) {
    .hero .hero__visual {
      margin-inline: -6%;
    }
  }
  @media (min-width: 768px) {
    .hero .hero__visual {
      margin: 0 -3% 0 0;
      padding-bottom: 60px;
      padding-left: 20%;
    }
  }
  @media (min-width: 1024px) {
    .hero .hero__visual {
      padding-bottom: 20px;
      padding-left: 10%;
    }
  }
  @media (min-width: 1280px) {
    .hero .hero__visual {
      padding-bottom: 0;
      padding-left: 6%;
    }
  }
  .hero .hero__image {
    width: 100%;
  }
  /* ------------------------------------------------
   1.2 - Message
  ------------------------------------------------ */
  .message-section {
    position: relative;
    padding-block: clamp(5.625rem, 2.7840909091rem + 12.1212121212vw, 11.875rem) 0;
    background: url(../img/bg_dots.png) left top repeat;
  }
  .message-section::before, .message-section::after {
    position: absolute;
    content: "";
  }
  @media (min-width: 768px) {
    .message-section::before {
      z-index: 1;
      top: -55px;
      left: 50%;
      width: 35px;
      height: 112px;
      background: url(../img/bg_scroll.svg) center bottom no-repeat;
      transform: translateX(-50%);
    }
  }
  @media (min-width: 1024px) {
    .message-section::before {
      top: -65px;
      width: 40px;
      height: 128px;
    }
  }
  .message-section::after {
    inset: 0;
    background: url(../img/bg_message.svg) center top no-repeat;
  }
  .message-section .message-section__inner {
    width: 100%;
    max-width: 1280px;
    margin-inline: auto;
    padding-inline: 20px;
  }
  @media (min-width: 768px) {
    .message-section .message-section__inner {
      padding-inline: 24px;
    }
  }
  @media (min-width: 1024px) {
    .message-section .message-section__inner {
      padding-inline: 30px;
    }
  }
  .message-section .message-section__inner {
    position: relative;
    z-index: 1;
  }
  .message-section .message-section__title {
    width: clamp(14.375rem, 7.8409090909rem + 27.8787878788vw, 28.75rem);
    margin: 0 auto clamp(2.5rem, 1.3636363636rem + 4.8484848485vw, 5rem);
  }
  .message-section .message-section__text {
    padding-block: 0 clamp(4.375rem, 2.3863636364rem + 8.4848484848vw, 8.75rem);
    border-bottom: 1px solid #C0D4DC;
    text-align: center;
  }
  .message-section .message-section__text p {
    margin-block: 0 2em;
    font-size: clamp(0.875rem, 0.7045454545rem + 0.7272727273vw, 1.25rem);
    font-weight: 600;
    line-height: 2.4;
  }
  .message-section .message-section__text p:last-child {
    margin: 0;
  }
  .message-section .message-section__text p span {
    display: inline-block;
  }
  @media (max-width: 767px) {
    .message-section .message-section__text p br {
      display: none;
    }
  }
  /* ------------------------------------------------
   1.3 - Uscras Way - 事業内容
  ------------------------------------------------ */
  .way-section {
    position: relative;
    overflow: hidden;
    padding-block: clamp(3.75rem, 0.0568181818rem + 15.7575757576vw, 11.875rem) clamp(3.125rem, 2.2727272727rem + 3.6363636364vw, 5rem);
    background: url(../img/bg_dots.png) left top repeat;
  }
  .way-section .way-section__inner {
    width: 100%;
    max-width: 1024px;
    margin-inline: auto;
    padding-inline: 20px;
  }
  @media (min-width: 1280px) {
    .way-section .way-section__inner {
      padding-inline: 0;
    }
  }
  .way-section .way-section__inner {
    position: relative;
  }
  .way-section .way-section__intro {
    text-align: center;
  }
  @media (min-width: 768px) {
    .way-section .way-section__intro {
      text-align: left;
    }
  }
  .way-section .way-section__heading {
    position: relative;
    z-index: 2;
  }
  .way-section .way-section__label {
    display: flex;
    flex-direction: row;
    justify-content: center;
    gap: 10px;
    margin-bottom: 15px;
  }
  @media (min-width: 768px) {
    .way-section .way-section__label {
      flex-direction: column;
      align-items: flex-start;
      gap: 25px;
      margin-bottom: 20px;
    }
  }
  .way-section .way-section__label img {
    width: auto;
    height: clamp(2.25rem, 1.2272727273rem + 4.3636363636vw, 4.5rem);
  }
  .way-section .way-section__title {
    margin-block: 0 clamp(1.25rem, 0.3977272727rem + 3.6363636364vw, 3.125rem);
    font-size: 16px;
    font-weight: 600;
    color: #001663;
  }
  @media (min-width: 768px) {
    .way-section .way-section__title {
      text-align: left;
    }
  }
  .way-section .way-section__visual {
    z-index: 1;
    width: 110%;
    margin-left: -5%;
  }
  @media (min-width: 768px) {
    .way-section .way-section__visual {
      position: absolute;
      top: clamp(-6.25rem, 0.1136363636rem + -8.4848484848vw, -1.875rem);
      right: 0;
      margin: 0 -3% 0 0;
      padding-bottom: 60px;
      padding-left: clamp(17.5rem, 15.5113636364rem + 8.4848484848vw, 21.875rem);
    }
  }
  @media (min-width: 1024px) {
    .way-section .way-section__visual {
      margin-right: -8%;
      padding-bottom: 20px;
    }
  }
  @media (min-width: 1280px) {
    .way-section .way-section__visual {
      margin-right: -12%;
      padding-bottom: 0;
    }
  }
  .way-section .way-section__image {
    width: 100%;
  }
  .way-section .way-section__lead {
    position: relative;
    z-index: 2;
    margin-block: 25px 40px;
    font-size: clamp(1rem, 0.7727272727rem + 0.9696969697vw, 1.5rem);
    font-weight: 600;
    line-height: 1.85;
  }
  /* 1.3.1 - クリニックカード
  ------------------------------------------------ */
  .clinic-card-list {
    position: relative;
    z-index: 2;
    display: grid;
    gap: 20px;
  }
  @media (min-width: 768px) {
    .clinic-card-list {
      grid-column: 1/-1;
      grid-template-columns: repeat(2, 1fr);
      gap: 30px;
    }
  }
  @media (min-width: 1024px) {
    .clinic-card-list {
      gap: 40px;
    }
  }
  .clinic-card {
    position: relative;
    overflow: hidden;
    display: grid;
    place-items: center;
    min-height: 165px;
    padding: clamp(1.875rem, 1.3068181818rem + 2.4242424242vw, 3.125rem) 25px clamp(0.9375rem, 0.3693181818rem + 2.4242424242vw, 2.1875rem);
    background-color: #FFFFFF;
    border: 1px solid #C0D4DC;
    border-radius: clamp(0.625rem, 0.3409090909rem + 1.2121212121vw, 1.25rem);
  }
  @media (min-width: 768px) {
    .clinic-card {
      min-height: 180px;
    }
  }
  .clinic-card .clinic-card__logo {
    width: clamp(11.875rem, 9.3181818182rem + 10.9090909091vw, 17.5rem);
    margin-bottom: clamp(0.3125rem, -0.8238636364rem + 4.8484848485vw, 2.8125rem);
  }
  .clinic-card .clinic-card__link {
    display: inline-flex;
    align-items: center;
    height: clamp(0.5rem, 0.3011363636rem + 0.8484848485vw, 0.9375rem);
    margin-left: auto;
  }
  @media (min-width: 768px) {
    .clinic-card .clinic-card__link {
      margin: 0;
    }
  }
  .clinic-card .clinic-card__link img {
    width: auto;
    height: 100%;
  }
  .clinic-card .clinic-card__badge {
    position: absolute;
    top: 0;
    right: 0;
    padding: clamp(0.625rem, 0.3409090909rem + 1.2121212121vw, 1.25rem) clamp(0.75rem, 0.4659090909rem + 1.2121212121vw, 1.375rem);
    border-bottom-left-radius: clamp(0.625rem, 0.3409090909rem + 1.2121212121vw, 1.25rem);
    background-color: #EB6A8A;
    color: #FFFFFF;
    font-size: clamp(0.75rem, 0.6647727273rem + 0.3636363636vw, 0.9375rem);
    font-weight: 600;
    text-align: center;
    line-height: 1.2;
  }
  /* ------------------------------------------------
   1.4 - For Doctors - 採用情報、研修情報
  ------------------------------------------------ */
  .recruit-section {
    position: relative;
    overflow: hidden;
    padding-block: clamp(3.125rem, 1.7045454545rem + 6.0606060606vw, 6.25rem) clamp(3.125rem, 2.2727272727rem + 3.6363636364vw, 5rem);
    background-color: #FFFFFF;
  }
  .recruit-section .recruit-section__inner {
    width: 100%;
    max-width: 1024px;
    margin-inline: auto;
    padding-inline: 20px;
  }
  @media (min-width: 1280px) {
    .recruit-section .recruit-section__inner {
      padding-inline: 0;
    }
  }
  .recruit-section .recruit-section__inner {
    position: relative;
  }
  .recruit-section .recruit-section__label {
    width: clamp(18.125rem, 10.1704545455rem + 33.9393939394vw, 35.625rem);
    margin: 0 auto clamp(0.9375rem, 0.7954545455rem + 0.6060606061vw, 1.25rem);
  }
  .recruit-section .recruit-section__label img {
    width: 100%;
  }
  .recruit-section .recruit-section__title {
    margin-block: 0 clamp(1.25rem, 0.3977272727rem + 3.6363636364vw, 3.125rem);
    font-size: 16px;
    font-weight: 600;
    color: #001663;
    text-align: center;
  }
  /* 1.4.1 - リクルートカード
  ------------------------------------------------ */
  .recruit-card-list {
    position: relative;
    z-index: 2;
    display: grid;
    gap: 20px;
  }
  @media (min-width: 768px) {
    .recruit-card-list {
      grid-column: 1/-1;
      grid-template-columns: repeat(2, 1fr);
      gap: 30px;
    }
  }
  @media (min-width: 1024px) {
    .recruit-card-list {
      gap: 40px;
    }
  }
  .recruit-card {
    display: grid;
    place-items: center;
    padding: clamp(1.25rem, 0.5397727273rem + 3.0303030303vw, 2.8125rem) 25px;
    background-color: #75A2D6;
    border-radius: clamp(0.625rem, 0.3409090909rem + 1.2121212121vw, 1.25rem);
  }
  .recruit-card.recruit-card--02 {
    background-color: #E67D7A;
  }
  .recruit-card .recruit-card__text {
    margin-bottom: clamp(1.25rem, 0.3977272727rem + 3.6363636364vw, 3.125rem);
    color: #FFFFFF;
    font-size: clamp(1.25rem, 0.9090909091rem + 1.4545454545vw, 2rem);
    font-weight: 600;
    text-align: center;
    line-height: 1.85;
  }
  .recruit-card .recruit-card__more {
    display: inline-flex;
    align-items: center;
    height: clamp(0.625rem, 0.4829545455rem + 0.6060606061vw, 0.9375rem);
  }
  .recruit-card .recruit-card__more img {
    width: auto;
    height: 100%;
  }
}

/*# sourceMappingURL=top.css.map */
