/* responsive
-------------------------------------------------- */
.sp { display: none; }
.pc_f {
  display: flex;
  display: -ms-flexbox;
  display: -webkit-flex;
}

/* 高さの制限
-------------------------------------------------- */
@media ( height <= 768px ) {
  .nav_panel_inner {
    height: 440px;
  }
}

/* 画面幅小さいPC - small_pc
-------------------------------------------------- */
@media ( width <= 1280px ) {
  .breadcrumb_list {
    padding: 0 3rem;
    max-width: 1080px;
  }
  .nav_inner ul.nav_list {
    padding: 1rem 1rem 0;
  }

  .nav_inner ul.nav_list_sub {
    padding: 0 1rem;
  }
  .nav_inner ul.nav_list > li a {
    padding: 0 1rem;
    width: auto;
    font-size: 1.4rem;
  }

  .nav_panel_inner {
    width: 800px;
  }

  .catch_copy {
    left: 4rem;
    bottom: 3rem;
    font-size: 2.6rem;
  }

  .box_inner {
    max-width: 1080px;
  }

  .swiper_loop .swiper-slide img {
    height: 250px;
  }


  .column_full_box.wp-block-columns.is-layout-flex {
    padding-left: 3rem;
    padding-right: 3rem;
    max-width: 100%;
  }
  .wp-block-columns:not(.column_full_box) {
    padding-left: 3rem;
    padding-right: 3rem;
  }
  .column_full_box.wp-block-columns .wp-block-columns {
    padding: 0;
  }


  .list_session_info {
    padding: 0 3rem;
    max-width: 1080px;
  }

  .list_faq dt {
    font-size: 2.1rem;
  }

  body.privacy-policy h2.chapter_ttl {
    max-width: 980px;
  }

  .entry_application {
    max-width: 1080px;
  }
  .f_inner {
    padding: 1rem 2rem;
  }
  .footer_link > li a {
    padding: 0 2rem;
  }
}

/* 画面幅小さいPC - small_pc
-------------------------------------------------- */
@media ( width <= 1080px ) {
  .sub_visual {
    min-height: 360px;
  }

  .btn_area {
    width: 80px;
  }
  .main_logo {
    max-width: 240px;
  }

  #ac_menu, #ac_menu span {
    width: 36px;
  }
  #ac_menu span:nth-child(1) {
    top: 9px;
  }
  #ac_menu span:nth-child(3) {
    top: 33px;
  }

  .nav_panel .nav_list_panel_menu > li:first-of-type {
    font-size: 3rem;
  }
  .nav_panel .nav_list_panel_menu > li:not(:first-of-type) a {
    font-size: 1.6rem;
  }

  .txt_sub {
    font-size: 1.8rem;
  }

  .list_therapists {
    flex-wrap: wrap;
  }
  /* .list_therapists > li .therapist_img img {
    width: 160px;
    height: 160px;
  } */
  .list_therapists > li .therapist_company {
    font-size: 1.6rem;
  }
  .list_therapists > li .therapist_name {
    font-size: 1.4rem;
  }

  .event_detail > span:not(:last-of-type) {
    margin-right: 1rem;
  }
  .event_label {
    min-width: 150px;
    font-size: 1.4rem;
  }

  .access_info dt {
    font-size: 1.4rem;
  }
  .access_info dt span {
    font-size: 1.2rem;
  }

  .box_inner {
    padding: 5rem;
  }
  body.voice .box_inner {
    padding-top: 0;
  }

  .experiences_box dt {
    font-size: 2.1rem;
  }
  .memory_photos {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  .list_faq dd {
    font-size: 1.6rem;
  }

  .list_step_flow li::before {
    margin-right: 2rem;
    min-width: auto;
    font-size: 1.6rem;
  }
  .list_step_lectures .step_title {
    font-size: 1.6rem;
  }

  .ttl_sitemap {
    font-size: 1.8rem;
  }

  .experiences_box dd {
    padding: 5rem;
  }
}


