@charset 'UTF-8';


/* font
----------------------------------------------------------------*/

.gill-book{
    font-family: gill-sans-nova, sans-serif;
font-weight: 400;
font-style: normal;
}


/* animation
----------------------------------------------------------------*/
@keyframes fadeIn{
    0%{
        opacity: 0;
    }
    100%{
        opacity: 1;
    }
}

@keyframes fadeOut{
    0%{
        opacity: 1;
    }
    100%{
        opacity: 0;
    }
}
@-webkit-keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInRight {
  -webkit-animation-name: slideInRight;
  animation-name: slideInRight;
}
@-webkit-keyframes slide-in-left{
    0%{transform:translateX(-100%)}to{transform:translateX(0)}
}
@keyframes slide-in-left{
    0%{transform:translateX(-100%)}to{transform:translateX(0)}
}
@-webkit-keyframes slide-fade-in-left{
    0%{opacity:0;transform:translateX(-2rem)}to{opacity:1;transform:translateX(0)}
}
@keyframes slide-fade-in-left{
    0%{opacity:0;transform:translateX(-2rem)}to{opacity:1;transform:translateX(0)}
}
@-webkit-keyframes slide-in-right{
    0%{transform:translateX(100%)}to{transform:translateX(0)}
}
@keyframes slide-in-right{
    0%{transform:translateX(100%)}to{transform:translateX(0)}
}

.animated {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}
.animated.delay-025s {
  -webkit-animation-delay: 0.25s;
  animation-delay: 0.25s;
}
.animated.delay-05s {
  -webkit-animation-delay: 0.5s;
  animation-delay: 0.5s;
}
.animated.delay-1s {
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
}
.animated.delay-2s {
  -webkit-animation-delay: 2s;
  animation-delay: 2s;
}
.animated.delay-3s {
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
}
.animated.delay-4s {
  -webkit-animation-delay: 4s;
  animation-delay: 4s;
}
@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(2vw);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(2vw);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}


@media screen and (min-width: 769px) {

@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(1vw);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(1vw);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

}

.fadeInUp {
    -webkit-animation-name: fadeInUp;
    animation-name: fadeInUp;
}



@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}
.fadeIn {
    -webkit-animation-name: fadeIn;
    animation-name: fadeIn;
    -webkit-animation-duration: 2s;
    animation-duration: 2s;
}



/* Preferences
----------------------------------------------------------- */
* {
    margin: 0;
    padding: 0;
}
/* html5 reset css */
html, body, div, span, object, iframe,h1, h2, h3, h4, h5, h6, p, a, blockquote, pre,abbr, address, cite, code,del, dfn, em, img, ins, kbd, q, samp,small, strong, sub, sup, var,b, i,dl, dt, dd, ol, ul, li,fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td,article, aside, dialog, figure, footer, header,hgroup, menu, nav, section,time, mark, audio, video { margin: 0; padding: 0; border: 0; outline: 0; vertical-align: baseline; background: transparent; } article, aside, dialog, figure, footer, header,hgroup, nav, section {display:block;} nav ul {list-style:none;} blockquote, q {quotes:none;} blockquote:before, blockquote:after,q:before, q:after { content:''; content:none; } ins { background-color:#ff9; color:#000; text-decoration:none; } mark { background-color:#ff9; color:#000; font-style:italic; font-weight:bold; } del {text-decoration: line-through;} abbr[title], dfn[title] { border-bottom:1px dotted #000; cursor:help; } hr { display:block; height:1px; border:0; border-top:1px solid #cccccc; margin:1em 0; padding:0; } input, select {vertical-align:middle;} 
/* //html5 reset css */

html {
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
}
main{
    
}
body {
    font-family: 'Noto Sans JP', "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 15px;
    line-height: 1.8666667;
    font-weight: 500;
    position: relative;
    word-break: break-word;
    color: #000000;
    /*font-feature-settings: "palt";*/
    letter-spacing: 0.25px;
}
h1,h2,h3,h4,h5,h6{
    font-size: 100%;
    font-weight: 700;
}
table{
    border-collapse: collapse;
    width: 100%;
}
ul{
    list-style: none;
}
ol{
    list-style: none;
}
img{
    max-width: 100%;
    height: auto;
    border: 0;
    vertical-align: middle;
}
a{
    color: #1f140f;
    text-decoration: none;
    outline: none;
    display: block;
    transition: all .5s;
}
p{
    /* margin-bottom: 1em; */
}
blockquote{
    margin: 0 0 1rem;
    padding: 1rem;
    background: rgba(255,255,255,0.1);
}
blockquote p{margin: 0;}

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

    body{
        width: 1200px;
    }

}

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

    main {
    }
    body{
        width: 100%;
        font-size: 14px;
        letter-spacing: 0;
    }

}

/* public css
----------------------------------------------------------------*/
.clear{clear: both;}
.cf:after {visibility: hidden;display: block;font-size: 0;content: " ";clear: both;height: 0;overflow: hidden;}
* html .cf{ zoom: 1; } /* ie6 */
*:first-child+html .cf { zoom: 1; } /* ie7 */

.alignleft{float: left; margin-right: 40px;}
.alignright{float: right; margin-left: 40px;}
.aligncenter{text-align: center; display: block; margin-left: auto; margin-right: auto; }
@media screen and (max-width: 600px) {
    .alignleft{
        float: none;
        margin-right: 0;
    }
    .alignright{
        float: none;
        margin-left: 0;
    }
}

