@charset "UTF-8";

:root {
  /* カラー */
  --c-btn-green: #8ac23e; /* 錦糸町・新小岩・北千住 */
  --c-btn-pink: #f09ba7; /* 本八幡・北習志野・佐倉・八千代 */
  --c-btn-orange: #fabf4e; /* 埼玉 */
  --c-btn-darkgreen: #28ac4b; /* 大阪・北大阪・東大阪 */
}

@media (max-width: 480px) {
  html {
    scroll-padding-top: 100px;
  }
  body {
    padding-top: 100px;
  }
}

.header {
  height: 110px;
  padding: 10px 40px 20px;
}

.header .header_lead {
  font-size: clamp(8px, 0.63vw, 12px);
  font-weight: 600;
  margin-bottom: 10px;
  padding: 0 20px;
  line-height: 1.4;
}

.header .header_total_inner {
  max-width: 1840px;
  width: 100%;
  margin: 0 auto;
}

.header .header_total_main {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: clamp(8px, 1.5vw, 20px);
}

.header .header_total_main .header_logo {
  align-items: flex-end;
}

.header_logo .logo_osaka {
  width: 100%;
  max-width: clamp(200px, 18vw, 260px);
}

.header .header_nav_total {
  flex-grow: 1;
}

.header .header_nav_total ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: clamp(4px, 0.4vw, 6px) clamp(4px, 1.2vw, 25px);
  margin-bottom: 5px;
}

.header .header_nav_total ul li a {
  font-size: clamp(12px, 0.8vw, 16px);
  font-weight: bold;
  white-space: nowrap;
}

@media (max-width: 1440px) {
  .header .header_nav_total ul li a {
    font-size: 10px;
    letter-spacing: -0.05em;
  }
}

@media (max-width: 1024px) {
  .header .header_nav_total.pc,
  .header .header_right {
    display: none;
  }
}

@media (max-width: 780px) {
  .header {
    height: 100px;
    padding: 10px;
  }
  .header .header_lead {
    padding: 0;
  }
}

/* FV */
#wrap_alltop .mv_image::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0.5) 0%, transparent 70%);
  pointer-events: none;
}
#wrap_alltop .mv_lead {
  text-shadow:
    0 0 2px rgba(255, 255, 255, 1),
    0 0 3px rgba(255, 255, 255, 1),
    0 0 6px rgba(255, 255, 255, 0.8),
    0 0 10px rgba(255, 255, 255, 0.6);
}

#wrap_alltop .mv_lead_all_sub {
  font-size: min(2vw, 22px);
  margin-bottom: min(3vw, 12px);
}

#wrap_alltop .mv_lead_all {
  font-size: min(6vw, 50px);
  margin-bottom: min(5vw, 82px);
}

#wrap_alltop .mv_lead_all02 {
  font-size: min(6vw, 50px);
}

#wrap_alltop .mv_sublead {
  font-size: min(1.8vw, 20px);
  margin-bottom: min(3vw, 40px);
}

#wrap_alltop .mv_icon {
  background: url(/common_osaka/images/top/icon_fv_v2.png) center / contain no-repeat;
}

@media (max-width: 780px) {
  #wrap_alltop .mv_osaka .mv_text {
    /* top: 70%; */
    top: 52%;
  }
  #wrap_alltop .mv_lead_all_sub {
    /* font-size: 4.5vw; */
    font-size: 4vw;
  }
  #wrap_alltop .mv_lead_all {
    /* font-size: 8vw; */
    font-weight: 500;
    font-size: 7vw;
    margin-bottom: 20vw;
  }
  #wrap_alltop .mv_lead_all02 {
    font-size: 7vw;
    margin-bottom: 40vw;
    font-weight: 500;
  }
  #wrap_alltop .mv_lead_all02_sub {
    font-size: 3.5vw;
  }
}

#sec_main_lead .main_lead_box {
  padding-bottom: min(13.5vw, 260px);
}

#sec_main_lead .main_lead_box .main_bg_deco {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: 130px;
  background: url(/common/images/top/bg_mainlead.png) no-repeat center bottom / contain;
  z-index: 1;
  pointer-events: none;
}