/* タブレット - tablet
-------------------------------------------------- */
@media ( width <= 768px ) {
  .half_box > * {
    width: 100%;
  }
  .box_inner {
    padding: 5rem 2rem;
  }

  /* パンくず - breadcrumb
  --------------------------------------------- */
  .breadcrumb_list {
    flex-wrap: nowrap;
    padding-left: 0;
    word-break: keep-all;
    white-space: nowrap;
    overflow-x: scroll;
  }

  .sub_visual {
    margin-bottom: 3rem;
    min-height: 260px;
  }

  .ttl_sub {
    font-size: 2.1rem;
  }
  .ttl_sub > p {
    font-size: 2.6rem;
  }

  .modal-content {
    padding: 5rem 3rem;
  }


  body.logged-in.admin-bar nav .nav_fixed {
    top: 46px;
  }

  .nav_inner ul.nav_list_sub > li:nth-child(1) a,
  .nav_inner ul.nav_list_sub > li:nth-child(2) a {
    padding: .5rem 2rem;
  }
  .nav_inner ul.nav_list {
    display: none;
  }

  .nav_inner ul.nav_list_sub {
    height: 100px;
  }

  .news_tab_group button {
    font-size: 1.4rem;
  }

  .nav_panel .nav_list_panel_menu > li:first-of-type {
    margin-bottom: .5rem;
  }

  .nav_panel_inner ul:not(:last-of-type) {
    margin-bottom: 3rem;
  }
  .nav_panel {
    padding: 2rem 5rem;
    width: 100%;
  }
  .nav_panel_inner {
    max-height: 600px;
  }
  .nav_panel .nav_list_panel_menu {
    width: 100%;
  }

  .btn_area {
    width: 100px;
  }
  #ac_menu, #ac_menu span {
    width: 40px;
  }
  #ac_menu span:nth-child(1) {
    top: 7px;
  }
  #ac_menu span:nth-child(3) {
    top: 36px;
  }


  .ttl_main > p {
    font-size: 1.8rem;
  }

  .event_ttl {
    padding: 1rem 2rem 0 3rem;
    flex: auto;
    width: 100%;
  }

  .about_box .about_img,
  .company_info {
    margin-bottom: 3rem;
  }
  .about_box .about_img, .about_box .about_txt,
  .company_info, .access_info {
    padding-left: 0;
    padding-right: 0;
    width: 100%;
  }

  .support_list > li {
    flex-direction: column;
    align-items: center;
  }
  .support_img img {
    width: 200px;
    height: 200px;
  }


  .list_therapists > li a {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto; 
    column-gap: 1.5rem;
    row-gap: 0.5rem;
    align-items: center;
    padding: 1.5rem 4rem 1.5rem 1rem;
  }

  .list_therapists > li .therapist_img {
    grid-row: 1 / 3; 
    margin: 0;
  }

  .list_therapists > li .therapist_img img {
    height: 80px;
    width: 80px;
  }

  .list_therapists > li .therapist_name {
    grid-column: 2 / 3;
    grid-row: 1 / 2;
    margin: 0;
    width: fit-content;
    padding: 0.2rem 1.2rem;
    font-size: 1.4rem;
    text-align: center;
  }

  .list_therapists > li .therapist_company {
    grid-column: 2 / 3;
    grid-row: 2 / 3;
    margin: 0;
    padding-left: 1rem;
    /* white-space: normal; */
    line-height: 1.2;
    align-self: start;
  }
  .list_therapists > li .therapist_company p {
    font-size: 1.6rem;
  }


  .swiper_loop .swiper-slide img {
    height: 150px;
  }

  .company_box {
    padding-bottom: 0;
  }
  .access_info dt {
    width: 40%;
  }
  .access_info dd {
    width: 60%;
  }
  .access_info dt, .access_info dd {
    padding-bottom: 3rem;
  }


  .f_inner {
    flex-direction: column;
    padding: 2rem;
  }
  
  .footer_link {
    margin-bottom: 1.5rem;
  }
  .f_inner .copy {
    margin-left: 0;
    text-align: center;
  }

  .hypno_status_capsule {
    min-width: auto;
  }

  .photo_therapist figure img {
    max-width: 180px;
  }

  .list_flower > li {
    font-size: 1.6rem;
  }

  .course_list .event_ttl.course_ttl {
    padding-left: 0;
  }

  .list_session_info > li {
    width: 48%;
  }
  .experiences_box dd {
    padding: 5rem;
  }

  .list_faq dt {
    font-size: 1.8rem;
  }
  .list_faq dt::before {
    font-size: 2rem;
  }

  #cancel_page .box_inner {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .sitemap_block {
    margin-bottom: 3rem !important;
  }
  [id*="policy"], #ssl, #analytics, #mensakizikou {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  .num_list {
    padding-left: 3rem;
  }

  .txt_form {
    padding-left: 2rem;
    padding-right: 2rem;
    font-size: 1.4rem;
  }
  #calendar .txt_form {
    padding: 0;
  }
  .wpcf7.js {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  #reservationHeader {
    margin-top: 0;
    font-size: 1.6rem !important;
  }

  .contact_form dt, .contact_form dd {
    width: 100%;
  }

  .sp_flex_reverse {
    flex-direction: column-reverse;
  }
}


