@charset "UTF-8";
/*スマホ用
----------------------------------*/
/*@media only screen and (max-width: 1035px) {
  .FEATURE-box .text {width: 100%;}
.FEATURE-box .right {width: 100%;}
.FEATURE-box .left {width: 100%;}  
}*/

@media only screen and (max-width: 1000px) {

header .head {background: #fff;}
header .read {font-size: 20px;}
header .contents {display: none;}
header .sp-logo-box {display: block;}
header .sp-logo-box h1 {width: 100%; text-align: center; padding: 40px 0; background: #2f373a;}
header .slide-area {padding: 0; background-size: 310%; height: 100vh; animation: none;}
header .slide-area .read {top: 175px;}
.scroll {bottom: 15%;}
.scroll img {width:35px;}
.contents ul.NEWS-area li span {margin-bottom: 15px; display: block;}
.contents {width: 90%; margin:0 5%;}
br.sp-br {display: block;}

.pc-zone {display: none;}

header h1.sp-index-logo {width: 100%; position: absolute; float: none; z-index: 999; text-align: center; padding: 100px 0;}





.news-sidebar {
    margin-left: 50px;
}












}






/* ===============================
   レスポンシブ対応
   =============================== */

@media screen and (max-width: 1266px) {
    .menu-item-type {
        min-width: 11rem;
    }
}
/* ======== タブレット (768px〜1023px) ======== */
@media screen and (min-width: 768px) and (max-width: 1023px) {
    /* ======== フォントサイズ設定  ======== */
    html {
        font-size: 55%;
    }
    /* ======== デザイン設定  ======== */
    #mainhead .head-mm-contents {
        flex-direction: column;
        align-items: center;
        padding: 20px;
    }
    .logoBox {
        width: 100%;
        text-align: center;
    }
    #mainhead .head-mm-contents .logo {
        width: 200px;
    }
    .headmenu {
        width: 100%;
        text-align: center;
    }
    .menu {
        justify-content: center;
        flex-wrap: wrap;
        gap: 10px;
    }
    .menu-item-type {
        min-width: auto;
        padding: 8px 10px;
    }
    .menu .sub-menu {
        min-width: 220px;
        left: 50%;
        transform: translateX(-50%);
    }
    .language-btn-wrapper {
        padding-right: 20px;
    }
    #mainfoot .head-mm-contents {
        display: block;
    }
    .services-grid,.news-section,.resources-section,.ser-hkatte ,.company-info-container,.grniit ,.main-back-inline ,.news-content,.news-section-single,.contact-section{
        width: 90%;
    }
    .main-back-inline {
        width: 90%;
    }
    .resources-grid {
        gap: 1rem;
        grid-template-columns: repeat(2, 1fr);
    }
    #mainfoot .head-mm-contents .menuWrap {
        display: none;
    }
    .companyinfo {
        text-align: left;
    }
    #mainfoot .head-mm-contents .logo {
        display: block;
        margin: 5px auto 30px;
        width: fit-content;
    }
    .btn-border {
        width: 115px;
    }
    .vuyv {
        width: 90px;
    }
    .hero-content p {
       font-size: clamp(2rem, 2vw + 1rem, 2.6rem);
    }
    .third-side {
        left: 14%;
    }
    /* ========== スマホメニュー（アコーディオン）設定 ========== */
    .service-submenu {
        display: none; 
        max-height: 0;
        opacity: 0;
        overflow: hidden;
        transition: max-height 0.35s ease, opacity 0.25s ease;
        padding-left: 15px;
    }
    .service-submenu.open {
        opacity: 1;
    }
    .service-submenu li {
        padding: 5px 0;
    }
    .service-submenu li a {
        font-size: 1rem;
        color: #333;
        text-decoration: none;
    }
    .service-submenu li a:hover {
        text-decoration: underline;
    }
    .header-submenu-toggle-btn {
        display: inline-block;
        position: relative;
        width: 22px;
        height: 22px;
        cursor: pointer;
        flex-shrink: 0;
    }
    .header-submenu-toggle-btn::before,
    .header-submenu-toggle-btn::after {
        content: "";
        position: absolute;
        background-color: #000;
        width: 14px;
        height: 2px;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        transition: transform 0.25s ease, opacity 0.25s ease;
    }
    .header-submenu-toggle-btn::after {
        transform: translate(-50%, -50%) rotate(90deg);
    }
    .header-submenu-toggle-btn.active::after {
        transform: translate(-50%, -50%) rotate(0deg);
        opacity: 0;
    }
    .service-list-wrapper {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
}