#sec_main_lead .main_lead_box .deco_character {
  position: absolute;
  bottom: 0;
  left: calc(50% + 10vw);
  width: min(9vw, 150px);
  aspect-ratio: 1 / 1.3;
  background: url(/top/images/photo_01_2x.png) no-repeat center / contain;
  z-index: 3;
  pointer-events: none;
}

@media (max-width: 780px) {
  #sec_main_lead .main_lead_box .deco_character {
    display: none;
  }
}

#wrap_alltop #sec_main_lead .main_sublead p::before {
  left: 12%;
}

@media (max-width: 780px) {
  #sec_main_lead .main_sublead p::before {
    left: 12%;
  }
}

/* グループ分院案内 */
#wrap_alltop #sec_topmap .p-alltop .bunin_item:last-child {
  margin-bottom: 0;
}

@media (max-width: 780px) {
  #wrap_alltop #sec_topmap {
    padding-top: 30px;
    padding-bottom: 0;
    scroll-margin-top: unset;
  }
  #wrap_alltop #sec_topmap .bunin_box ul {
    gap: 0;
  }
  #wrap_alltop .bunin_item {
    margin-bottom: 0;
  }
  #wrap_alltop .bunin_item.area_tokyo {
    margin-top: 0;
  }
  #wrap_alltop .bunin_item.area_osaka {
    margin-top: 25px;
  }
}

/* 当院は在宅医療に特化したクリニックです。 */
@media (max-width: 780px) {
  #home_medical {
    padding-top: 40px;
  }
}

/* トピックス */
#wrap_alltop #sec_topics {
  padding-top: clamp(40px, 16.27vw, 274px);
}

@media (min-width: 781px) {
  .js-total-top-slider .topics_arrow {
    display: block !important;
  }

  .js-total-top-slider .topics .slick-slide {
    margin: 0 15px !important;
  }
}

@media (max-width: 780px) {
  #wrap_alltop #sec_topics {
    padding-top: 40px;
  }
  #sec_topics .topics li.topics_item02 > p {
    letter-spacing: -1px;
  }
  #sec_topics .topics li.topics_item02 .logo_topics {
    width: 50%;
  }
  #sec_topics .topics li.topics_item03 > p {
    letter-spacing: -1.8px;
  }
}

.js-total-top-slider .topics.slick-initialized {
  display: block !important;
}

/* お知らせ */
#sec_news {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 0;
}

.news_meta,
.tag_group {
  display: flex;
  flex-wrap: wrap; /* 折り返しを許可 */
  align-items: center; /* 垂直方向の中央揃え */
  gap: 6px; /* タグ同士の隙間 */
  margin: 0;
  padding: 0;
}

.tag_item {
  display: inline-block;
  white-space: nowrap;
  font-size: clamp(11px, 0.8333vw, 14px);
  color: #fff;
  font-weight: bold;
  border-radius: 5px;
  padding: 2px 8px;
  line-height: 1.5;
  margin-right: 4px;
  margin-bottom: 4px;
  background-color: #dcedc5;
}

.tag_item.錦糸町,
.tag_item.新小岩,
.tag_item.北千住 {
  background-color: var(--c-btn-green);
}

.tag_item.本八幡,
.tag_item.北習志野,
.tag_item.佐倉,
.tag_item.八千代,
.tag_item.埼玉 {
  background-color: var(--c-btn-pink);
}

.tag_item.大阪,
.tag_item.北大阪,
.tag_item.東大阪,
.tag_item.全院 {
  background-color: var(--c-btn-darkgreen);
}

.tag_title p,
.tag_group {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.sp_only {
  display: none;
}

.pc_only {
  display: table-cell;
}

.title_area_sp a {
  font-size: clamp(14px, 1.47vw, 20px);
  font-weight: normal;
  color: #222222;
}

@media (max-width: 780px) {
  .sp_only {
    display: block;
  }

  .pc_only {
    display: none !important;
  }

  .meta_title_wrapper_sp {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding-bottom: 23px;
    margin-bottom: 28px;
  }

  .date_tag_wrapper {
    display: flex;
    align-items: baseline;
    gap: 10px;
    width: 100%;
  }

  .sp_tag_container {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
  }

  .title_area_sp {
    width: 100%;
    padding-top: 5px;
  }

  .news_table th.sp_thead {
    width: 100%;
    border: none;
    padding: 0;
    text-align: left;
    position: relative;
  }
}

/* 理事長挨拶 */
.greeting {
  padding-top: clamp(40px, 8.33vw, 140px);
  padding-bottom: clamp(20px, 8.33vw, 200px);
}

/* リンクボタン */
:root {
  --c-btn-green: #8ac23e;
  --c-btn-pink: #f09ba7;
  --c-btn-orange: #fabf4e;
  --c-btn-darkgreen: #28ac4b;
}

.link_clinics,
.link_relation {
  max-width: 1200px;
  width: 100%;
  margin: clamp(40px, 8.33vw, 160px) auto;
  padding: 0;
  box-sizing: border-box;
}

.link_clinics ul,
.link_relation ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  padding: 0;
  margin: 0;
  list-style: none;
  gap: 30px 40px;
}