.middle{
    vertical-align: middle;
}
.center{text-align: center !important;}
.left{text-align: left !important;}
.right{text-align: right !important;}
.red{color: #d70e19;}
.medium{font-weight: 500;}
.bold700{font-weight: 700;}
.bold500{font-weight: 500;}
.small{font-size: 12px;}

.fright{float: right;}
.fleft{float: left;}

.white{
    color: #fff !important;
}
.red{
    color: #ff0000;
}
.text-green {
    color: #1F8A05;
}

ul.disc{
    list-style: disc;
    margin-left: 1.1rem;
}
ul.number{
    list-style: decimal;
    margin-left: 1.3rem;
}
ul.en{
    list-style: lower-alpha;
    margin-left: 1.3rem;
}

.en{
    
}
.jp{

}

.sh{
    position: absolute !important;
    clip: rect(1px 1px 1px 1px);
}

/*space*/
.mt0{margin-top: 0;}.mt5{margin-top: 5px;}.mt10{margin-top: 10px;}.mt15{margin-top: 15px;}.mt20{margin-top: 20px;}.mt25{margin-top: 25px;}.mt30{margin-top: 30px;}.mt35{margin-top: 35px;}.mt40{margin-top: 40px;}.mt45{margin-top: 45px;}.mt50{margin-top: 50px;}.mt100{margin-top: 100px;}
.mr0{margin-right: 0;}.mr5{margin-right: 5px;}.mr10{margin-right: 10px;}.mr15{margin-right: 15px;}.mr20{margin-right: 20px;}.mr25{margin-right: 25px;}.mr30{margin-right: 30px;}.mr35{margin-right: 35px;}.mr40{margin-right: 40px;}.mr45{margin-right: 45px;}.mr50{margin-right: 50px;}.mr100{margin-right: 100px;}
.mb0{margin-bottom: 0;}.mb5{margin-bottom: 5px;}.mb10{margin-bottom: 10px;}.mb15{margin-bottom: 15px;}.mb20{margin-bottom: 20px;}.mb25{margin-bottom: 25px;}.mb30{margin-bottom: 30px;}.mb35{margin-bottom: 35px;}.mb40{margin-bottom: 40px;}.mb45{margin-bottom: 45px;}.mb50{margin-bottom: 50px;}.mb100{margin-bottom: 100px;}.ml0{margin-left: 0;}
.ml5{margin-left: 5px;}.ml10{margin-left: 10px;}.ml15{margin-left: 15px;}.ml20{margin-left: 20px;}.ml25{margin-left: 25px;}.ml30{margin-left: 30px;}.ml35{margin-left: 35px;}.ml40{margin-left: 40px;}.ml45{margin-left: 45px;}.ml50{margin-left: 50px;}.ml100{margin-left: 100px;}.pt0{padding-top: 0;}
.pt5{padding-top: 5px;}.pt10{padding-top: 10px;}.pt15{padding-top: 15px;}.pt20{padding-top: 20px;}.pt25{padding-top: 25px;}.pt30{padding-top: 30px;}.pt35{padding-top: 35px;}.pt40{padding-top: 40px;}.pt45{padding-top: 45px;}.pt50{padding-top: 50px;}.pt100{padding-top: 100px;}
.pr0{padding-right: 0;}.pr5{padding-right: 5px;}.pr10{padding-right: 10px;}.pr15{padding-right: 15px;}.pr20{padding-right: 20px;}.pr25{padding-right: 25px;}.pr30{padding-right: 30px;}.pr35{padding-right: 35px;}.pr40{padding-right: 40px;}.pr45{padding-right: 45px;}.pr50{padding-right: 50px;}.pr100{padding-right: 100px;}
.pb0{padding-bottom: 0;}.pb5{padding-bottom: 5px;}.pb10{padding-bottom: 10px;}.pb15{padding-bottom: 15px;}.pb20{padding-bottom: 20px;}.pb25{padding-bottom: 25px;}.pb30{padding-bottom: 30px;}.pb35{padding-bottom: 35px;}.pb40{padding-bottom: 40px;}.pb45{padding-bottom: 45px;}.pb50{padding-bottom: 50px;}.pb100{padding-bottom: 100px;}.pl0{padding-left: 0;}
.pl5{padding-left: 5px;}.pl10{padding-left: 10px;}.pl15{padding-left: 15px;}.pl20{padding-left: 20px;}.pl25{padding-left: 25px;}.pl30{padding-left: 30px;}.pl35{padding-left: 35px;}.pl40{padding-left: 40px;}.pl45{padding-left: 45px;}.pl50{padding-left: 50px;}.pl100{padding-left: 100px;}


/* 共通パーツ
----------------------------------------------------------------*/

.contents-inner {
    max-width: 1200px;
    margin: 0 auto;
}
.contents-inner-sm {
    max-width: 1000px;
    margin: 0 auto;
}

article#main-article{

}
article#main-article section{
  padding: 80px 0;
}

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

    .contents-inner{
      padding: 0 20px;
    }
    .contents-inner-sm{
      
    }

    article#main-article section{
      padding: 56px 0;
    }

}

/* base rayout */
.pc{
    display: block !important;
}
.sp{
    display: none !important;
}


@media screen and (max-width: 767px) {
    
    .pc{
        display: none !important;
    }
    .sp{
        display: block !important;
    }

}


/* section共通パーツ */
.section-head{
  text-align: center;
  margin-bottom: 40px;
}
.section-head-title{
  font-size: 32px;
  line-height: 1.35;
}
.section-head-description{
  font-size: 16px;
  font-weight: 500;
  margin-top: 12px;
}

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

    .section-head{
      margin-bottom: 28px;
    }
    .section-head-title{
      font-size: 24px;
    }
    .section-head-description{
      font-size: 14px;
      line-height: 1.5;
    }

}


/* ボタン */