@media (max-width: 1179px) {
  .hero-content p {
    font-size: 2.6rem;
  }
}

/* 880px未満でさらに縮める */
@media (max-width: 879px) {
  .hero-content p {
    font-size: 2.1rem;
  }
}


   

/* ======== モバイル (〜767px) ======== */
@media screen and (max-width: 768px) {
    .sp-zone {display: block;}
    header .sp-navi {display: block;}

    /*btn-navi*/
    .Btn-navi {padding: 10px 5px; right: 10px; bottom: 15%; position: fixed; background: #02b9ee; width: 40px; display:block; line-height:1em; z-index:9999; transition: .3s; box-shadow: 0px 0px 4px rgba(255, 255, 255, 1); border-radius: 4px;}
    .Btn-navi .name {font-weight: bold; position: relative; bottom: -25px; vertical-align:middle; text-align:center; color:#ffffff; font-size:7.3px; line-height: 1em; }
    .Btn-navi .menuBtn {display: inline-block; position: relative; width: 40px; height:30px;}
    .menu-icon {display: block; position: absolute; top: 20%; left: 50%; width: 24px; height: 2px; margin: -1px 0 0 -12px; background: #ffffff; transition: .2s;}
    .menu-icon:before,.menu-icon:after {display: block; content: ""; position: absolute; top: 50%; left: 0; width: 24px; height: 2px; background: #ffffff; transition: .3s;}
    .menu-icon:before {margin-top: -8px;}
    .menu-icon:after {margin-top: 6px;}
    .menuBtn:hover .menu-icon:before {margin-top: -10px;}
    .menuBtn:hover .menu-icon:after {margin-top: 8px;}
    .Btn-navi.close .name { color:#ffffff; overflow: hidden; left: 0px; width: 100%; font-size: 7.3px; line-height: 10px; text-align: center; font-weight: bold; height: 8px;}
    .Btn-navi.close .name:before {display: block; content: 'CLOSE'; overflow: hidden; margin-right: 0px; }
    .Btn-navi.close .menu-icon:before,.Btn-navi.close .menu-icon:after {background: #ffffff;}
    .Btn-navi.close .menuBtn .menu-icon {background: transparent;}
    .Btn-navi.close .menuBtn .menu-icon:before, .Btn-navi.close .menuBtn .menu-icon:after {margin-top: 0;}
    .Btn-navi.close .menuBtn .menu-icon:before { -webkit-transform: rotate(-45deg); transform: rotate(-45deg);}
    .Btn-navi.close .menuBtn .menu-icon:after { -webkit-transform: rotate(-135deg); transform: rotate(-135deg);}
    #mainhead .Btn-navi{ position: absolute; left:5px; top:5px; }
    #mainhead .Btn-navi.close { opacity: 0; display: none;}
    #fixBtn-navi {position: fixed;  width: auto; bottom: 20px; right:15px;}
    #fixBtn-navi.Btn-navi .menuBtn { display: block; background-color:#333; border-radius: 10px; padding:10px 0px 0px;}
    #fixBtn-navi.Btn-navi .menuBtn .menu-icon {margin-top: -6px;}
    #fixBtn-navi .menu-icon,#fixBtn-navi .menu-icon:before,#fixBtn-navi .menu-icon:after {background-color: #ffffff;}
    #fixBtn-navi .menu-icon:before{margin-top: -7px;}
    #fixBtn-navi .menu-icon:after {margin-top: 5px;}
    #fixBtn-navi.close .menu-icon:before,#fixBtn-navi.close .menu-icon:after {margin-top: 0;}
    #fixBtn-navi.close .menu-icon {background: transparent;}
    #fixBtn-navi .name { color: #ffffff; display: block; position: relative; left:0px; bottom: -17px;}
    #fixBtn-navi .name:before { display: inline; content: 'MENU';}
    #fixBtn-navi.close .name:before { display: inline; content: 'CLOSE';}
    #fixBtn-navi.close .name { color: #ffffff;}
    #cavor.Btn-navi {width: 100%; height: 100%; position: fixed; top:0px; left: -100%; transition:0s;  z-index: 999;}
    #cavor.Btn-navi .menuBtn {display:block; width: 100%; height: 100%; background:rgba(255,255,255,0.6); }
    #cavor.close { left: 0px; }
    .navi {
        background-color: #02b9ee; /*メニュー背景色*/
        box-sizing: border-box;
        height: 100%;
        padding: 5%; /*メニュー内部上下左右余白*/
        position: fixed;
        left: -70%; /*メニュー横幅①と合わせる*/
        top: 0;
        transition: .2s; /*0.3s は変化するのにかかる時間*/
        width: 70%; /*メニュー横幅①*/
        z-index: 1000;
    }
    .Btn-navi:hover + .navi-background {
        opacity: 0.5; /*黒背景部分透過度*/
        z-index: 999;
    }
    /*.navi-background {width: 100%; height: 100%; position: fixed; top: 0px; left: 0%; transition: 0s; z-index: 999;}*/
    .navi-background a.background-btn{display: block; width: 100%; height: 100%; background: rgba(255,255,255,0.6);}
    .navi.open { left: 0; }
    .navi-background {z-index: 999; display: none; position: fixed; width: 100%; height: 100%; top: 0; left:0; }
    .navi-background.open {display: block; background: rgba(255,255,255,0.6); }
    .navi.open {padding-bottom: 10px; padding-top: 30px; text-align: center;         overflow-y: scroll;}


    .Btn-navi_first {padding: 5px; background: #816a29; width: 40px; display:none; line-height:1em; z-index:9999; transition: .3s;}
    .Btn-navi_first .name { vertical-align:middle; text-align:center; color:#ffffff; font-size:7.3px; line-height: 1em; }
    .Btn-navi_first .menuBtn {display: inline-block; position: relative; width: 40px; height:30px;}
    /*footer .navi ul {display: block; padding: 30px 0px;}*/
    footer .navi ul {
        font-size: 12px;
        height: 280px;
        overflow: auto;
        /* background-color: #FFF; */
        padding: 10px 10px;
        margin-bottom: 15px;
        /* border: 1px solid #CCC; */
        display: block;
        padding: 30px 0px;
    }
    /* ======== フォントサイズ設定  ======== */
    html {
        font-size: 40%;
    }   
    .hero-content p {
        font-size: clamp(1.4rem, 3vw + 1rem, 2rem);
    }
    /* ======== デザイン設定  ======== */
    .single-pagination a,.previouspostslink,.listpage-link,.nextpostslink {
        width: 130px;
    }
    #mainhead .head-mm-contentss {
        flex-direction: column;
        align-items: flex-start;
        padding: 10px 20px;
    }
    .about-content  {
        width: 85%;
    }
    .logoBox {
        width: 100%;
        text-align: left;
    }
    #mainhead .head-mm-contents .logo {
        width: 180px;
    }
    #mainfoot .head-mm-contents {
        display: block;
    }
    #mainfoot .head-mm-contents .menuWrap {
        display: none;
    }
    .services-grid,.news-section,.resources-section,.ser-hkatte,.company-info-container,.grniit ,.main-back-inline ,.news-content,.news-section-single,.contact-section{
        width: 90%;
    }    
    .headmenu {
        display: none;
    }
    .resource-card {
        margin-bottom: 30px;
    }
    .btn-border {
        width: 100px;
    }
    .vuyv {
        width: 60px;
    }
    #mainhead .head-mm-contents {
        padding-bottom: 0px;
    }
    .about-section {
        padding: 50px 0;
    }
    .tab-content {
        padding: 5px 10px;
    }
    .section-title {
        margin-bottom: 50px;
    }
    .services-section {
        padding: 50px 0;
    }
    .news-item {
        gap: 0;
    }
    .news-content-e {
        height: auto;
    }
    .essdd {
        margin-bottom: 50px;
    }
    .enis {
        padding-top: 50px;
    }
    .res-btn {
        padding-bottom: 50px;
        padding-top: 20px;
    }
    .resources-grid {
        display: block;
    }
    .service-title {
        height: 140px;
    }
    .ser-main-title {
        margin-top: 50px;
    }
    .ser-hkatte {
        padding-top: 50px;
    }
    .dmah-ser {
        display: block;
        margin-bottom: 50px;
    }
    .ser-main-title {
        width: 90%;
    }
    .dmah-ser-2 {
        display: block;
    }
    .thain-2 {
        padding-bottom: 30px;
    }
    .nfseiudvnbz {
        margin-top: 3rem;
    }
    .small-text {
        font-size: 2.2rem;
    }
    .semi-small-text ,.checklist-item ,.statutory-section div ,.difference-heading{
        font-size: 2.2rem;
    }
    .retention-requirements {
        font-size: 1.9rem;
    }
    .list-fact-2 {
        font-size: 2rem;
    }
    .resource-text {
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .resource-text p {
        padding: 3rem;
    }
    .rid-container:not(:last-child) {
        padding-bottom: 30px;
    }
    .resource-bottom,.pmaext-list,.rounder-medisuth {
        padding-bottom: 50px;
    }
    .thund-esr {
        padding-bottom: 0;
    }
    .big-text {
        margin-top: 3rem;
    }
    .hsnere {
        padding-top: 30px;
        padding-bottom: 30px;
    }
    .dmah-image {
        margin-bottom: 30px;
    }
    .service-content p {
        font-size: 2.2rem;
    }
    .service-content h3 {
        font-size: 3.1rem;
    }
    .side-fix {
        display: block;
        height: 62px;
        min-width: 300px;
    }
    .tab-btn.active {
        padding: 0;
        height: 57px;
    }
    .check-container {
        display: block;
        padding-bottom: 20px;
    }
    .dotted-border::before {
        width: 10px;
        height: 10px;
    }
    .check-list-main:not(:last-child) {
        margin-bottom: 30px;
    }
    .check-list-main-title {
        margin-bottom: 10px;
    }
    .side-fix-title br {
        display: none;
    }
    .ser-main-title{
        font-size: 3rem;
    }
    .flex-erry {
        padding-bottom: 30px;
    }
    .first-side {
        top: 38%;
        left: 14%;
    }
    .second-side {
        left: 25%;
        top: 38%;
    }
    .third-side {
        top: 38%;
        left: 8%;
    }
    .forth-side {
        left: 40%;
        top: 36%;
    }
    .side-fix-title {
        font-size: 2.3rem;
    }
    .list-fact::before {
        left: 7px;
        top: 10px;
        width: 10px;
        height: 10px;
    }
    .list-fact-2::before {
        left: 5px;
        top: 8px;
        width: 7px;
        height: 7px;
    }
    .btn-guide {
        padding-top: 50px;
        margin-bottom: 50px;
    }
    .guide-text {
        padding-bottom: 30px;
        width: 90%;
        margin-left: auto;
        margin-right: auto;
    }
    .page-service-section section {
        padding-bottom: 30px;
    }
    #mainfoot .head-mm-contents .logo {
        display: block;
        margin: 5px auto 30px;
        width: fit-content;
    }
    .pagination-ret{
        padding-bottom: 50px;
    }
    .pagination-ret .nav-links .dots {
        position: relative;
        top: 1rem;
    }
    .pagination-ret .nav-links .page-numbers {
        line-height: 1.8;
    }
    .archive-header {
        margin-top: 100px;
    }
    /* ========== スマホメニュー（アコーディオン）設定 ========== */
    .service-submenu {
        display: none; 
        max-height: 0;
        opacity: 0;
        overflow: hidden;
        transition: max-height 0.35s ease, opacity 0.25s ease;
        padding-left: 15px;
    }
    .service-submenu.open {
        opacity: 1;
    }
    .service-submenu li {
        padding: 5px 0;
    }
    .service-submenu li a {
        font-size: 1rem;
        color: #333;
        text-decoration: none;
    }
    .service-submenu li a:hover {
        text-decoration: underline;
    }
    .header-submenu-toggle-btn {
        display: inline-block;
        position: relative;
        width: 22px;
        height: 22px;
        cursor: pointer;
        flex-shrink: 0;
    }
    .header-submenu-toggle-btn::before,
    .header-submenu-toggle-btn::after {
        content: "";
        position: absolute;
        background-color: #000;
        width: 14px;
        height: 2px;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        transition: transform 0.25s ease, opacity 0.25s ease;
    }
    .header-submenu-toggle-btn::after {
        transform: translate(-50%, -50%) rotate(90deg);
    }
    .header-submenu-toggle-btn.active::after {
        transform: translate(-50%, -50%) rotate(0deg);
        opacity: 0;
    }
    .service-list-wrapper {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .navi:before {
        display: block;
        content: 'MENU';
        padding: 20px 0px;
        text-align: center;
        font-size: 20px;
        font-weight: bold;
        color: #ffffff;
        border-bottom: 1px solid #02b9ee;
    }
    .navi ul {
        display: block;
        margin: 0px;
        width: 100%;
        box-sizing: border-box;
    }
    .clearfix {
    min-height: 1px;
    }
    .navi ul li {
        padding: 0;
        display: block;
        border-right: none;
        font-size: 1em
    }
    .navi ul li a, .navi ul li div {
        color: #ffffff;
        display: block;
        padding: 10px 5px;
        font-size: 2.5rem;
        border-bottom: 1px solid #fff;
        text-align: left;
        font-weight: 700;
    }
    .navi ul li span {
        color: #ffffff;
        font-size: 12px;
        letter-spacing: 2px;
    }
    .navi ul li .sub-menu-ham {
        padding-left: 0;
    }
    .navi ul li .sub-menu-ham {
        margin: 0px;
    }
    .navi ul li .sub-menu-ham li {
        margin-top: 0;
    }
    .navi ul li .sub-menu-ham li {
        list-style: disc;
        padding-bottom: 0px;
    }
    .navi ul li .sub-menu-ham li a {
        padding-left: 20px;
    }
    .news-content {
        display: block;
        font-size: 2.2rem;
    }
    .news-sidebar {
        margin-left: 0;
        width: 100%;
    }
    .archive-list {
        width: 100%;
    }
    .officer-item {
        display: block;
    }
    .info-his-value {
        padding: 10px;
    }
    .affiliated-companies {
        display: block;
    }
    .company-card {
        padding-bottom: 30px;
    }
    .business-partner-section {
        margin: 80px auto 250px;
    }
    .affiliated-section {
        margin: 20px auto;
        padding-top: 50px;
    }
    .grniit {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .sub-title-virticle::before {
        top: calc(1em - 1px);
        width: 7px;
        height: 7px;
    }
    .service-title-i{
        padding-top: 20px;
    }
    .service-sab-title {
        padding: 0 70px 70px;
    }
    .read-more-btn {
        top: 27%;
        font-size: 2rem;
    }
    #mainfoot .head-mm-contents .companyinfo p {
        font-size: 2.5rem;
    }
    .read-more-btn::after {
        top: 1px;
    }
    .service-card {
        display: block;
    }
    .service-card .service-image {
        padding-bottom: 30px;
    }
    .head-more-btn {
        top: 23%;
    }
    #mainfoot .head-mm-contents .logo svg { 
        height: 40px;
    }
    .resource-content h4 {
        font-size: 3.1rem;
    }
    .resource-content p {
        font-size: 2.2rem;
    }
    .news-item-arc {
        padding-left: 5px;
        gap: 0.5rem;
        display: grid;
        height: 70px;
    }
    .news-date-arc {
        width: auto;
    }
    .marve {
        height: 70px;
    }
    .archive-item p {
        padding: 28px 5px;
    }
    .archive-header p  {
        left: 30%;
    }
}
/* 452px未満（スマホ縦）で固定 */
@media (max-width: 452px) {
    .single-pagination a,.previouspostslink,.listpage-link,.nextpostslink {
        width: 90px;
    }
    .contact-section p {
        font-size: 1.8rem;
    }
 .hero-content p {
    font-size: 1.5rem;
  }
  .neusode tr th {
    padding: 10px 10px;
  }
  .main-table-body tr td {
    padding: 10px 10px;
  }
  .news-item-arc {
        padding-left: 5px;
        gap: 0.5rem;
        display: grid;
        height: 70px;
    }
    .news-date-arc {
        width: auto;
    }
    .marve {
        height: 70px;
    }
    .archive-item p {
        padding: 28px 5px;
        font-size: 1.8rem;
    }
    .archive-header p  {
        left: 30%;
    }
    .news-content {
        display: block;
        font-size: 1.8rem;
    }
    .info-his-label {
        width: 60px;
    }
    .map-placeholder {
        height: 400px;
    }
    .trniesaa {
        padding-top: 50px;
    }
    .partner-link {
        padding-top: 15px;
    }
    .big-btn-border {
        padding: 6px 17px;
    }
    .big-read-more-btn {
        font-size: 2rem;
    }
}