.link_clinics ul li,
.link_relation ul li {
  width: calc((100% - 80px) / 3);
  box-sizing: border-box;
}

.link_clinics ul li span,
.link_relation ul li span {
  color: #fff;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 76px;
  border-radius: 38px;
  line-height: 1;
}

.link_clinics ul li span {
  font-size: 1.4rem;
  padding: 0 40px;
}

.link_relation ul li span {
  font-size: 1.25rem;
  padding-right: 30px;
  padding-left: 74px;
}

.link_clinics ul li span::after,
.link_relation ul li span::after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
  transform: rotate(45deg);
}

.link_clinics ul li span.green,
.link_relation ul li span.green {
  background-color: var(--c-btn-green);
}
.link_clinics ul li span.pink,
.link_relation ul li span.pink {
  background-color: var(--c-btn-pink);
}
.link_clinics ul li span.orange,
.link_relation ul li span.orange {
  background-color: var(--c-btn-orange);
}
.link_clinics ul li span.drak_green,
.link_relation ul li span.drak_green {
  background-color: var(--c-btn-darkgreen);
}

.link_clinics ul li a:hover span,
.link_relation ul li a:hover span {
  filter: brightness(0.9);
}

@media screen and (max-width: 900px) {
  .link_clinics ul,
  .link_relation ul {
    gap: 10px;
  }
  .link_clinics ul li,
  .link_relation ul li {
    width: calc((100% - 10px) / 2);
  }
}

@media screen and (max-width: 780px) {
  .link_clinics {
    margin: 40px auto 80px;
  }
  .link_relation {
    margin: 40px auto;
  }
  .link_clinics ul li span,
  .link_relation ul li span {
    font-size: 0.8rem;
    height: 44px;
    padding: 0 20px;
    line-height: 1.2;
  }
  .link_clinics ul li span::after,
  .link_relation ul li span::after {
    width: 5px;
    height: 5px;
  }
}

/* 在宅診療とは */
#wrap_alltop #sec_about {
  margin-top: -160px;
  padding-top: 160px;
  padding-bottom: clamp(40px, 8.33vw, 160px);
}

/* 対象となる方 */
#wrap_alltop .subject {
  padding-top: clamp(40px, 8.33vw, 160px);
  padding-bottom: 0;
}

@media screen and (max-width: 780px) {
  #wrap_alltop #sec_about {
    margin-top: -78px;
    padding-top: 78px;
    padding-bottom: clamp(40px, 8.33vw, 160px);
  }
}

@media screen and (max-width: 480px) {
  #wrap_alltop .subject {
    padding-top: 40px;
    padding-bottom: 0;
  }
}

/* 診療内容・エリア */
#wrap_alltop #sec_shinryo {
  margin-top: -160px;
  padding-top: 160px;
}

@media screen and (max-width: 780px) {
  #wrap_alltop #sec_shinryo {
    margin-top: -38px;
    padding-top: 38px;
  }
}

/* 診療実績 */
#wrap_alltop #sec_groupshinryou {
  margin-top: -160px;
  padding-top: 160px;
}

@media screen and (max-width: 780px) {
  #wrap_alltop #sec_groupshinryou {
    margin-top: -40px;
    padding-top: 40px;
  }
}

/* 施設ギャラリー */
.gallery_alltop .bunin_item + .bunin_item {
  margin-top: 25px;
}

.gallery_alltop .bunin_item {
  margin-bottom: 0;
}