.conversion-btn{
    margin-top: 24px;
}
.conversion-btn a{
    width: 462px;
    height: 76px;
    color: #fff;
    background: rgb(229,81,34);
    background: linear-gradient(180deg, rgba(255,127,64,1) 0%, rgba(229,81,34,1) 100%);
    border-radius: 80px;
    box-shadow: 4px 4px 20px rgba(0,0,0,0.3);
    margin: 0 auto;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
}
.conversion-btn a:hover{
    background: rgb(64,64,64);
    background: linear-gradient(180deg, rgba(64,64,64,1) 0%, rgba(0,0,0,1) 100%);
}
.conversion-btn-free{
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: #FFEA2A;
    font-weight: 900;
    font-size: 19px;
    line-height: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    left: 8px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    color: #000;
}
.conversion-btn-text{
    text-align: center;
    font-size: 20px;
    line-height: 1.5;
    font-weight: 700;
}
.conversion-btn-arrow{
    width: 60px;
    height: 60px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.conversion-btn-arrow .material-symbols-outlined {
    font-size: 32px;
    font-weight: 600;
}

@media screen and (max-width: 767px) {
    
    .conversion-btn {
      margin-top: 24px;
    }
    .conversion-btn a{
      width: 100%;
      height: 64px;
    }
    .conversion-btn-free{
      width: 48px;
      height: 48px;
      font-size: 15px;
    }
    .conversion-btn-text{
      font-size: 16px;
    }
    .conversion-btn-arrow {
      width: 48px;
      height: 48px;
    }
    .conversion-btn-arrow .material-symbols-outlined {
      font-size: 24px;
    }

}



/* header
----------------------------------------------------------------*/

header{
  position: absolute;
  top: 0;
  left: 0;
  /* width: 100%; */
}
.header-inner{
  padding: 22px 28px;
}

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

    .header-inner{
      padding: 14px 16px;
    }
    #header-logo{
      width: 80px;
    }


}




/* footer
----------------------------------------------------------------*/

footer {
    background: #222222;
    padding: 72px 0 56px;
}
.footer-inner{
  max-width: 1000px;
  margin: 0 auto;
}
.footer-logo{
  text-align: center;
  margin-bottom: 32px;
}
.footer-logo a{
  display: inline-block;
}
.footer-logo a:hover{
  opacity: 0.6;
}
.footer-logo-text {
    display: block;
    color: #fff;
    margin-top: 12px;
    font-weight: 500;
    font-style: normal;
    font-size: 14px;
}
ul.footer-link{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
ul.footer-link li{
  font-size: 14px;
  margin: 0 12px;
}
ul.footer-link li a{
  color: #fff;
  -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
ul.footer-link li a:hover{
  opacity: 0.6;
  text-decoration: underline;
}
ul.footer-link li i {
    margin-left: 4px;
}

ul.footer-sns {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin: 32px -4px 0;
}
ul.footer-sns li {
    padding: 0 4px;
}
ul.footer-sns li a {
    border-radius: 4px;
    background: #444444;
    color: #fff;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding: 0 20px 0 16px;
    height: 48px;
    font-weight: 700;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
ul.footer-sns li a:hover {
    background: #666666;
}
.footer-sns-icon {
    margin-right: 12px;
}
.footer-sns-icon img {
    display: block;
}
.footer-sns-name {
    line-height: 1;
    font-size: 14px;
}

.copyright {
    text-align: center;
    color: #fff;
    font-family: gill-sans-nova, sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 12px;
  margin-top: 56px;
}



#fixed-conversion .conversion-btn{
  margin-top: 20px;
}
#fixed-conversion .conversion-btn a{
  width: 240px;
  height: 60px;
  font-size: 18px;
  box-shadow: 0px 4px 12px 0px rgba(126, 28, 201, 0.1);
}
#fixed-conversion .conversion-btn-decorate{
  width: 36px;
  height: 36px;
}
#fixed-pagetop-btn{
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  position: fixed;
  right: 20px;
  z-index: 9;
  bottom: -145px;
  transition: all 0.3s ease 0s;
}
#fixed-pagetop-btn a{
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: #000;
  box-shadow: 0px 4px 12px 0px rgba(126, 28, 201, 0.1);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  flex-flow: column;
  color: #fff;
}
#fixed-pagetop-btn a:hover{
  background: #444;
}

#fixed-pagetop-btn.fixed{
  bottom: 20px;
}
.pagetop-btn-icon{

}
.pagetop-btn-icon .material-symbols-outlined{
  font-size: 40px;
}
.pagetop-btn-text{
  font-size: 15px;
  margin-top: -20px;
  margin-bottom: 10px;
  line-height: 1.5;
  font-weight: 600;
}
#fixed-conversion-btn{
  display: none;
}

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

    footer {
        padding: 56px 0 108px;
    }
    .footer-logo img{
      width: 140px;
    }
    #fixed-conversion{
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      flex-flow: row-reverse;
      box-sizing: border-box;
        padding: 0 20px;
        width: 100%;
    }
    #fixed-conversion.fixed {
        bottom: 8px;
        right: 0;
    }
    .pagetop-btn {
        width: 52px;
    }
    .pagetop-btn a {
        width: 52px;
        height: 52px;
    }
    #fixed-pagetop-btn{
      display: none;
    }
    #fixed-conversion .conversion-btn {
        margin-top: 0;
        width: 100%;
        margin: 0;
        box-sizing: border-box;
        /* padding-right: 20px; */
    }
    #fixed-conversion .conversion-btn a {
        width: 100%;
        height: 48px;
        font-size: 15px;
        border-radius: 0;
        box-shadow: none;
        padding: 4px 0;
    }

    .footer-logo-text{
      font-size: 14px;
    }

    ul.footer-link li{
      padding: 5px 0;
    }

    ul.footer-sns{
      margin: 24px 0 0;
    }
    ul.footer-sns li {
      padding: 4px 4px;
    }

    ul.footer-sns li a{
       height: 45px;
       padding: 0 16px 0 12px;
    }
    .footer-sns-name{
      font-size: 13px;
    }
    .footer-sns-icon{
      margin-right: 8px;
    }
    .footer-sns-icon img{
      width: 20px;
    }

    #fixed-conversion-btn{
      display: block;
      position: fixed;
      bottom: 0;
      left: 0;
      width: 100%;
      box-shadow: 0 -5px 6px rgba(126,28,201,0.1);
      z-index: 9999;
    }

    #fixed-conversion .conversion-btn .conversion-btn-free{
      width: 44px;
      height: 44px;
    }

}



/* main-visual
----------------------------------------------------------------*/

#main-firstview{

}
#main-visual{
  background-image: url(../images/firstview_bg.png);
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  padding-top: 72px;
  padding-bottom: 164px;
}
#main-visual-box{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 0 40px;
}
.main-vision-teaser {
    width: 100%;
    text-align: center;
}
.main-vision-teaser-text {
    background: #fff;
    border: 2px solid #ff0000;
    color: #ff0000;
    font-size: 17px;
    text-align: center;
    font-weight: 700;
    padding: 8px 0;
    line-height: 1.6;
    margin-bottom: 32px;
    border-radius: 8px;
    display: inline-block;
    width: 50%;
}
.main-visual-content {
    width: calc(100% - 640px);
    box-sizing: border-box;
    padding-right: 32px;
    padding-top: 36px;
}

