.top h2 {
  margin-bottom: 3em; }
  .top h2 * {
    display: block; }
  .top h2 strong {
    font-family: "futura-pt", sans-serif;
    font-size: 1.9em;
    margin-bottom: 0.25em;
    letter-spacing: 0.15em;
    line-height: 1; }
  .top h2 span {
    font-size: .9em;
    letter-spacing: 0; }
  .top h2.color_b strong {
    color: #59c3e1; }
  .top h2.color_b span {
    color: #464646; }
  .top h2.color_w * {
    color: #fff; }
.top .hero {
  margin-bottom: 8em; }
  .top .hero .sp {
    display: none; }
  .top .hero .slick-dotted.slick-slider {
    margin-bottom: 0; }
  .top .hero .slick-dots {
    bottom: -38px; }
  .top .hero .slick-dots li {
    width: 12px;
    height: 12px;
    margin: 0 5px; }
  .top .hero .slick-dots li button {
    width: 12px;
    height: 12px; }
  .top .hero .slick-dots li button::before {
    font-size: 0;
    background: #e5e5e5;
    border-radius: 50%;
    opacity: 1;
    width: 12px;
    height: 12px; }
  .top .hero .slick-dots li.slick-active button::before {
    background: #7dcce3; }
.top .bnr_area {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 990px;
  margin-bottom: 8em; }
  .top .bnr_area li {
    width: 49%;
    max-width: 480px; }
.top .concept_area {
  margin-bottom: 8em; }
  .top .concept_area h3, .top .concept_area p {
    color: #767676; }
  .top .concept_area h3 {
    font-size: 1.5em;
    margin-bottom: 1em; }
  .top .concept_area p {
    margin-bottom: 2em;
    line-height: 1.9; }
    .top .concept_area p:last-of-type {
      margin-bottom: 0; }
.top .menu_area {
  margin-bottom: 11.5em;
  padding: 5.5em 0 7em;
  background: url("../images/top_bg.jpg") no-repeat center/cover; }
  .top .menu_area ul {
    width: 90%;
    max-width: 735px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    /*justify-content: center;*/
    flex-wrap: wrap;
    /*column-gap: 2.5em;*/
    row-gap: 2.5em; }
  .top .menu_area li {
    background: #fff;
    width: 31%;
    max-width: 224px;
    box-sizing: border-box; }
  .top .menu_area a {
    padding: 1.5em 0; }
  .top .menu_area figure {
    margin-bottom: 1.2em; }
  .top .menu_area figcaption {
    color: #59c3e1;
    font-size: 1.05em;
    font-weight: bold;
    line-height: 1.3;
    margin-bottom: .8em;
    box-sizing: border-box;
    background-repeat: no-repeat;
    background-position: left center;
    background-size: 38px;
    display: inline-block;
    padding: .5em 0 .5em 2.3em; }
  .top .menu_area .ico_01 {
    background-image: url("../images/ico_menu_01.png"); }
  .top .menu_area .ico_02 {
    background-image: url("../images/ico_menu_02.png"); }
  .top .menu_area .ico_03 {
    background-image: url("../images/ico_menu_03.png"); }
  .top .menu_area .ico_04 {
    background-image: url("../images/ico_menu_04.png"); }
  .top .menu_area .ico_05 {
    background-image: url("../images/ico_menu_05.png"); }
  .top .menu_area .ico_06 {
    background-image: url("../images/ico_menu_06.png"); }
  .top .menu_area .ico_07 {
    background-image: url("../images/ico_menu_07.png"); }
  .top .menu_area figure img {
    width: 100%;
    margin: 0 auto; }
  .top .menu_area p {
    color: #767676;
    letter-spacing: 0;
    padding: 0 1em; }
.top .info_area {
  margin-bottom: 10em; }
  .top .info_area ul {
    max-width: 700px;
    margin: 0 auto; }
  .top .info_area li {
    text-align: left;
    padding: 0.7em 3em;
    border-bottom: .1em solid #e5e5e5;
    position: relative; }
    .top .info_area li:first-of-type {
      border-top: .1em solid #e5e5e5; }
    .top .info_area li a {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      color: inherit; }
      .top .info_area li a:after {
        content: "";
        position: absolute;
        top: 0;
        right: 1.5em;
        bottom: 0;
        margin: auto;
        width: 0.5em;
        height: 0.5em;
        border-top: 0.1em solid #767676;
        border-right: 0.1em solid #767676;
        transform: rotate(45deg); }
    .top .info_area li div {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start; }
    .top .info_area li span {
      width: 22%; }
    .top .info_area li p {
      width: 78%; }
  .top .info_area .more_btn_wrap {
    text-align: center;
    margin-top: 3.5em; }
  .top .info_area .more_btn {
    color: #fff;
    background: #59c3e1;
    padding: 0.5em 0;
    display: inline-block;
    max-width: 200px;
    width: 100%;
    cursor: pointer;
    font-size: 1.1em;
    position: relative; }
    .top .info_area .more_btn:hover {
      opacity: .5;
      transition: all .2s ease-in; }
    .top .info_area .more_btn:after {
      content: "";
      position: absolute;
      top: 0;
      right: 15px;
      bottom: 0;
      margin: auto;
      width: 8px;
      height: 8px;
      border-top: 1px solid #fff;
      border-right: 1px solid #fff;
      transform: rotate(135deg);
      transition: .5s; }
    .top .info_area .more_btn.active:after {
      transform: rotate(-45deg); }
.top .clinic_area {
  color: #767676;
  padding: 5.5em 0;
  background: url("../images/top_bg.jpg") no-repeat center/cover; }
  .top .clinic_area .bg_w {
    background: rgba(255, 255, 255, 0.85);
    padding: 3em 4em;
    margin: 0 auto;
    max-width: 1100px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between; }
    .top .clinic_area .bg_w > * {
      width: 45%;
      max-width: 436px; }
  .top .clinic_area h3 {
    text-align: left;
    color: #767676;
    font-weight: bold;
    padding-bottom: .2em;
    border-bottom: 0.1em solid #59c3e1; }
  .top .clinic_area .logo_c {
    max-width: 368px;
    margin: 0 auto 1.5em; }
  .top .clinic_area .add_c {
    margin-bottom: 1.2em;
    font-size: .9em; }
  .top .clinic_area .btn_reserve {
    position: relative;
    width: 100%;
    max-width: 400px;
    font-size: 1.1em;
    margin-bottom: 1.5em; }
    .top .clinic_area .btn_reserve:after {
      content: "";
      position: absolute;
      top: .3em;
      left: 0;
      z-index: 1;
      width: 100%;
      height: 100%;
      border-radius: .2em;
      background-color: #B35968; }
    .top .clinic_area .btn_reserve span {
      position: relative;
      z-index: 2;
      background: #E67E8F;
      border-radius: .2em;
      color: #fff;
      font-weight: bold;
      transition: all 0.3s ease;
      padding: 0.8em 0; }
    .top .clinic_area .btn_reserve:hover span {
      transform: translateY(0.1em); }
  .top .clinic_area .tel {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #59c3e1;
    line-height: 1;
    font-family: "futura-pt", sans-serif;
    margin: 0 auto 2.5em; }
    .top .clinic_area .tel dt {
      margin-right: 1em;
      font-size: 1.2em; }
    .top .clinic_area .tel dd {
      font-size: 2.4em; }
      .top .clinic_area .tel dd a {
        pointer-events: none;
        cursor: default;
        text-decoration: none;
        color: inherit; }
  .top .clinic_area .reception .flex_wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 2em 0 1em;
    margin-top: 1.2em;
    position: relative; }
  .top .clinic_area .reception .time {
    width: 25%;
    padding-right: 1em;
    line-height: 5.5;
    font-size: .9em;
    border-right: .1em solid #cbcbcb; }
  .top .clinic_area .reception ul {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 66%; }
  .top .clinic_area .reception ul strong {
      position: absolute;
      top: 0;
      font-weight: bold;
      line-height: 1; }
  .top .clinic_area .right_area iframe {
    margin-top: 2em;
    margin-bottom: 1.2em;
    width: 100%;
    height: 277px; }
  .top .clinic_area .right_area ul {
    font-size: .9em;
    text-align: left; }
    .top .clinic_area .right_area ul span {
      color: #7dcce3;
      margin-right: .2em;
      display: inline-block; }

@media print, screen and (max-width: 768px) {
  .top h2 {
    margin-bottom: 2em; }
  .top .hero {
    margin-bottom: 6em; }
    .top .hero .pc {
      display: none; }
    .top .hero .sp {
      display: block; }
    .top .hero .slick-dots {
      bottom: -30px; }
  .top .bnr_area {
    display: block;
    margin-bottom: 6em; }
    .top .bnr_area li {
      width: 100%;
      margin: 0 auto 1.5em;
      max-width: 350px; }
      .top .bnr_area li:last-of-type {
        margin-bottom: 0; }
  .top .concept_area {
    margin-bottom: 6em; }
    .top .concept_area p {
      text-align: left;
      display: inline-block; }
      .top .concept_area p br {
        display: none; }
  .top .menu_area {
    padding: 4em 0 5em;
    margin-bottom: 6em; }
    .top .menu_area ul {
      max-width: 450px;
      row-gap: 2em; }
    .top .menu_area li {
      width: 48%;
      max-width: none; }
    .top .menu_area a {
      padding: 1em 0; }
    .top .menu_area figure {
      margin-bottom: .8em; }
    .top .menu_area figcaption {
      margin-bottom: .5em;
      font-size: 1em;
      background-size: 25px;
      padding-left: 1.8em; }
      .top .menu_area figcaption.font_s {
        letter-spacing: 0;
        font-size: min(3.6vw, 1em); }
    .top .menu_area p {
      padding: 0 .5em;
      font-size: .9em; }
  .top .info_area {
    margin-bottom: 6em; }
    .top .info_area li {
      padding: 0.7em 1em .7em 0; }
      .top .info_area li a::after {
        right: 0; }
      .top .info_area li div {
        display: block; }
        .top .info_area li div > * {
          width: 100%; }
    .top .info_area .more_btn_wrap {
      margin-top: 2.5em; }
  .top .clinic_area {
    padding: 4em 0; }
    .top .clinic_area .bg_w {
      padding: 2em 1.5em;
      max-width: 500px;
      display: block; }
      .top .clinic_area .bg_w > * {
        width: 100%;
        max-width: none; }
    .top .clinic_area .left_area {
      margin-bottom: 2em; }
    .top .clinic_area .tel dt {
      margin-right: .5em; }
    .top .clinic_area .tel dd {
      font-size: min(2.4em, 8.5vw); }
      .top .clinic_area .tel dd a {
        pointer-events: inherit;
        cursor: pointer; }
    .top .clinic_area .reception .flex_wrap {
      display: block; }
      .top .clinic_area .reception .flex_wrap > * {
        width: 100%;
        max-width: 240px;
        margin: 0 auto; }
    .top .clinic_area .reception .time {
      padding: 0;
      margin-bottom: 1em;
      line-height: inherit;
      text-align: left;
      border: 0; }
    .top .clinic_area .reception ul strong {
      position: static;
      margin-bottom: .5em; }
    .top .clinic_area .right_area iframe {
      height: 200px;
      margin-bottom: 0.5em; } }