.gallery_alltop li.bunin_item:nth-child(1) h3,
.gallery_alltop li.bunin_item:nth-child(2) h3,
.gallery_alltop li.bunin_item:nth-child(3) h3,
.gallery_alltop li.bunin_item:nth-child(4) h3 {
  background-color: var(--c-btn-green);
}

.gallery_alltop li.bunin_item:nth-child(1) .area_box,
.gallery_alltop li.bunin_item:nth-child(2) .area_box,
.gallery_alltop li.bunin_item:nth-child(3) .area_box,
.gallery_alltop li.bunin_item:nth-child(4) .area_box {
  border-top: 3px solid var(--c-btn-green);
}

.gallery_alltop li.bunin_item:nth-child(5) h3,
.gallery_alltop li.bunin_item:nth-child(6) h3,
.gallery_alltop li.bunin_item:nth-child(7) h3 {
  background-color: var(--c-btn-darkgreen);
}

.gallery_alltop li.bunin_item:nth-child(5) .area_box,
.gallery_alltop li.bunin_item:nth-child(6) .area_box,
.gallery_alltop li.bunin_item:nth-child(7) .area_box {
  border-top: 3px solid var(--c-btn-darkgreen);
}

.gallery_alltop li.bunin_item:nth-child(8) h3,
.gallery_alltop li.bunin_item:nth-child(9) h3,
.gallery_alltop li.bunin_item:nth-child(10) h3,
.gallery_alltop li.bunin_item:nth-child(11) h3 {
  background-color: var(--c-btn-pink);
}

.gallery_alltop li.bunin_item:nth-child(8) .area_box,
.gallery_alltop li.bunin_item:nth-child(9) .area_box,
.gallery_alltop li.bunin_item:nth-child(10) .area_box,
.gallery_alltop li.bunin_item:nth-child(11) .area_box {
  border-top: 3px solid var(--c-btn-pink);
}

.gallery_alltop li.bunin_item:nth-child(12) h3 {
  background-color: var(--c-btn-orange);
}

.gallery_alltop li.bunin_item:nth-child(12) .area_box {
  border-top: 3px solid var(--c-btn-orange);
}

@media screen and (max-width: 780px) {
  #wrap_alltop #sec_topmap.gallery_alltop {
    margin-top: -40px;
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

/* 採用・求人 */
#wrap_alltop #sec_recruit {
  margin-top: -160px;
  padding-top: 160px;
}

@media screen and (max-width: 780px) {
  #wrap_alltop #sec_recruit {
    margin-top: -40px;
    padding-top: 40px;
  }
}

/* 法人概要 */
#sec_houjin {
  padding-top: clamp(40px, 8.33vw, 160px);
}

#sec_houjin .houjin_box {
  width: 100%;
  background-color: #fff;
  border-radius: 30px;
  padding: 70px;
  box-sizing: border-box;
}

#sec_houjin table {
  width: 100%;
  border-collapse: collapse;
}

#sec_houjin table tbody tr {
  border-bottom: 1px solid #ccc;
}

#sec_houjin table tbody tr:first-child {
  border-top: 1px solid #ccc;
}

#sec_houjin th,
#sec_houjin td {
  font-size: 16px;
  font-weight: bold;
  text-align: left;
  vertical-align: middle;
  border: none;
  padding: 25px 0;
  line-height: 1.6;
}

#sec_houjin th {
  width: 25%;
  padding-right: 20px;
}

#sec_houjin td {
  width: 75%;
}

#sec_houjin td.kyoninka p {
  margin-bottom: 10px;
}

#sec_houjin td.kyoninka p:last-child {
  margin-bottom: 0;
}

#sec_houjin a {
  color: inherit;
  text-decoration: none;
}

#sec_houjin .history_link:hover {
  opacity: 0.7;
}

@media screen and (max-width: 780px) {
  #sec_houjin {
    padding-bottom: 40px;
  }
  #sec_houjin .houjin_box {
    padding: 30px;
  }

  #sec_houjin th,
  #sec_houjin td {
    font-size: 14px;
    display: table-cell;
    vertical-align: middle;
    line-height: 1.7;
  }

  #sec_houjin th {
    width: 40%;
    padding-right: 0;
  }

  #sec_houjin td {
    letter-spacing: -0.6px;
  }
}

/* 診療科目・診療日 */
#sec_shinryo_kamoku {
  padding-top: clamp(40px, 8.33vw, 160px);
}