.main-visual-pagename{
  color: #fff;
}
.main-visual-pagename span{
  display: block;
}
.main-visual-pagename-sub{
  font-size: 31px;
  line-height: 1;
  margin-bottom: 8px;
}
.main-visual-pagename-main{
  font-size: 20px;
  line-height: 1.5;
}

.main-visual-copy{
  font-size: 29px;
  line-height: 1.45;
  color: #fff;
  font-weight: 700;
  margin-top: 36px;
}
.main-visual-copy2 {
    font-size: 43px;
    line-height: 1.35;
    color: #fff;
    font-weight: 700;
    margin-top: 12px;
}

.main-visual-benefit{
  width: 640px;
  text-align: center;
}
.main-visual-benefit-caption{
  font-size: 18px;
  line-height: 1.5;
  color: #fff;
  font-weight: 700;
  margin-bottom: 24px;
}
ul.benefit-list{
  display: flex;
  flex-wrap: wrap;
  margin: -16px -8px 0;
}
ul.benefit-list li{
  width: calc(100% / 3);
  box-sizing: border-box;
  padding: 0 8px;
  margin-top: 16px;
}
.benefit-card{
  background: #fff;
  padding: 15px 0 15px;
  border-radius: 8px;
}
.benefit-card-icon{
  width: 72px;
  height: 72px;
  background: #f8f8f8;
  border-radius: 50%;
  margin: 0 auto;
}
.benefit-card-icon img {
    height: 72px;
    object-fit: contain;
    width: auto;
    padding: 14px;
    box-sizing: border-box;
}
.benefit-card-name{
  line-height: 1.5;
  font-weight: 600;
  font-size: 13px;
  margin-top: 5px;
  letter-spacing: 0;
}

ul.benefit-list li:nth-of-type(1) .benefit-card-icon img{
  padding: 10px;
}
ul.benefit-list li:nth-of-type(2) .benefit-card-icon img{
  padding: 10px;
}
ul.benefit-list li:nth-of-type(3) .benefit-card-icon img{
  padding: 12px;
}
ul.benefit-list li:nth-of-type(4) .benefit-card-icon img{
  padding: 8px;
}


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

    #main-visual{
      padding-top: 72px;
      padding-bottom: 120px;
    }
    #main-visual-box{
      display: block;
      padding: 0;
    }
    .main-visual-content{
      width: 100%;
      padding-right: 0;
      padding-top: 0;
    }
    .main-visual-pagename{
      text-align: center;
    }
    .main-visual-pagename-sub{
      font-size: 6vw;
      margin-bottom: 6px;
    }
    .main-visual-pagename-main{
      font-size: 3.9vw;
    }

    .main-visual-copy{
        font-size: 6vw;
        margin-top: 24px;
        text-align: center;
    }
    .main-visual-copy2 {
        font-size: 9.5vw;
        margin-top: 8px;
        text-align: center;
    }

    .main-visual-benefit{
      width: 100%;
      margin-top: 24px;
    }
    .main-visual-benefit-caption{
      font-size: 14px;
      margin-bottom: 16px;
    }
    ul.benefit-list{
      margin: -10px -10px 0;
    }
    ul.benefit-list li{
      padding: 0 5px;
      margin-top: 10px;
    }
    .benefit-card{
      padding: 12px 0;
      height: 100%;
      box-sizing: border-box;
    }
    .benefit-card-name{
      font-size: 3vw;
      text-align: center;
      line-height: 1.2;
    }
    .benefit-card-icon{
      width: 64px;
      height: 64px;
    }
    .benefit-card-icon img{
      height: 64px;
    }

    .main-vision-teaser-text{
      font-size: 14px;
      width: 100%;
    }

}



/* about
----------------------------------------------------------------*/

#about-area {
    margin-top: -120px;
}
#about-box{
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 3px 6px rgba(0,0,0,0.16);
}
.about-box-head{
  padding: 40px 0 36px;
  text-align: center;
}
.about-box-head-title{
  font-size: 24px;
  line-height: 1.5;
  margin-bottom: 16px;
  font-weight: 700;
}
.about-box-head-description{
  font-size: 16px;
}
.grad-trigger{
  display: none;
}
label.grad-btn{
  height: 62px;
  width: 100%;
  display: block;
  color: #fff;
  background: rgb(39,49,103);
  background: linear-gradient(180deg, rgba(12,83,127,1) 0%, rgba(39,49,103,1) 100%);
  text-align: center;
  border-radius: 0 0 8px 8px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 17px;
  font-weight: 700;
}
label.grad-btn:hover{
  background: rgb(64,64,64);
  background: linear-gradient(180deg, rgba(64,64,64,1) 0%, rgba(0,0,0,1) 100%);
}
.about-trigger-arrow{
  margin-right: 4px;
  transition: all .5s;
  position: relative;
}


article#about-article{
  background: #f5f5f5;
  padding: 40px 48px;
  display: none;
  transition: all .5s;
}
article#about-article section{
  background: #fff;
  border-radius: 8px;
  padding: 30px;
}
article#about-article section:not(:first-of-type){
  margin-top: 16px;
}
.about-section-title{
  font-size: 20px;
  line-height: 1.5;
  margin-bottom: 12px;
}

ul.about-section-list{
    margin-top: 24px;
}
ul.about-section-list li{
  display: flex;
  flex-wrap: wrap;
}
ul.about-section-list li:not(:first-of-type){
  border-top: 1px solid #DCDCDC;
  margin-top: 20px;
  padding-top: 24px;
}
.about-section-list-number{
  font-size: 18px;
  font-weight: 700;
  width: 28px;
  line-height: 1.5;
}
.about-section-list-content{
  width: calc(100% - 28px);
}
.about-section-list-item{
  font-size: 18px;
  line-height: 1.5;
}
.about-section-list-item a{
  display: inline-block;
  color: rgb(39,49,103);
  text-decoration: underline;
  margin-right: 4px;
}
.about-section-list-item a:hover{
  text-decoration: none;
  color: #404040;
}
.about-section-list-text{
  margin-top: 8px;
}

