@charset "UTF-8";
@media only screen and (max-width : 1215px) {}
/*--------------------------------------------------------
モバイル用レイアウト667px以下
--------------------------------------------------------*/
@media only screen and (max-width : 667px) {
  /*--------------------------------------------------------
サイト全体
-------------------------------------------------------*/
  html, body {
    overflow-y: scroll;
    overflow-x: hidden;
      font-weight: 400;
  }
  p {
    font-size: 15px;
    line-height: 2rem;
    letter-spacing: .3px;
  }
  .pc {
    display: none;
  }
  /*--------------------------------------------------------
ヘッダー
-------------------------------------------------------*/
  .header_inner {
    padding: 1rem;
  }
  .fixed .logo {
    margin-top: 0;
    padding-top: 0;
  }
  .l-header__logo__symbol {
    width: 3rem;
  }
  .l-header__logo__txt {
    width: 13rem;
  }
  .fixed .l-header__logo__symbol {
    width: 2rem;
  }
  .fixed .l-header__logo__txt {
    width: 9rem;
  }
  .fixed.header_inner {
    padding: 1rem;
    height: 60px;
  }
  .nav-button {
    display: block;
    cursor: pointer;
    transition: 1s;
  }
  .header_menu {
    position: fixed;
    left: 0;
    top: 0;
    display: none;
    z-index: 10;
    background-color: #fff;
    width: 100%;
    height: 100%;
    transition: 1s;
    padding-top: 25%;
    overflow-x: hidden;
    overflow-y: auto;
  }
  .header_menu li {
    display: block;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: solid .5px #999;
    position: relative;
  }
  .header_menu li a {
    color: #333;
    font-size: 16px;
  }
  .header_menu li a:after {
    position: absolute;
    right: 5%;
    top: auto;
    font-family: "Material Icons";
    content: "\eaaa";
  }
  .header_menu li a::before {
    content: "●";
    font-size: 12px !important;
    color: #ff98b5;
    margin-right: .5rem;
  }
  .header_menu.open {
    display: block;
  }
  .header_menu.close {
    display: none;
  }
  /*メニューボタン*/
  .nav-button, .nav-button span {
    display: inline-block;
    transition: all 0.4s;
    box-sizing: border-box;
  }
  .nav-button {
    z-index: 20;
    position: relative;
    width: 35px;
    height: 30px;
  }
  .nav-button span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #f0008a;
    border-radius: 4px;
  }
  .nav-button span:nth-of-type(1) {
    top: 0;
  }
  .nav-button span:nth-of-type(2) {
    top: 14px;
  }
  .nav-button span:nth-of-type(3) {
    bottom: 0;
  }
  .nav-button.active span:nth-of-type(1) {
    -webkit-transform: translateY(13px) rotate(-45deg);
    transform: translateY(13px) rotate(-45deg);
  }
  .nav-button.active span:nth-of-type(2) {
    opacity: 0;
  }
  .nav-button.active span:nth-of-type(3) {
    -webkit-transform: translateY(-15px) rotate(45deg);
    transform: translateY(-15px) rotate(45deg);
  }
  .information_wrap, footer .cont_wrap {
    width: 100%;
  }
  /*--------------------------------------------------------
TOP
-------------------------------------------------------*/
  .kv_wrap {
    background: url("../images/top/kv_01_sp.jpg") no-repeat center center / cover;
    height: 100vh;
  }
  .kv_contents {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    top: 35%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
  }
  .cont_01_inner {
    background: url("../images/top/bg_02_sp.png") no-repeat center top / 100% auto;
  }
  .about_greeting {
    display: block;
  }
  .about_greeting_contents {
    width: 100%;
  }
  .sakura_txt {
    padding: 7rem 2rem 0rem;
  }
  .about_greeting {
    padding: 2rem;
  }
  .about_greeting p.purple {
    font-size: 25px;
    line-height: 2.5rem;
    margin-bottom: 2rem;
  }
  .about_greeting p, .about_greeting h2 {
    font-size: 16px;
    line-height: 1.6rem;
  }
  .more_btn {
    width: 140px;
    height: 140px;
  }
  .more_btn a {
    height: 140px;
    font-size: 12px;
  }
  .cont_01 {
    padding-bottom: 8rem;
  }
  .cont_03 ul {
    display: block;
    height: auto;
  }
  .cont_03 li {
    height: 50vh
  }
  .service_catch {
    right: 2.3rem;
      top: 2rem;
  }
  .service_catch span {
    font-size: 1.2rem;
    line-height: 3rem;
  }
  .main_title {
    font-size: 24px;
  }
  .cont_04 {
    padding: 6rem 2.5rem;
  }
  .cont_04 ul {
    flex-wrap: wrap;
  }
  .cont_04 li {
    width: 47%;
  }
  .cont_04 li h4 {
    font-size: 15px;
    line-height: 1.3rem;
  }
  .cont_04 li p {
    font-size: 13px;
    line-height: 1.3rem;
  }
  .cont_05, .cont_07 {
    padding: 6rem 2.5rem;
  }
  .cont_05 ul {
    display: block;
  }
  .cont_05 li {
    width: 100%;
  }
  .cont_05 li a {
    padding: 1.5rem 0 2rem 40px;
    background-size: 30px auto;
  }
  .cont_05 li a h5 {
    font-size: 18px;
  }
  .cont_06, .cont_08, .cont_10, .contact_area, .information {
    padding: 6rem 2.5rem;
  }
  .cont_06 ul {
    display: block;
  }
  .cont_06 li {
    width: 100%;
    height: 300px;
    padding-top: 3.3rem;
  }
  .cont_06 li h3 {
    font-size: 1.5rem;
    line-height: 3rem;
  }
    .cont_10 .mb60{
        margin-bottom: 30px;
    }
    .cont_09 {
  height: 50vh;
}
  .advantage_box {
    margin-top: 3rem;
  }
  .advantage_box .text {
    width: 100%;
  }
  .advantage_box {
    flex-direction: column;
  }
  .advantage_box:nth-child(even) {
    flex-direction: column;
  }
  .text {
    margin-bottom: 2rem;
  }
  .advantage_box:nth-child(even) .text {}
  .advantage_box:nth-child(even) .pict {
    margin-left: 0;
    margin-right: 0%;
  }
  .advantage_box .pict, .pict img {
    width: 100%;
  }
  .advantage_box h3 {
    font-size: 22px;
    margin-bottom: 1rem;
  }
  .news {
    display: block;
    padding: 1rem 3rem 1rem 0;
  }
  time {
    font-size: 13px;
    display: inline-block;
  }
  .category {
    font-size: 11px;
    margin-left: .5rem;
    display: inline-block;
    padding: .5px 20px;
  }
  .news h5 {
    font-size: 16px;
    margin-left: 0;
  }
  .jp_title {
    margin-bottom: 2rem;
  }
  .blog {
    display: block;
  }
  .blog dl {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin-bottom: 1.5rem;
  }
  .blog dt {
    width: 40%;
  }
  .blog dd {
    width: 57%;
  }
  .blog dt img {
    height: 135px;
  }
  .blog dd h5 {
    font-size: 14px;
    line-height: 1.3rem;
  }
  .view_btn {
    margin: 0 auto 5rem;
  }
  .cont_10 dd {
    padding-left: 0;
    margin-top: 1rem;
  }
  .pink_title {
    font-size: 2rem;
  }
  .sub_title {
    font-size: .8rem;
  }
  .biz-hour {
    width: 100%;
    display: block;
  }
  .biz-hour th, .biz-hour td {
    padding: 10px;
  }
  .cont_10 .img_round img {
    width: 100%;
    height: 300px;
    object-fit: cover;
  }
  .contact_area h5 {
    font-size: 2rem;
    line-height: 3rem;
  }
  .contact_area ul {
    display: block;
  }
  .contact_area li {
    width: 100%;
    margin: 3rem 0 1rem;
  }
  a.btn-c {
    font-size: 1.5rem;
  }
  .information h3 {
    font-size: 1rem;
  }
  .information h4 {
    font-size: .8rem;
  }
  .information h4 {
    font-size: 1rem;
    margin-bottom: 1rem;
  }
    .category_txt{
        font-size: 12px;
        display: block;
    }
   .category_txt .material-symbols-outlined {
  font-size: 20px;
    }
    .sp_mb3{
        margin-bottom: 3rem;
    }
  /*--------------------------------------------------------
footer
-------------------------------------------------------*/
  .footer_bnr li {
    width: 100%;
    margin-bottom: 1rem;
  }
  .footer_bnr, footer {
    padding: 3rem 2.5rem;
  }
  footer {
    background: url("../images/top/bg_02_sp.png") no-repeat center bottom / cover;
  }
    footer li{
        margin-bottom: 15px;
    }
  footer li a {
    color: #333;
    font-size: 13px;
  }
  /*--------------------------------------------------------
page
-------------------------------------------------------*/
  .page_contant_wrap {
    margin-top: 150px;
  }
  .page_kv dl {
    display: block;
    margin-bottom: 0;
  }
  .page_kv dl dd {
    width: 90%;
  }
  .page_kv dl dt {
    width: 100%;
    text-align: right;
    padding: 3%;
    margin-bottom: 1rem;
  }
  .page_kv dl dd img {
    border-radius: 0 20px 20px 0;
    height: 250px;
    object-fit: cover;
  }
  .catch_title {
    font-size: 1.5rem;
  }
  .page_title {
    font-size: 24px;
    line-height: 2.4rem;
  }
  .page_wrap {
    padding: 10% 7%;
  }
  .message dl {
    display: block;
  }
  .message dt {
    width: 70%;
    margin: 0 auto 1rem;
  }
  .message dd {
    width: 100%;
  }
  .message dl h3 {
    font-size: 23px;
    line-height: 2rem;
    margin-top: 2rem;
  }
  .flex_padding {
    padding: 0;
  }
  .flow dd a {
    display: block;
    padding: 3% 5%;
  }
  .staff li {
    width: 48%;
  }
.name {
  line-height: 2rem;
}
  .recruit_detail th, .recruit_detail td {
    display: block;
    width: 100%;
    text-align: left;
  }
  .recruit_detail th {
    border-bottom: none;
  }
  .point_box {
    padding: 10%;
    margin-top: 60px;
  }
  .page-numbers, .page-numbers.current {
    padding: 5px 10px; /* パディングを小さく */
  }
  .breadcrumbs {
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }
  .breadcrumbs li a {
    margin: 0 10px;
  }
}