/* 訪問エリア */
#sec_houmonarea {
  padding-bottom: clamp(40px, 8.33vw, 160px);
}

#sec_houmonarea .sec_wrapper {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
}

#sec_houmonarea .area_body {
  background-color: #fff;
  border-radius: 30px;
  padding: clamp(40px, 5vw, 70px);
  box-sizing: border-box;
}

.area_list02 {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.area_list02 li {
  font-size: clamp(14px, 3vw, 20px);
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  line-height: 1.7;
}

.area_list02 li span {
  font-weight: bold;
  display: inline-block;
  width: 110px;
  flex-shrink: 0;
  margin-right: 20px;
}

.area_list02 li span.green,
.area_list02 li span.kita {
  color: var(--c-btn-green);
}

.area_list02 li span.pink {
  color: var(--c-btn-pink);
}

.area_list02 li span.orange {
  color: var(--c-btn-orange);
}

.area_notice {
  font-size: clamp(14px, 3vw, 20px);
  margin-top: 10px;
  line-height: 2;
}

.area_notice_tokyo {
  margin-bottom: 70px;
}

.area_map {
  text-align: center;
  margin-bottom: 70px;
}

.area_map img {
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 780px) {
  #sec_houmonarea .area_body {
    padding: 40px 30px;
  }

  .area_map {
    margin-bottom: 30px;
  }

  .area_list02 {
    gap: 0;
  }

  .area_list02 li {
    flex-wrap: nowrap;
  }

  .area_list02 li span {
    width: 70px;
  }

  .area_notice {
    margin-top: 0;
  }

  .area_notice_tokyo {
    margin-bottom: 30px;
  }
}

/* 院長紹介 */
#wrap_alltop #sec_introduction {
  padding-top: clamp(40px, 8.33vw, 160px);
}

#wrap_alltop #sec_introduction .area_name {
  font-size: 1rem;
}

#wrap_alltop #sec_introduction .introduction_note {
  background-color: #fff;
  border-radius: 30px;
  padding: clamp(20px, 5vw, 30px) clamp(30px, 5vw, 70px);
  box-sizing: border-box;
  line-height: 1.4;
}

@media screen and (max-width: 780px) {
  #wrap_alltop .staff .introduction_img {
    width: 40%;
  }
  #wrap_alltop #sec_introduction .introduction_note {
    margin-top: 25px;
  }
}

/* 求人情報 */
.recruit {
  margin-bottom: clamp(40px, 8.33vw, 160px);
}
.recruit_text,
.recruit_name {
  font-size: 1.25rem;
}

.recruit_content {
  margin-bottom: 205px;
}

.recruit_text .small {
  font-size: 0.9rem;
}

@media screen and (max-width: 780px) {
  .recruit_text,
  .recruit_name {
    font-size: 1rem;
  }
  .recruit_text .small {
    font-size: 0.7rem;
  }
}

/* お知らせ */
.news_all .header_total_inner,
.news_all_single .header_total_inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px 20px;
}

.news_all .header_total_main,
.news_all_single .header_total_main {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}

.news_all .header_total_main .header_logo,
.news_all_single .header_total_main .header_logo {
  width: 300px;
  flex-shrink: 0;
}

.news_all .header_total_main .header_logo img,
.news_all_single .header_total_main .header_logo img {
  width: 100%;
  height: auto;
}

.news_all .header_nav_total.pc ul,
.news_all_single .header_nav_total.pc ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 10px 15px;
}

.news_all .header_nav_total.pc ul li a,
.news_all_single .header_nav_total.pc ul li a {
  text-decoration: none;
  color: #333;
  font-size: 13px;
  font-weight: bold;
  white-space: nowrap;
}

.news_all .header,
.news_all_single .header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  background: transparent;
}

/* フッター */
.footer_bnr li.bnr_tmi a {
  background-image: url(/common/images/footer/bnr_tmi.png);
}
.footer_bnr li.bnr_zaitaku a {
  background-image: url(/common/images/footer/bnr_zaitaku.png);
}

.footer_bnr li.bnr_clinics a {
  background-image: url(/common/images/footer/bnr_clinics.png);
}

.footer_bnr li.bnr_message a {
  background-image: url(/common/images/footer/bnr_message.png);
}