#about-trigger:checked ~ label.grad-btn{
  border-radius: 0;
  background: rgb(64,64,64);
  background: linear-gradient(180deg, rgba(64,64,64,1) 0%, rgba(0,0,0,1) 100%);
}
#about-trigger:checked ~ label.grad-btn .about-trigger-arrow{
  transform:rotateX(180deg);
  top: 2px;
}
#about-trigger:checked ~ article#about-article {
    display: block !important;
}

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

    #about-area{
      margin-top: -96px;
    }
    #about-box{
      border-radius: 12px;
    }
    .about-box-head{
      padding: 22px 20px 20px;
    }
    .about-box-head-title{
      font-size: 18px;
      margin-bottom: 12px;
    }
    .about-box-head-description{
      font-size: 13px;
      text-align: left;
    }

    label.grad-btn{
      height: 52px;
      font-size: 14px;
    }
    article#about-article{
      padding: 24px 20px;
    }
    article#about-article section{
      padding: 20px;
    }
    .about-section-title{
      font-size: 16px;
      margin-bottom: 10px;
    }
    .about-section-content-text{
      font-size: 13px;
    }
    ul.about-section-list{
      margin-top: 16px;
    }
    .about-section-list-item{
      font-size: 16px;
    }
    .about-section-list-text{
      font-size: 13px;
    }

    ul.about-section-list li:not(:first-of-type){
      margin-top: 16px;
      padding-top: 20px;
    }
    .about-section-list-number {
        font-size: 16px;
        width: 22px;
    }
    .about-section-list-content{
      width: calc(100% - 22px);
    }

}




/* conversion
----------------------------------------------------------------*/

.conversion-area{
  padding: 64px 0 72px;
}
.conversion-caption {
    text-align: center;
    line-height: 1.5;
    font-size: 22px;
    font-weight: 700;
}

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

    .conversion-area{
      padding: 48px 0 52px;
    }
    .conversion-caption{
      font-size: 16px;
      line-height: 1.75;
    }

}




/* company
----------------------------------------------------------------*/

section#company{
  background: #F5F5F5;
}

ul.company-list{
  display: flex;
  flex-wrap: wrap;
  margin: -40px -16px 0;
}
ul.company-list > li{
  width: 50%;
  box-sizing: border-box;
  padding: 0 16px;
  margin-top: 40px;
  margin-bottom: -40px;
}
.company-card{
  background: #fff;
  border-radius: 0 0 8px 8px;
  position: relative;
  height: calc(100% - 40px);
  overflow: hidden;
}
.company-card-visual-img{
  height: 240px;
  background: #777;
}
.company-card-visual-img img{
  height: 240px;
  object-fit: cover;
  width: 100%;
}

.company-card-visual-company{
  padding: 0 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  margin-top: -34px;
}
.company-modal-content .company-card-visual-company{
  padding: 0;
}

.company-card-visual-company-logo{
  width: 120px;
  box-sizing: border-box;
  border: 1px solid #DEDEDE;
  background: #fff;
  border-radius: 8px;
  text-align: center;
}
.company-card-visual-company-logo img{
  height: 84px;
  object-fit: contain;
  box-sizing: border-box;
  padding: 8px 12px;
  display: block;
  width: 100%;
}
.company-card-visual-company-name{
  width: calc(100% - 120px);
  box-sizing: border-box;
  padding-left: 18px;
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 10px;
}

li#toyoseikan .company-card-visual-company-name{
  font-size: 19px;
}
#modal05 .company-card-visual-company-name{
  font-size: 19px;
}

.company-card-info{
  padding: 0 20px;
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  /* align-items: flex-end; */
}
.company-card-info-overview{
  width: calc(100% - 190px);
  box-sizing: border-box;
  padding-right: 28px;
}
.company-card-info-link{
  width: 190px;
  padding-top: 3px;
}
table.company-card-info-overview-table{

}
table.company-card-info-overview-table tr{
  border-bottom: 1px solid #DADCE0;
}
table.company-card-info-overview-table tr th{
  width: 96px;
  padding: 9px 0;
  line-height: 1.5;
  color: #606060;
  font-weight: 500;
  text-align: left;
}
table.company-card-info-overview-table tr td{
  padding: 9px 0;
  line-height: 1.5;
}

ol.company-card-info-link-list{

}
ol.company-card-info-link-list li{

}
ol.company-card-info-link-list li:not(:first-of-type){
  margin-top: 5px;
}
ol.company-card-info-link-list li a{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  color: #fff;
  background: rgb(39,49,103);
  background: linear-gradient(180deg, rgba(12,83,127,1) 0%, rgba(39,49,103,1) 100%);
  padding: 9px 8px 10px 16px;
  border-radius: 4px;
}
ol.company-card-info-link-list li a:hover{
  background: rgb(64,64,64);
  background: linear-gradient(180deg, rgba(64,64,64,1) 0%, rgba(0,0,0,1) 100%);
}
.company-card-info-link-list-name{
  font-size: 14px;
  line-height: 1;
  font-weight: 700;
}
.company-card-info-link-list-arrow{
  position: relative;
  top: 1px;
}
.company-card-info-link-list-arrow .material-symbols-outlined{
  display: block;
  font-size: 18px;
  font-weight: 600;
}

.company-card-body{
  padding: 0 20px;
}
.company-card-body::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 156px;
  background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0.9) 50%, #fff 100%);
  background: linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0.9) 50%, #fff 100%);
}
.company-card-point{
  margin-top: 24px;
}
.company-card-caption{
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 16px;
  line-height: 1.6;
}