/* スマホ - sp
-------------------------------------------------- */
@media ( width <= 480px ) {
  
  /* レスポンシブ - responsive
  --------------------------------------------- */
  .pc { display: none; }
  .sp { display: block; }

  body {
    font-size: 1.4rem;
  }

  .ttl_sub {
    padding: 0 2rem;
    font-size: 1.8rem;
  }
  .ttl_sub > p {
    font-size: 2rem;
  }
  .ttl_faq {
    font-size: 1.8rem !important;
  }
  .ttl_question, .ttl_question::before {
    font-size: 1.6rem;
  }

  .ttl_icon, .ttl_course {
    font-size: 1.6rem;
  }
  .ttl_course::before,
  .ttl_icon::before {
    width: 25px;
    height: 25px;
  }

  .txt_sub {
    padding: 0 2rem;
  }

  .box_inner {
    padding: 3rem 2rem;
  }

  .modal-content {
    padding: 3rem;
    max-height: 70vh;
  }
  .modal-content h2.ttl_main > p {
    font-size: 1.8rem;
  }
  .modal-content h2.ttl_main span {
    font-size: 1.8rem;
  }
  

  .btn_area {
    width: 80px;
    border-left: none;
  }


  .main_logo img {
    height: 60px;
  }
  .nav_inner ul.nav_list_sub,
  .btn_area {
    height: 80px;
  }
  .nav_inner ul.nav_list_sub {
    padding: 0;
  }
  .main_logo {
    max-width: 160px;
  }
  .nav_inner ul.nav_list_sub > li:not(:last-child) {
    margin-right: 0;
  }

  .nav_panel_main {
    margin-bottom: 3rem;
  }
  .nav_panel {
    padding: 2rem 3rem;
  }
  .nav_panel_inner {
    max-height: 400px;
  }
  .news_tab_group button {
    min-width: 100%;
  }
  .news_tab_group button:not(:last-of-type) {
    margin-bottom: 2rem;
  }

  .news_btns {
    flex-direction: column;
  }
  .news_btns > div.btn_df:not(:last-of-type) {
    margin-bottom: 2rem;
  }
  .news_btns > div.btn_df {
    width: 100%;
  }

  .news_box {
    margin-bottom: 3rem;
  }

  .normal_event_list {
    padding-top: 2rem;
    /* border-top: 1px solid rgba( 204, 204, 204, .8 ); */
  }

  .after_event_info {
    margin-top: 1rem;
    padding: 0 2rem;
  }
  .event_after_detail .event_time,
  .event_after_detail .event_zoom {
    margin-left: 0;
    padding: .25rem 2rem;
    width: 100%;
  }
  .after_event_info, .event_after_detail .event_content {
    width: 100%;
  }
  .event_after_detail .event_content {
    padding: 2rem 1rem;
  }

  .event_label {
    margin-top: 1rem;
    margin-left: 3rem;
  }
  .event_ttl {
    padding-left: 3rem;
    white-space: wrap;
    overflow: visible;
    text-overflow: initial;
  }

  .ttl_main::after {
    background-image: url( '../imgs/svg/leaf_short.svg' );
  }
  .txt_sub {
    font-size: 1.6rem;
  }

  .catch_copy {
    left: 2rem;
    bottom: 2rem;
    font-size: 1.4rem;
  }
  .swiper_fade {
    height: 320px;
  }

  .swiper_loop .swiper-slide img {
    height: 120px;
  }

  .supporter_detail {
    padding: 3rem 2rem;
  }
  .support_job { font-size: 1.4rem; }
  .support_ttl { font-size: 1.8rem; }

  .swiper-button-prev.support_prev,
  .swiper-button-next.support_next {
    width: 30px;
    height: 30px;
  }
  .swiper-button-prev.support_prev::after,
  .swiper-button-next.support_next::after {
    font-size: 1.4rem;
  }
  .swiper-button-next.support_next {
    right: -1rem;
  }
  .swiper-button-prev.support_prev {
    left: -1rem;
  }

  .list_therapists > li a {
    grid-template-columns: 70px 1fr;
    column-gap: 1rem;
    padding-right: 3.5rem;
  }

  .list_therapists > li .therapist_img img {
    height: 70px;
    width: 70px;
  }

  .list_therapists > li .therapist_company p {
    font-size: 1.4rem;
  }

  .list_therapists > li a::after {
    right: 1rem;
  }

  .access_info dt, .access_info dd {
    width: 100%;
  }
  .access_info dt {
    padding-bottom: 2rem;
  }
  .access_info dt:not(:last-of-type) {
    border-bottom: none;
  }
  .access_info dd:not(:first-of-type) {
    padding-top: 0;
  }

  .breadcrumb_list {
    padding: 0 2rem;
  }

  .sub_visual {
    min-height: 160px;
  }

  .f_inner {
    align-items: flex-start;
  }
  .footer_link {
    flex-direction: column;
    align-items: flex-start;
  }
  .footer_link > li:not(:last-child) {
    margin-bottom: .5rem;
  }
  .footer_link > li a {
    padding: 0;
  }
  .footer_link > li:not(:last-child) a {
    border-right: none;
  }


  .representative_name {
    font-size: 1.6rem;
  }
  .representative_name > span {
    font-size: 1.8rem;
  }
  .hypno_status {
    padding: 2rem 0;
    flex-direction: column;
  }
  .hypno_status_capsule {
    min-width: 100%;
  }
  .hypno_status .arrow-icon.pink-bg {
    transform: rotate( 90deg );
  }
  .hypno_status .arrow-icon.blue-bg {
    transform: rotate( 90deg );
  }

  .photo_therapist figure img {
    max-width: 120px;
  }

  .list_session_info {
    padding: 0 2rem;
  }
  .list_session_info > li {
    width: 100%;
  }
  .list_session_info > li a {
    font-size: 1.6rem;
  }

  .tbl_price table {
    width: 780px !important;
  }

  .list_step_flow li {
    flex-direction: column;
  }
  .step_title {
    margin-top: 2rem;
    font-size: 1.6rem;
  }

  .list_step_lectures .step_title {
    font-size: 1.6rem;
  }
  .list_step_lectures .step_title br {
    display: none;
  }

  .experiences_box dt {
    padding: 1rem 2rem;
    font-size: 1.8rem;
  }
  .experiences_box dd {
    padding: 3rem 2rem;
  }
  .course_list > li .event_ttl {
    align-items: flex-start;
  }

  #cancel_page h2.ttl_main,
  #cancel_page .box_inner .cancel_main_txt {
    margin-bottom: 3rem;
  }

  .column_full_box.wp-block-columns.is-layout-flex {
    padding: 2rem;
  }

  .list_externallink > li a {
    display: flex;
    align-items: flex-start;
    font-size: 1.6rem;
  }
  .list_externallink > li a::before {
    flex-shrink: 0;
  }
  .list_externallink > li span {
    padding: 0 2rem;
  }

  #calendar {
    margin-bottom: 0;
  }
  #calendar .box_inner {
    padding: 2rem;
  }

  .post_content {
    margin-bottom: 0;
  }
  .post_content > .wp-block-columns:not(.column_full_box) {
    padding-left: 0;
    padding-right: 0;
  }
  .wp-block-columns:not(.column_full_box) {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .post_content .wp-block-table table tr td:first-of-type,
  .post_content .wp-block-table table tr td:last-of-type {
    display: block;
    padding: 1rem 2rem;
    width: 100%;
    font-size: 1.6rem;
  }
  .entry_application button.btn_submit,
  .application_end {
    margin-top: 3rem;
    font-size: 1.6rem;
  }
  .contact_form_submit {
    font-size: 1.6rem;
  }

  .contact_form {
    padding: 1rem;
  }
  .contact_form dt, .contact_form dd {
    padding: 1rem;
  }
  .contact_form dd:not(:last-of-type) {
    margin-bottom: 1rem;
  }

  #reservationHeader {
    padding: .5rem 6rem !important;
  }
}

/* スマホ - sp
-------------------------------------------------- */
@media ( width <= 360px ) {
  .main_logo {
    max-width: 140px;
  }
}