ol.company-card-point-list{

}
ol.company-card-point-list li{
  background: #202020;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
ol.company-card-point-list li:not(:first-of-type){
  margin-top: 5px;
}
.company-card-point-list-number{
  width: 48px;
  color: #fff;
  line-height: 1;
  font-weight: 700;
  font-size: 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
.company-card-point-list-content {
    width: calc(100% - 48px);
    box-sizing: border-box;
    padding-left: 20px;
    padding: 12px 20px;
    background: #F5F5F5;
}
.company-card-point-list-content-title{
  line-height: 1.5;
  font-size: 16px;
  font-weight: 700;
}
.company-card-point-list-content-text{

}

.company-card-description{
  font-size: 14px;
  margin-top: 20px;
  height: 150px;
}
.company-card-popupbtn {
    height: 62px;
    width: 100%;
    display: block;
    color: #fff;
    background: rgb(39,49,103);
    background: linear-gradient(180deg, rgba(12,83,127,1) 0%, rgba(39,49,103,1) 100%);
    text-align: center;
    border-radius: 0 0 8px 8px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 17px;
    font-weight: 700;
    position: absolute;
    bottom: 0;
    left: 0;
}
.company-card-popupbtn:hover{
  background: rgb(64,64,64);
  background: linear-gradient(180deg, rgba(64,64,64,1) 0%, rgba(0,0,0,1) 100%);
}
.company-card-popupbtn-arrow{
  margin-right: 4px;
}
.company-card-body-spcontent-inner{
  display: none;
  padding: 0 20px 78px;
}
.company-sp-trigger{
  display: none;
}
label.company-sp-btn{
  display: none;
}


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

    .company-card-popupbtn{
      display: none;
    }
    ul.company-list{
      display: block;
      margin: 0 -20px;
    }
    ul.company-list > li{
      width: 100%;
      padding: 0;
      margin-top: 32px;
      margin-bottom: 0;
    }
    .company-card-visual-img{
      height: auto;
    }
    .company-card-visual-img img{
      height: auto;
    }
    .company-card-visual-company{
      padding: 0 10px;
      margin-top: -20px;
    }
    .company-card-visual-company-logo{
      width: 80px;
    }
    .company-card-visual-company-logo img{
      height: 56px;
      padding: 4px 8px;
    }
    .company-card-visual-company-name{
      width: calc(100% - 80px);
      padding-left: 10px;
      font-size: 16px;
      margin-bottom: 0;
      line-height: 1.4;
    }
    li#toyoseikan .company-card-visual-company-name {
      font-size: 3.5vw;
    }

    .company-card-info{
      display: block;
      margin-top: 8px;
    }
    .company-card-info-overview{
      width: 100%;
      padding-right: 0;
    }
    .company-card-info-link{
      margin-top: 14px;
      width: 100%;
    }
    table.company-card-info-overview-table{
      font-size: 13px;
    }
    table.company-card-info-overview-table tr th{
      width: 88px;
      padding: 8px 0;
    }
    table.company-card-info-overview-table tr td{
      padding: 8px 0;
    }
    ol.company-card-info-link-list{
      display: flex;
      flex-wrap: wrap;
      margin: -5px -4px 0;
    }
    ol.company-card-info-link-list li{
      width: 50%;
      box-sizing: border-box;
      padding: 0 4px;
      margin-top: 5px;
    }
    ol.company-card-info-link-list li:not(:first-of-type){
      margin-top: 5px;
    }
    ol.company-card-info-link-list li a{
      padding: 10px 6px 11px 10px;
    }
    .company-card-info-link-list-name{
      font-size: 13px;
    }
    .company-card-info-link-list-arrow .material-symbols-outlined{
      font-size: 15px;
    }

    .company-card-description{
      font-size: 13px;
      margin-top: 16px;
      padding: 0 20px;
      height: 120px;
    }

    .company-card-body{
      padding: 0;
      position: relative;
    }
    label.company-sp-btn {
        height: 52px;
        width: 100%;
        display: block;
        color: #fff;
        background: rgb(39,49,103);
        background: linear-gradient(180deg, rgba(12,83,127,1) 0%, rgba(39,49,103,1) 100%);
        text-align: center;
        border-radius: 0 0 8px 8px;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        font-size: 14px;
        font-weight: 700;
        margin-top: 16px;
        position: absolute;
        bottom: 0;
        left: 0;
        z-index: 9;
    }
    .company-sp-trigger{
      display: none;
    }
    .company-sp-trigger:checked ~ .company-card-body-spcontent .company-card-body-spcontent-inner {
        display: block !important;
    }
    .company-card-body::after{
        content: none;
    }
    .company-card-body-spcontent::after{
      content: "";
      display: block;
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 140px;
      background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0.9) 50%, #fff 100%);
      background: linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0.9) 50%, #fff 100%);
    }
    .company-sp-trigger:checked ~ .company-card-body-spcontent::after{
      content: none;
    }
    .company-sp-trigger:checked ~ .company-card-description{
      height: auto;
    }
    .company-sp-trigger:checked ~ label.company-sp-btn {
        border-radius: 0;
        background: rgb(64,64,64);
        background: linear-gradient(180deg, rgba(64,64,64,1) 0%, rgba(0,0,0,1) 100%);
    }
    .company-sp-trigger-arrow {
        margin-right: 4px;
        transition: all .5s;
        position: relative;
    }
    .company-sp-trigger:checked ~ label.company-sp-btn .company-sp-trigger-arrow {
        transform: rotateX(180deg);
        top: 2px;
    }

}



/* modal-overlay
----------------------------------------------------------------*/

.modal-overlay {
    display: none;
    opacity: 0;
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: 9999;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.65);
}
.modal-overlay.open {
    display: block;
    opacity: 1;
    /*-webkit-animation: opacityAnimation 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    animation: opacityAnimation 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;*/
    transition: all .5s;
}
.close-modal-button {
    position: absolute;
    right: -32px;
    top: -24px;
    width: 64px;
    height: 64px;
    background: #404040;
    border-radius: 50%;
    color: #fff;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all .5s;
    z-index: 99;
}
.close-modal-button:hover{
  background: #606060;
}
.close-modal-button .material-symbols-outlined{
  font-size: 36px;
  font-weight: 600;
}

.modal-overlay .contents-inner{
  padding: 56px 0;
  height: 100vh;
  box-sizing: border-box;
}
.company-modal{
  background: #fff;
  border-radius: 16px;
  height: 100%;
  position: relative;
  z-index: 99;
}
.company-modal-content-wrap {
    overflow-y: scroll;
    overflow-x: hidden;
    height: calc(100% - 72px);
}
.company-modal-content{
  display: flex;
  flex-wrap: wrap;
  padding: 32px 32px 32px;
  margin: 0 -16px;
}
.company-modal-left{
  width: 50%;
  box-sizing: border-box;
  padding: 0 16px;
}
.company-modal-right{
  width: 50%;
  box-sizing: border-box;
  padding: 0 16px;
}
.company-modal-content .company-card-point-list-content{
  padding: 20px;
}
.company-card-point-list-content-text{
  font-size: 13px;
  margin-top: 10px;
  line-height: 1.6;
}
.company-modal-content .company-card-caption{
  font-size: 16px;
}
.company-modal-content ol.company-card-point-list li:not(:first-of-type){
  margin-top: 10px;
}
.company-modal-content .company-card-info{
  padding: 0;
  margin-top: 20px;
}
.company-modal-content .company-card-description{
  margin-top: 32px;
  height: auto;
}
.company-modal-content .company-card-point{
  margin-top: 40px;
  margin-bottom: 32px;
}

.company-modal-content .company-card-visual-img{
  height: auto;
}
.company-modal-content .company-card-visual-img img{
  height: auto;
}

table.company-card-faq-table{
  font-size: 13px;
  line-height: 1.6;
  letter-spacing: 0;
}
table.company-card-faq-table thead{

}
table.company-card-faq-table thead tr th{
  background: #202020;
  color: #fff;
  font-weight: 600;
  padding: 6px 12px;
  text-align: left;
  border: 1px solid #DCDCDC;
}
table.company-card-faq-table thead tr th.question-th{
  width: 156px;
  box-sizing: border-box;
}
table.company-card-faq-table tbody tr:nth-of-type(even){
  background: #F5F5F5;
}
table.company-card-faq-table tbody tr td{
  padding: 10px 12px;
  text-align: left;
  border: 1px solid #DCDCDC;
  font-weight: 500;
}
table.company-card-faq-table tbody tr td.question-td{
  vertical-align: middle;
  color: #505050;
  font-weight: 600;
}

.company-card-honestly{
  margin-top: 32px;
}
ol.company-card-honestly-list{

}
ol.company-card-honestly-list li{
  border: 1px solid #DCDCDC;
}
ol.company-card-honestly-list li:not(:first-of-type){

}
.company-card-honestly-list-question{
  background: #F5F5F5;
  padding: 10px 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.company-card-honestly-list-person{
  width: 56px;
  text-align: center;
}
.company-card-honestly-list-person-name{
  font-size: 11px;
  font-weight: 500;
  line-height: 1.5;
}
.company-card-honestly-list-text{
  width: calc(100% - 56px);
  box-sizing: border-box;
  padding-left: 12px;
}
.company-card-honestly-list-text p{
  font-size: 13px;
  line-height: 1.6;
}
.company-card-honestly-list-answer{
  border-top: 1px solid #DCDCDC;
  padding: 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}


.company-modal-fixed {
    position: sticky;
    bottom: 0;
    left: 0;
    height: 72px;
    box-shadow: 0 -5px 6px rgba(126,28,201,0.1);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding-right: 6px;
}
.company-modal-fixed-content{
  width: calc(100% - 320px);
  box-sizing: border-box;
  padding-right: 32px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  height: 100%;
}
.company-modal-fixed-content-item {
    color: #fff;
    background: rgb(39,49,103);
    background: linear-gradient(180deg, rgba(12,83,127,1) 0%, rgba(39,49,103,1) 100%);
    height: 100%;
    border-radius: 0 0 0 16px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    line-height: 1.5;
    font-weight: 700;
    width: 120px;
}
ul.fixed-benefit-list{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: calc(100% - 120px);
  box-sizing: border-box;
  padding-left: 16px;
}
ul.fixed-benefit-list li{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
ul.fixed-benefit-list li:not(:first-of-type){
  margin-left: 16px;
}
.fixed-benefit-icon{
  width: 40px;
  height: 40px;
  background: #f5f5f5;
  border-radius: 50%;
  text-align: center;
}
.fixed-benefit-icon img{
  height: 40px;
    object-fit: contain;
    width: auto;
    padding: 10px;
    box-sizing: border-box;
}
.fixed-benefit-name{
  font-size: 12px;
  font-weight: 600;
  line-height: 1.4;
  margin-left: 8px;
}

.company-modal-fixed-btn{
  width: 320px;
}
.company-modal-fixed-btn .conversion-btn{
  margin-top: 0;
}
.company-modal-fixed-btn .conversion-btn a{
  width: 100%;
  height: 56px;
  box-shadow: none;
}
.company-modal-fixed-btn .conversion-btn-free{
  width: 44px;
  height: 44px;
  font-size: 14px;
}
.company-modal-fixed-btn .conversion-btn-text{
  font-size: 15px;
}
.company-modal-fixed-btn .conversion-btn-arrow{
  width: 44px;
  height: 44px;
}
.company-modal-fixed-btn .conversion-btn-arrow .material-symbols-outlined{
  font-size: 24px;
}

.company-card-location {
    margin-top: 28px;
}
.company-card-location-table-wrap{
  overflow-x: scroll;
  margin-top: -4px;
}
table.company-card-location-table{
  font-size: 13px;
  line-height: 1.6;
  letter-spacing: 0;
}
table.company-card-location-table thead{

}
table.company-card-location-table thead tr th{
  background: #202020;
  color: #fff;
  font-weight: 600;
  padding: 4px 12px;
  text-align: left;
  border: 1px solid #DCDCDC;
  box-sizing: border-box;
  vertical-align: middle;
}
table.company-card-location-table tbody tr:nth-of-type(even){
  background: #F5F5F5;
}
table.company-card-location-table tbody tr td{
  padding: 4px 12px;
  text-align: left;
  border: 1px solid #DCDCDC;
  font-weight: 500;
}
table.company-card-location-table tbody tr td:nth-of-type(4){
  text-align: center; 
}
table.company-card-location-table.company-card-location-table-type2 th.prefectures-th {
    width: 292px;
}
.company-card-location-note {
    font-size: 12px;
    line-height: 1.6;
    margin-top: 10px;
    font-weight: 400;
}

/* 専用 */
table.company-card-location-table thead tr th.prefectures-th {
    width: 80px;
}
table.company-card-location-table thead tr th.name-th {
    width: 92px;
}
table.company-card-location-table thead tr th.transfer-th{
    width: 90px;
}
#modal04 table.company-card-location-table thead tr th.name-th{
    width: 90px;
}
#modal05 table.company-card-location-table thead tr th.prefectures-th {
    width: 90px;
}


.company-modal-fixed-content-text{
  padding-left: 32px;
}


.company-modal-benefit {
    padding: 0px 32px 40px;
}
table.company-card-benefit-table{
  font-size: 13px;
  line-height: 1.6;
  letter-spacing: 0;
}
table.company-card-benefit-table thead{

}
table.company-card-benefit-table thead tr th{
  background: rgb(39,49,103);
    background: linear-gradient(180deg, rgba(12,83,127,1) 0%, rgba(39,49,103,1) 100%);
  color: #fff;
  font-weight: 600;
  padding: 8px 12px;
  text-align: left;
  border: 1px solid #DCDCDC;
  box-sizing: border-box;
  vertical-align: middle;
}
table.company-card-benefit-table tbody tr:nth-of-type(even){
  background: #F5F5F5;
}
table.company-card-benefit-table tbody tr td{
  padding: 8px 12px;
  text-align: left;
  border: 1px solid #DCDCDC;
  font-weight: 600;
  vertical-align: middle;
}
table.company-card-benefit-table thead tr th.content-th{
  width: 290px;
  box-sizing: border-box;
}
.content-td-box{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
}
.content-td-box-icon {
    width: 40px;
    height: 40px;
    background: #f8f8f8;
    border-radius: 50%;
}
.content-td-box-icon img {
    height: 40px;
    object-fit: contain;
    width: auto;
    padding: 8px;
    box-sizing: border-box;
}
.content-td-box-name{
  margin-left: 16px;
  font-weight: 600;
  font-size: 14px;
}
table.company-card-benefit-table tbody tr td.name-td{
  font-size: 14px;
}
.name-td-note {
    display: block;
    font-size: 12px;
    color: #333;
    font-weight: 500;
}
.company-modal-benefit .company-card-caption {
    font-size: 16px;
}

table.company-card-benefit-table tbody tr:nth-of-type(even) .content-td-box-icon{
  background: #fff;
}

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

    .modal-overlay{
        width: 1200px;
    }

}

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

    .modal-overlay{
        width: 100%;
    }

    .company-card-point{
      margin-top: 24px;
    }
    .company-card-caption{
      font-size: 15px;
      margin-bottom: 14px;
    }
    .company-card-caption-note {
        display: block;
        font-size: 12px;
        font-weight: 500;
        color: #666;
    }
    ol.company-card-point-list li{
      display: block;
    }
    .company-card-point-list-number{
      width: 100%;
      padding: 6px 0;
      font-size: 15px;
    }
    .company-card-point-list-content{
      width: 100%;
      padding: 18px 20px 18px;
    }
    .company-card-point-list-content-title{
      font-size: 15px;
    }
    .company-card-point-list-content-text{
      font-size: 12px;
    }

    .company-card-faq{
      margin-top: 24px;
    }

    table.company-card-faq-table thead tr th.question-th{
      width: 110px;
    }
    .company-card-honestly {
        margin-top: 24px;
    }

    .company-modal-fixed-content{
      width: 100%;
      padding-right: 0;
      display: block;
      margin-top: 24px;
    }
    .company-modal-fixed-content-item{
      width: 100%;
      border-radius: 0;
      padding: 4px 0;
      margin-bottom: 12px;
      font-size: 14px;
    }

    .company-modal-fixed-content ul.benefit-list{
      margin: -10px -5px 0;
    }
    .company-modal-fixed-content .benefit-card{
      padding: 0;
    }

    .company-card-location-table-wrap{
      margin-top: 0;
    }
    table.company-card-location-table thead tr th{
      line-height: 1.2;
      padding: 6px 12px;
    }
    table.company-card-location-table thead tr th.prefectures-th{
      min-width: 78px;
    }
    table.company-card-location-table thead tr th.name-th{
      min-width: 145px;
    }
    table.company-card-location-table thead tr th.job-th{
      min-width: 240px;
    }
    table.company-card-location-table thead tr th.transfer-th{
      min-width: 90px;
    }

    li#toyoseikan table.company-card-location-table thead tr th.prefectures-th{
      min-width: 100px;
    }
    li#toyoseikan table.company-card-location-table thead tr th.name-th{
      min-width: 160px;
    }

    .company-card-location{
      margin-top: 24px;
    }
    table.company-card-location-table.company-card-location-table-type2 th.prefectures-th {
        width: auto;
        min-width: 292px;
    }

    

    .company-modal-fixed-content-text{
      padding-left: 0;
      text-align: center;
    }

    .company-modal-benefit {
        padding: 28px 0 0;
    }
    .company-card-benefit-table-wrap {
        overflow-x: scroll;
    }
    table.company-card-benefit-table thead tr th.content-th {
        width: auto;
        min-width: 272px;
    }
    table.company-card-benefit-table thead tr th.name-th{
        min-width: 300px;
    }
    .content-td-box-name{
      font-size: 13px;
    }
    table.company-card-benefit-table tbody tr td.name-td {
        font-size: 13px;
    }
    .name-td-note {
        line-height: 1.4;
        margin-top: 4px;
    }



    /* 専用 */
    li#shikokukasei table.company-card-location-table thead tr th.name-th {
        min-width: 92px;
    }

    li#yamaki table.company-card-location-table thead tr th.name-th {
        min-width: 100px;
    }

}










