@charset "UTF-8";
/* CSS Document */

html,body,p,ol,ul,li,dl,dt,dd,blockquote,figure,fieldset,legend,textarea,pre,iframe,hr,h1,h2,h3,h4,h5,h6{
 margin:0;
 padding:0;
 border:0;
}
ul,ol,dl,nav{
 list-style:none;
}
html {
 box-sizing:border-box;
 scroll-behavior:smooth;
}
.clearfix::after {
  content: "";
  display: table;   /* or block */
  clear: both;
}

/* iOSでのデフォルトスタイルをリセット */
button,
input[type="submit"],
input[type="button"] {
  -webkit-appearance: none; /* iOS/Safari対応 */
  appearance: none;         /* モダンブラウザ対応 */
}
body{
 font-family: "Noto Sans JP", "BIZ UDPGothic","Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN",Meiryo,system-ui,sans-serif;
 font-size:16px;
 font-size:1rem;
 background:#FFF;
 color: #333333;
 position:relative;
 overflow-x:hidden;
 -webkit-text-size-adjust:100%;
 -webkit-font-feature-settings:"palt";
 font-feature-settings:"palt";
}
a,a:hover{
 text-decoration:none;
 cursor: pointer;
}
img {
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  border: none;
}
button {
 cursor: pointer;
 -webkit-appearance:none;
 appearance: none;
 outline:none;
 border:none;
}
.noto-sans-jp-nomal {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight:400;
  font-style: normal;
}
.noto-sans-jp-mid {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight:500;
  font-style: normal;
}
.overpass-mid {
  font-family: "Overpass", sans-serif;
  font-optical-sizing: auto;
  font-weight:500;
  font-style: normal;
}
.solway-regular {
  font-family: "Solway", serif;
  font-weight: 400;
  font-style: normal;
}
h1 {
  line-height: 1;
}

/********** header *************/

/**** PC版メニュー ****/
#top-global-nav{display: none;}

.mv-area {
  position: relative;
  width:100vw;
  height:295px;
  overflow: hidden;
}
.mv-bg {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.2s;
  z-index: 0;
}
.mv-bg.active {
  opacity: 1;
  z-index: 1;
}
.mv-logo {
  position: absolute;
  left: 28%;
  top: 45%;
  width:100px;
  transform: translate(-45%, -28%);
  z-index: 10;
  transition: opacity 0.6s;
}
.mv-logo-wrap.is-right {
  position: absolute !important; /* 念のため明示 */
  left: auto !important;
  right: 6% !important;
  top: 50% !important;
  transform: translate(0, -50%) !important;
  z-index: 10 !important;       /* 背景の上に出す */
  text-align: right;
}

/* 右寄せのときは画像を“中身”扱いにして absolute を解除 */
.mv-logo-wrap.is-right .mv-logo {
  position: static !important;  /* ← これが肝。既存の absolute を無効化 */
  transform: none !important;   /* 既存の translate を解除 */
  width: min(50vw, 300px);      /* お好みで調整 */
  height: auto;
  display: block;
  opacity: 1 !important;        /* JSのフェードが0のまま残っている場合の保険 */
}


/********** サービスイントロ *************/
.service-intro{
  margin:30px auto 55px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
h2.block-ttle{
  margin:0 auto;
  font-size:20px;
  font-size: 1.25rem;
  font-weight: 500;
  color:#333;
}
h2.block-ttle span,
h2.block-ttle small{
  display: block;
  margin-bottom:5px;
  font-size:13px;
  font-size: 0.8125rem;
  color: #333;
  font-weight: normal;
  font-family: "DM Mono", monospace;
  font-weight: 300;
  font-style: normal;
}
.service-intro h3{
  margin:30px auto 35px;
  font-size:14px;
  font-size: 0.875rem;
  color: #333;
  width: calc(100% - 30px);
  font-weight: 500;
  text-align: left;
  line-height: 1.5;
}
.next-p a{
  font-size:15px;
  font-size: 0.9375rem;
  font-family: "DM Mono", monospace;
  font-weight:300;
  margin: 0 auto;
  position: relative;
  display: inline-block;
  color: #333;
}
.next-p a::after {
  content: '';
  position: absolute;
  left:-8px;
  right: 0;
  margin: 0 auto;
  bottom: -15px;
  width:103px;
  height: 7px;
  border-bottom: 1px solid #555;
  border-right: 1px solid #555; 
  border-radius: 0 0 0 0;
  transform: skewX(35deg);
}
.wrap{
  height:117px;
  background: url('../img/service.jpg') no-repeat center center / cover;
  position: relative;
  overflow: hidden;
  margin:0 0 49px;
}
.wrap::before {
  content: '';
  position: absolute;
  z-index: 0;
  left: 0; top: 0; right: 0; bottom: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4); 
  pointer-events: none;
}

@media screen and (min-width:700px) {
.mv-area {
  height:355px;
}
.mv-logo {
  left: 30%;
  top: 45%;
  width:130px;
  transform: translate(-45%, -30%);
}
.wrap{
  height:157px;
  margin:0 0 49px;
}
}

/********** サービスlineup *************/
.service-lineup{
  background: #f5f5f5;
  width:100%;
  margin: 0 auto;
  text-align: center;
  padding-bottom:73px;
}
.lineup-inner{
  display: flex;
  padding:0;
  justify-content: center;
  flex-direction: column;
  width: calc(100% - 30px);
  margin: 0 auto;
}
.media-no{
  display: flex;
  flex-direction: column;
  text-align: left;
  width:100%;
  height: auto;
  margin:0 auto 45px !important;
  max-width: 600px;
}
.media-no img{
  width:100%;
  height: auto;
  max-width:600px;
  margin: 0 auto;
}
.media-no h3{
  font-size:16px;
  font-size: 1rem;
  font-weight: 500;
  color:#333;
  margin: 20px 0 14px;
}
.media-no h3 span{
  font-size:13px;
  font-size: 0.8125rem;
  margin-left: 5px;
}
.media-no p{line-height: 1.5;}
.media-no p a{
  font-size:14px;
  font-size: 0.875rem;
  color: #333;
  position: relative;
  display: inline-block;
}
.media-no p a::after{
  content: '';
  position: absolute;
  background-image:url('../img/text-link.svg');
  width: 20px;
  height: 20px;
  margin-left:5px;
  margin-top:0px;
}

/********** トップのインフォ *************/
.top-info{
  margin:53px auto;
  text-align: center;
}
.top-info-area{
  width:calc(100% - 30px);
  margin: 48px auto 63px;
  text-align: center;
  padding: 0;
}
.top-info-area dl{
  margin:0 auto 35px;
  text-align: left;
  width:100%;
}
.top-info-area dl dt{
  font-size:13px;
  font-size: 0.8125rem;
  color: #000;
}
.top-info-area dl dt span.info{
  color: #fff;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#666;
}
.top-info-area dl dt span.grape{
  color: #fff;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#BC80AD;
}
.top-info-area dl dt span.press{
  color: #fff;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#666;
}
.top-info-area dl dt span.update{
  color: #000;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#fff;
  border: 1px solid #000;
}
.top-info-area dl dt span.umami{
  color: #fff;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#000;
}
.top-info-area dl dd{
  padding:15px 0 22px;
  border-bottom: 1px solid #999;
}
.top-info-area dl dd a{
  font-size:15px;
  font-size: 0.9375rem;
  text-decoration: underline;
  color: #333;
}
.top-info-area dl:last-of-type{
  margin-bottom: 0;
}





/********** 広告掲載エリア *************/
.media-kit-section {
  width:calc(100% - 30px);
  max-width: 600px;
  margin:80px auto 100px;
  text-align: center;
  z-index: 1;
}
.section-label {
  font-family: 'DM Mono', monospace;
  font-size:13px;
  font-size: 0.8125rem;
  color: #333;
  margin-bottom:17px;
}
.info-box-wrap {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}
.info-box-wrap::before {
  content: "";
  position: absolute;
  left: 6px;
  bottom:-9px;
  width: 100.4%;
  height: 79%;
  border: 1.5px solid #555;
  box-sizing: border-box;
  background: transparent;
  z-index: 0;
  pointer-events: none;
}
.info-box {
  position: relative;
  background: #fff;
  border: 1.5px solid #555;
  margin: 0 auto;
  box-shadow: 7px 8px 0 0 #f5f5f5;
  width: 100%;
  max-width: 1000px;
  min-height: 115px;
  padding-top:25px;
  padding-bottom:0px;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
  z-index:1; 
}
.section-title {
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  font-size:20px;
  font-size: 1.25rem;
  letter-spacing: 1px;
  z-index: 2;
  display: flex;
  align-items: center;
  font-weight: 500;
  background: linear-gradient(to bottom, #fafafa 50%, #fff 50%);
}
.section-title::before,
.section-title::after {
  content: "";
  display: block;
  height: 1px;
  background: #333;
}
.section-title::before {
  margin-right: 14px;
}
.section-title::after {
  margin-left: 14px;
}
.section-content {
  width: 95%;
  margin: 0 auto;
  font-size:18px;
  font-size: 1.125rem;
  color: #333;
  margin-top: 14px;
}
.section-content p {
  margin: 0;
  font-weight: 500;
  text-align: left;
  font-size:15px;
  font-size: 0.9375rem;
}
.section-content p a{
  color: #333;
  text-decoration: underline;
}

/********** 広告掲載エリア（topのみ） *************/
.top-section-title {
  position: absolute;
  top: -18px;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  font-size:20px;
  font-size: 1.25rem;
  letter-spacing: 1px;
  z-index: 2;
  display: flex;
  align-items: center;
  font-weight: 500;
  background:#fff;
}
.top-section-title::before,
.top-section-title::after {
  content: "";
  display: block;
  height: 1px;
  background: #333;
}
.top-section-title::before {
  margin-right: 14px;
}
.top-section-title::after {
  margin-left: 14px;
}
.top-section-content {
  width: 95%;
  margin: 0 auto;
  font-size:18px;
  font-size: 1.125rem;
  color: #333;
  margin-top: 14px;
}
.top-section-content p {
  margin: 0;
  font-weight: 500;
  text-align: left;
  font-size:15px;
  font-size: 0.9375rem;
}
.top-section-content p a{
  color: #333;
  text-decoration: underline;
}
.top-info-box {
  position: relative;
  background: #fff;
  border: 1.5px solid #555;
  margin: 0 auto;
  box-shadow: 7px 8px 0 0 #f5f5f5;
  width: 100%;
  max-width: 1000px;
  min-height: 115px;
  padding-top:25px;
  padding-bottom:0px;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
  z-index:1; 
}
@media screen and (max-width:406px) {
.info-box-wrap::before {
  width: 100.6%;
}
}
@media screen and (max-width:500px) {
.top-section-content p, .section-content p{
  font-size:14px;
  font-size: 0.875rem;
}
.info-box-wrap::before {
  width: 100.7%;
}
}
@media screen and (max-width:1024px) {
.top-section-content p, .section-content p{
  text-align: center;
}
}
@media screen and (max-width:569px) {
.top-section-content p, .section-content p{
  text-align:left;
}
}







/********** お問い合わせ *************/
.contact-area{
  border-top:1px solid #555;
  width:100%;
  margin: 0 auto;
  text-align: center;
  padding:85px 0;
}
.contact-area p{
  font-size:15px;
  font-size: 0.9375rem;
  color:#333;
  text-align:center;
  margin: 52px auto 58px;
  width: calc(100% - 30px);
}
button.box-btn,
p.box-btn{
  border:1px solid #333;
  display: flex;
  width:70%;
  max-width:400px;
  height:50px;
  align-items: center;
  justify-content: center;
  color:#000;
  font-size: 18px;
  font-size: 1.125rem;
  margin: 0 auto;
  background: #fff;
}
button.box-btn a,
p.box-btn a{
  color: #000;
}

/********** フッター *************/
.black-area{
  background-color:#000;
  width:100%;
  height: auto;
  padding:47px 0 0;
}
.footer-menu{
  width:calc(100% - 30px);
  height:auto;
  display:flex;
  flex-direction: column;
  margin:0 auto;
  justify-content: center;
}
.adress{
  display: flex;
  flex-direction: column;
  text-align:left;
}
.adress h2{
  margin:0 auto;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.adress h2 img{
  width:118px;
  height: auto;
}
.adress p{
  font-size:14px;
  font-size: 0.875rem;
  color: #fff;
  margin:33px 0 0;
}
.adress p span{
  display: block;
}
.adress p span.tel{
  display: block;
  margin-top:8px;
}
ul.g-menu{
  padding:28px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap:0 16px;
}
ul.g-menu li a{
  font-size:14px;
  font-size: 0.875rem;
  color: #fff;
}
ul.blank{
  padding: 28px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap:0 16px;
}
ul.blank li a{
  font-size:14px;
  font-size: 0.875rem;
  color: #fff;
}
.policy{
  width:calc(100% - 30px);
  border-top:1px solid #fff;
  margin:34px auto 0;
  display: flex;
  padding:23px 0;
  line-height: 1.2;
}
.policy ul{
  align-items: center;
  justify-content: center;
}
.policy ul li a{
  font-size:12px;
  font-size: 0.75rem;
  color:#fff;
  padding:0;
}

/** クレジット **/
.credit{
  width:100%;
  padding:15px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  color:#333;
  font-size:12px;
  font-size: 0.75rem;
}
@media screen and (min-width:500px) {
.adress p{
  max-width:700px;
  margin:33px auto 0;
}
ul.g-menu{
  margin:0 auto;
  max-width:700px;
  gap:0 13px;
}
ul.blank{
  max-width:700px;
  margin: 0 auto;
}
.policy ul{
  display:flex;
  gap: 0 15px;
  margin: 0 auto;
}
}

/** drawerメニュー **/
.drawer-logo{
  margin:43px 0 0 18px;
  text-align: left;
  width:132px;
}
.drawer-logo img{
  width: 100%;
  height: auto;
}
ul.hamburger-menu{
  margin:25px 0 0 18px;
  text-align: left;
}
ul.hamburger-menu li{
  padding-bottom: 31px;
}
ul.hamburger-menu li a{
  font-size:16px;
  font-size: 1rem;
  color:#333;
}
ul.hamburger-menu li:nth-child(6){
  padding-bottom: 61px;
}
ul.hamburger-menu li.g-menu-contact a{
  position: relative;
  background: #fff;
  border: 1px solid #333;
  padding: .8em 3.5em;
  cursor: pointer;
  z-index: 1;
  line-height: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
}
ul.hamburger-menu li.g-menu-contact a::before{
  content: "";
  position: absolute;
  top: 3px; left: 3px; right: 3px; bottom: 3px;
  border: 1px solid #333;
  pointer-events: none;
}
.drawer-nav{z-index: 1000;}


/********** お知らせ *************/

/** PC版 ***/
.lower-menu-area{display: none;}

.lower-menu-area-2{
  width:100%;
  height:54px;
  border-bottom: 1px solid #bfbfbf;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lower-menu-2{
  width: calc(100% - 30px);
  height: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.lower-menu-2 h1 a img{
  width:102px;
  height: auto;
}
#container{
  width:100%;
  height: auto;
  background:#fafafa;
  margin: 0 auto;
  padding-left:15px;
  padding-right:15px;
  box-sizing: border-box;
}
#side-bar{
  width:100%;
  height: auto;
  text-align: left;
  padding-top:37px;
}
#main-area{
  width:100%;
  height: auto;
  text-align:left;
  padding:36px 0;
}
.sidebar-ttle{display: none;}

h2.sidebar-ttle-2{
  margin:0 auto;
  font-size:20px;
  font-size: 1.25rem;
  font-weight: 500;
  color:#333;
  line-height: 1;
  text-align: center;
}
h2.sidebar-ttle-2 span{
  display: block;
  margin-bottom:10px;
  font-size:13px;
  font-size: 0.8125rem;
  color: #333;
  font-weight: normal;
  font-family: "DM Mono", monospace;
  font-weight: 300;
  font-style: normal;
  text-transform: uppercase;
}
h2.sidebar-ttle-2 br{
  display: none;
}

/*** パンくず ***/
.bread {
  display: flex;
  gap: 0 10px;
  list-style: none;
  padding: 0;
  font-size:12px;
  font-size: 0.75rem;
  margin-top:35px;
}
.bread li {
  display: flex;
  align-items: center;
}
.bread li:not(:last-child)::after {
  display: inline-block;
  transform: rotate(45deg);
  width: .3em;
  height: .3em;
  margin-left: 10px;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  content: '';
}
.bread li a {
  color: #000;
  text-decoration: none;
}
.bread li:last-child a{
  color: #666;
  text-decoration: underline;
}
@media screen and (min-width:600px) {
h2.sidebar-ttle-2{
  font-size:23px;
  font-size: 1.4375rem;
}
h2.sidebar-ttle-2 span{
  font-size:15px;
  font-size: 0.9375rem;
}

.bread {
  font-size:14px;
  font-size: 0.875rem;
}
}
.info-area{
  width:100%;
  margin:0 auto 96px;
  text-align: center;
  padding: 0;
}
.info-area dl{
  margin:0 auto 35px;
  text-align: left;
  width:100%;
}
.info-area dl dt{
  font-size:13px;
  font-size: 0.8125rem;
  color: #000;
}
.info-area dl dt span.info{
  color: #fff;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#666;
}
.info-area dl dt span.grape{
  color: #fff;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#BC80AD;
}
.info-area dl dt span.press{
  color: #fff;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#666;
}
.info-area dl dt span.update{
  color: #000;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#fff;
  border: 1px solid #000;
}
.info-area dl dt span.umami{
  color: #fff;
  font-size:13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#000;
}
.info-area dl dd{
  padding:15px 0 22px;
  border-bottom: 1px solid #999;
}
.info-area dl dd a{
  font-size:15px;
  font-size: 0.9375rem;
  text-decoration: underline;
  color: #333;
}
.info-area dl:last-of-type{
  margin-bottom: 0;
}
@media screen and (min-width:600px) {
.info-area dl dt{
  font-size:14px;
  font-size: 0.875rem;
}
.info-area dl dt span.info, .info-area dl dt span.grape, .info-area dl dt span.press, .info-area dl dt span.update,.info-area dl dt span.umami{
  font-size:14px;
  font-size: 0.875rem;
}
.info-area dl dd a{
  font-size:16px;
  font-size:1rem;
  color:#333;
}
}
/*** ページネーション ***/
.page-nav ul{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8px;
  list-style-type: none;
  padding: 0;
  margin: 97px auto 0;
}
.page-nav a,
.page-nav span {
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2em;
  height: 2em;
  border: 1px solid #000;
  border-radius: 1px;
  background: #fff;
  color: #000;
}
.page-nav span{
  border: none;
  background-color: transparent;
}
.page-nav span.dots{
  width: fit-content;
}
.page-nav a:not(:hover) {
  text-decoration: none;
}
.page-nav .current{
  background-color: #000;
  color: #fff;
  pointer-events: none;
}
.page-nav .prev,
.page-nav .next{
  gap: 0 4px;
  width: auto;
  padding: .5em .8em;
  line-height: 1;
  border: none;
  background: none;
}
.page-nav .prev::before,
.page-nav .next::after {
  display: inline-block;
  transform: rotate(45deg);
  width: .4em;
  height: .4em;
  content: '';
}
.page-nav .prev::before {
  border-bottom: 1px solid #000;
  border-left: 1px solid #000;
}
.page-nav .next::after {
  border-top: 1px solid #000;
  border-right: 1px solid #000;
}
@media screen and (max-width:640px) {
.page-nav .next {
  gap: 0 4px;
  width:60px;
  padding: .5em 0.2em;
  line-height: 1;
  border:none;
  justify-content: flex-start;
  box-sizing: border-box;
  font-size:15px;
}
.page-nav .prev {
  gap: 0 4px;
  width:60px;
  padding: .5em 0.2em;
  line-height: 1;
  border:none;
  justify-content:flex-end;
  box-sizing: border-box;
  font-size:15px;
}
}

/********** お知らせ詳細 *************/

/*** パンくず（お知らせ詳細） ***/
.bread-news {
  display: flex;
  gap: 0 10px;
  list-style: none;
  padding: 0;
  font-size:14px;
  font-size: 0.875rem;
  margin-top:40px;
  overflow-x: auto;
  white-space: nowrap;
}
.bread-news li {
  display: flex;
  align-items: center;
  flex: 0 0 auto; 
  min-width: 0;
}
.bread-news li:not(:last-child)::after {
  display: inline-block;
  transform: rotate(45deg);
  width: .3em;
  height: .3em;
  margin-left: 10px;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  content: '';
  flex-shrink: 0; 
}
.bread-news li a {
  color: #000;
  text-decoration: none;
  display: block;
}
.bread-news li:last-child a {
  color: #666;
  text-decoration: underline;
}
.info-area-detail{
  width:100%;
  margin:0 auto 23px;
  text-align: center;
  padding: 0;
}
.info-area-detail dl{
  margin:0 auto 35px;
  text-align: left;
  width:100%;
}
.info-area-detail dl dt{
  font-size:14px;
  font-size: 0.875rem;
  color: #000;
}
.info-area-detail dl dt span.info{
  color: #fff;
  font-size: 13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#666;
}
.info-area-detail dl dt span.grape{
  color: #fff;
  font-size: 13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#BC80AD;
}
.info-area-detail dl dt span.press{
  color: #fff;
  font-size: 13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#666;
}
.info-area-detail dl dt span.update{
  color: #000;
  font-size: 13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#fff;
  border: 1px solid #000;
}
.info-area-detail dl dt span.umami{
  color: #fff;
  font-size: 13px;
  font-size: 0.8125rem;
  border-radius: 20px;
  padding:.2em .5em;
  margin-left:8px;
  background:#000;
}
.info-area-detail dl dd{
  padding:15px 0 22px;
  border-bottom: 1px solid #999;
}
.info-area-detail dl dd h2{
  font-size:17px;
  font-size: 1.0625rem;
  font-weight: 500;
}
.info-area-detail dl:last-of-type{
  margin-bottom: 0;
}
.entry-content h3.wp-block-heading{
  font-size:17px;
  font-size: 1.0625rem;
  color: #000;
  margin:0 auto 30px;
  text-align: center;
  font-weight: 500;
}
.entry-content .has-text-align-center{
  text-align: center;
}
.entry-content .wp-block-image,
.news-pic{
  margin: 0 auto;
  text-align: center;
  width:60%;
}
.entry-content .wp-block-image img,
.news-pic img{
  width:100%;
  height: auto;
  object-fit: cover;
}
.entry-content p,
.news-text{
  font-size: 14px;
  font-size: 0.875rem;
  color: #333;
  text-align: left;
  margin:30px 0;
  line-height: 1.6;
}
dl.sns-lineup{
  font-size: 14px;
  font-size: 0.875rem;
  color: #333;
}
dl.sns-lineup div{
  display: flex;
}
dl.sns-lineup div dt{
  margin-right:5px;
  width:100px;
  font-weight: 500;
}
dl.sns-lineup div dd a{
  color: #333;
}
.entry-content ul li {
	line-height: 1.5;
	margin: 0.5rem 0;
	line-height: 1.8;
}
.entry-content a{
  color: #333;
  text-decoration: underline;
  text-decoration-line: underline;
	text-decoration-style: solid;
	text-decoration-thickness: 0.5px;
	text-underline-offset: 4px;
}
.entry-content .wp-block-group,
div.this-matter{
  margin:50px 0;
}
.entry-content .wp-block-group p,
div.this-matter p{
  font-size: 14px;
  font-size: 0.875rem;
  color: #333;
  margin-bottom: 10px;
}
div.this-matter dl{
  font-size: 14px;
  font-size: 0.875rem;
  color: #333;
}
div.this-matter dl div{
  display: flex;
}
div.this-matter dl div dt{
  margin-right:5px;
}
div.this-matter dl div dd a{
  color: #333;
}
.next-p-2{
  margin:90px auto 130px;
  text-align: center;
  width:100%;
}
.next-p-2 a{
  font-size:15px;
  font-size: 0.9375rem;
  font-family: "DM Mono", monospace;
  font-weight:300;
  margin: 0 auto;
  position: relative;
  display: inline-block;
  color: #333;
}
.next-p-2 a::after {
  content: '';
  position: absolute;
  left:-15px;
  right: 0;
  margin: 0 auto;
  bottom: -15px;
  width:103px;
  height: 7px;
  border-bottom: 1px solid #555;
  border-right: 1px solid #555; 
  border-radius: 0 0 0 0;
  transform: skewX(35deg);
}
@media screen and (min-width:800px) {
.entry-content .wp-block-image,
.news-pic{
  width:40%;
}
.info-area-detail dl dd h2{
  font-size:18px;
  font-size: 1.125rem;
}
}
@media screen and (max-width:447px) {
dl.sns-lineup div{
  display:block;
}
dl.sns-lineup div dt{
  width:100%;
}
.next-p-2{
  margin:60px auto 90px;
}
}
.entry-content .wp-block-media-text {
  margin:30px 0;
  box-sizing: border-box;
  /*!rtl:begin:ignore*/
  direction: ltr;
  /*!rtl:end:ignore*/
  display: grid;
  grid-template-columns: 50% 1fr;
  grid-template-rows: auto
}
.entry-content .wp-block-media-text.has-media-on-the-right {
  grid-template-columns: 1fr 50%
}
.entry-content .wp-block-media-text.is-vertically-aligned-top .wp-block-media-text__content,
.entry-content .wp-block-media-text.is-vertically-aligned-top .wp-block-media-text__media {
  align-self: start
}
.entry-content .wp-block-media-text .wp-block-media-text__content,
.entry-content .wp-block-media-text .wp-block-media-text__media,
.entry-content .wp-block-media-text.is-vertically-aligned-center .wp-block-media-text__content,
.entry-content .wp-block-media-text.is-vertically-aligned-center .wp-block-media-text__media {
  align-self: center
}
.entry-content .wp-block-media-text.is-vertically-aligned-bottom .wp-block-media-text__content,
.entry-content .wp-block-media-text.is-vertically-aligned-bottom .wp-block-media-text__media {
  align-self: end
}
.entry-content .wp-block-media-text .wp-block-media-text__media {
  /*!rtl:begin:ignore*/
  grid-column: 1;
  grid-row: 1;
  /*!rtl:end:ignore*/
  margin: 0
}
.entry-content .wp-block-media-text .wp-block-media-text__content {
  direction: ltr;
  /*!rtl:begin:ignore*/
  grid-column: 2;
  grid-row: 1;
  /*!rtl:end:ignore*/
  padding: 0 8%;
  word-break: break-word
}
.entry-content .wp-block-media-text.has-media-on-the-right .wp-block-media-text__media {
  /*!rtl:begin:ignore*/
  grid-column: 2;
  grid-row: 1 /*!rtl:end:ignore*/
}
.entry-content .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
  /*!rtl:begin:ignore*/
  grid-column: 1;
  grid-row: 1 /*!rtl:end:ignore*/
}
.entry-content .wp-block-media-text__media img,
.entry-content .wp-block-media-text__media video {
  height: auto;
  max-width: unset;
  vertical-align: middle;
  width: 100%
}
.entry-content .wp-block-media-text.is-image-fill .wp-block-media-text__media {
  background-size: cover;
  height: 100%;
  min-height: 250px
}
.entry-content .wp-block-media-text.is-image-fill .wp-block-media-text__media>a {
  display: block;
  height: 100%
}
.entry-content .wp-block-media-text.is-image-fill .wp-block-media-text__media img {
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  clip: rect(0,0,0,0);
  border: 0
}
.entry-content .wp-block-media-text p:first-child{
  margin-top: 0;
}
.entry-content .box-lead{
	border-bottom: 3px solid rgba(119, 119, 119, 0.1);
	padding: 0 1rem 2rem;
	margin-bottom: 2rem;
}
.entry-content p.box-lead{
	line-height: 1.5;
}
.entry-content .box-txt{
	border: 3px solid rgba(119, 119, 119, 0.1);
	padding: 1rem;
}
.entry-content .box-txt p:last-child{
	margin-bottom: 0;
}
.entry-content .box-txt h4:first-child{
	margin-top: .4rem;
}
.entry-content .txt-large{
	font-size: 1.33333rem;
}
.entry-content .txt-small{
	font-size: 0.8rem;
}
.entry-content .wp-block-table figcaption,
.entry-content .wp-block-image .aligncenter>figcaption{
	font-size: 0.8rem;
	text-align: right;
}


/********** 事業内容 *************/
.business-purpose{
  font-size:15px;
  font-size: 0.9375rem;
  color: #333;
  font-weight: 500;
  line-height: 1.7;
}
.media-tab > .wp-block-group__inner-container{
  display: flex;
  flex-wrap: wrap;
  gap:5px 25px;
  width:100%;
  margin: 42px auto 0;
  justify-content: center;
}
.media-tab > .wp-block-group__inner-container > label {
  flex:none;
  order: -1;
  opacity: .5;
  min-width: 70px;
  color: #000;
  font-size:14px;
  font-size: 0.875rem;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  padding:.35em .4em;
  box-sizing: border-box;
}
.media-tab > .wp-block-group__inner-container > label:last-of-type{
  gap: 0;
}
.media-tab > .wp-block-group__inner-container > label:hover {
  opacity: .8;
}
.tab-2 input {
  display: none;
}
.media-tab > .wp-block-group__inner-container > div {
  display: none;
  width: 100%;
  margin-top: 29px;
  border-top:1px solid #000;
  padding-top: 31px;
}
.media-tab label:has(:checked) {
  opacity: 1;
  border:1px solid #000;
  border-radius: 20px;
  padding:.35em .4em;
  box-sizing: border-box;
}
.media-tab label:has(:checked) + div {
  display: block;
}
.media-tab input[type="radio"] {
  display: none;
}

/*** メディア中身 ***/
.media-detail{
  width:100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  box-sizing: border-box;
}
.media-img,
.media-detail .wp-block-media-text__media{
  width: 100%;
  height: auto;
  display: flex;
  max-width:700px;
  margin:0 auto;
}
.explain,
.media-detail .wp-block-media-text__content{
  width:100%;
  height: auto;
  max-width:700px;
  margin:0 auto;
  padding: 0 !important;
}
.media-img img,
.media-detail .wp-block-media-text__media img{
  width:100%;
  height: auto;
  object-fit: cover;
}
.media-detail .category{
  font-family: "DM Mono", monospace;
  font-weight: 300;
  font-style: normal;
  font-size:15px;
  font-size: 0.9375rem;
  color:#000;
  padding:18px 0;
  margin-bottom:25px;
  width:100%;
  border-bottom: 1px solid #000;
}
.media-detail h3{
  font-size:16px;
  font-size: 1rem;
  font-weight: 500;
  color:#000;
}
.media-detail h3 span{
  margin-left:5px;
  font-size:13px;
  font-size: 0.8125rem;
}
.media-detail h3 + p{
  margin-top:15px;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.7;
}
.media-detail .wp-block-buttons{
  margin:30px auto 0 !important;
  box-sizing: border-box;
  width:100%;
  gap:10px !important;
  max-width:500px;
}
.media-detail .wp-block-buttons .wp-block-button{
  width: 100%;
}
#main-area .media-detail .wp-block-buttons .display-none{
  display: none;
}
.media-detail .wp-block-buttons .media-data a{
  border: 1px solid #333;
  padding:1em .8em;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  width:100%;
  box-sizing: border-box;
  background: #fff;
  color:#000;
  font-size:16px;
  font-size: 1rem;
}
.media-detail .wp-block-buttons .media-official a{
  background: #000;
  padding: 1em .8em;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width:100%;
  color:#fff;
  font-size:16px;
  font-size: 1rem;
}

/********** 会社情報 *************/
.our-company table{
  border:1px solid #333;
  border-collapse: collapse;
  box-sizing: border-box;
  text-align: left;
  width:100%;
  font-size:15px;
  font-size: 0.9375rem;
  max-width: 700px;
  margin: 0 auto;
}
.our-company table tr {
    display: flex;
    flex-direction: column;
}
.our-company table td{
  width:100%;
  border-bottom:1px solid #555;
  padding:.8em;
  box-sizing: border-box;
}
td.boad-men dt{
  padding-bottom:3px;
}
.our-company table td span{display: block;padding-top:3px;}
.our-company table td.table-ttle,
.our-company table td:first-child,
.our-company table th:first-child{
  background:#333;
  color: #fff;
  width: 100%;
  border-bottom:1px solid #fff;
  padding:.8em;
  box-sizing: border-box;
}
.our-company table td.boad-men dl{
  display: grid;
  grid-template-columns: 140px 1fr;
  column-gap: 18px;
  margin: 0;
}
.our-company table td.boad-men.table-last{
  border: none;
}
.our-company table td.table-last{
  border: none;
}
.access-help{
  font-size: 13px;
  font-size: 0.8125rem;
  margin:18px auto 0;
  text-align: left;
  max-width: 700px;
}
.access-help span{
  display: block;
}
.map{
  width: 100%;
  height:410px;
  margin: 36px auto -36px;
  text-align: center;
}
.map.alignfull{
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  width: auto;
}
.map iframe{
  width: 100% !important;
  height: 100% !important;
}

/********** お問い合わせランナップ *************/
.contact-lineup{
  width:100%;
  height: auto;
  margin: 0 auto;
  text-align: center;
}
.contact-explain{
  width:100%;
  text-align: left;
  margin-bottom:57px !important;
}
.contact-explain h3{
  font-size:16px;
  font-size: 1rem;
  color: #000;
  font-weight: 500;
  border-bottom: 1px solid #000;
  padding-bottom:18px;
  margin-bottom:20px;
}
.contact-explain p{
  font-size:14px;
  font-size: 0.875rem;
  color: #333;
  line-height: 1.7;
}
.contact-explain p span{
  display: block;
}
.contact-explain .link-button a{
  border: 1px solid #333;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: .8em;
  margin-top: 30px;
  width:100%;
  background: #fff;
  max-width:400px;
  color:#000;
  font-size: 14px;
  font-size: 0.875rem;
  box-sizing: border-box;
}
.arrow-line-link{
  margin-top: 26px;
}
.arrow-line-link a{
  color:#000;
  font-size: 14px;
  font-size: 0.875rem;
  position: relative;
  display:inline-block;
}
.arrow-line-link a::after{
  content: '';
  position: absolute;
  right: -48px;
  bottom: 3px;
  margin: 0 auto;
  width: 45px;
  height: 12px;
  border-bottom: 1px solid #555;
  border-right: 1px solid #555; 
  border-radius: 0 0 0 0;
  transform: skewX(35deg);
}
.press-release-link{
  margin-top:24px;
}
.press-release-link a{
  font-family: "DM Mono", monospace;
  font-weight: 300;
  font-style: normal;
  color:#000;
  font-size: 15px;
  font-size: 0.9375rem;
  position: relative;
  margin-left:30px;
}
.press-release-link a::before{
  position:absolute;
  content: '';
  background-image: url('../img/mail.svg');
  width: 26px;
  height: 26px;
  background-size: contain;
  left:-30px;
}
@media screen and (min-width:600px) {
.contact-explain p{
  font-size:15px;
  font-size: 0.9375rem;
}
}

/********** プライバシー&コンテンツポリシー *************/
.privacy-intro{
  font-size:14px;
  font-size: 0.875rem;
  width:100%;
  text-align: left;
}
.privacy-intro2{
  font-size:15px;
  font-size: 0.9375rem;
  width:100%;
  text-align: left;
  margin-bottom:31px;
}
h2.chapter{
  font-size: 17px;
  font-size: 1.0625rem;
  color: #000;
  padding-bottom:21px;
  margin:34px 0 33px;
  border-bottom: 1px solid #000;
  font-weight: 500;
}
h2.chapter2{
  font-size: 17px;
  font-size: 1.0625rem;
  color: #000;
  padding-bottom:21px;
  margin:0 0 33px;
  border-bottom: 1px solid #000;
  font-weight: 500;
}
.article{
  padding: .1em .8em;
  color: #000;
  border-left: solid 3px #BC80AD;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 400;
}
.article-text-area{
  width:100%;
  text-align: left;
  font-size:14px;
  font-size: 0.875rem;
  color: #333;
  margin: 16px 0 28px;
  box-sizing: border-box;
  padding-left:calc(.8em + 3px);
}
.article-text-area2{
  width:100%;
  text-align: left;
  font-size:16px;
  font-size: 1rem;
  color: #333;
  margin: 16px 0 28px;
  box-sizing: border-box;
  padding-left:calc(.8em + 3px);
  padding-bottom:50px;
}
.article-text-area p{
  margin-bottom:28px;
}
dl.hav-info div{
  display: flex;
  gap:20px;
  margin-bottom:22px;
}
dl.hav-info div dd{
  text-align: left;
}
dl.hav-info div dd span{
  text-align: left;
  display: block;
}
dl.hav-info div dd ul{
  list-style-position: inside;
}
dl.hav-info div dd ul li.point{
  list-style-type: disc;
}
ul.info-purpose{
  margin-top:20px;
  text-align: left;
}
ul.info-purpose li{
  margin: 0;
}
ul.third-people{
  margin:20px 0 20px 35px;
}
ul.third-people li{
  margin: 0;
}
.policy-adress{
  border:1px solid #bababa;
  padding:1.5em;
  width:100%;
  box-sizing: border-box;
}
.policy-adress ul li{
  margin: 0;
}
.policy-adress ul li:last-child{
  margin:20px 0 0;
}
.policy-adress ul li a{
  color: #333;
  text-decoration: underline;
  text-decoration-line: underline;
	text-decoration-style: solid;
	text-decoration-thickness: 0.5px;
	text-underline-offset: 4px;
}
.hav-info2,
dl.hav-info2{
  padding:0 0 20px;
  line-height: 1.2;
}
dl.hav-info2 div{
  display: block;
  margin: 0;
  text-align: left;
}
dl.hav-info2 div dd{
  width:100%;
  box-sizing: border-box;
}
.hav-info2 strong{
  font-weight: 400;
  display: block;
  margin-top: 10px;
}
.hav-info2 a,
dl.hav-info2 div dd a{
  color: #333;
  white-space: normal;
  word-break: break-word;
  text-decoration: underline;
  text-decoration-line: underline;
	text-decoration-style: solid;
	text-decoration-thickness: 0.5px;
	text-underline-offset: 4px;
}
.num-list li{
  counter-increment: num;
  margin: 0 0 22px;
  padding-left: 30px;
  position: relative;
}
.num-list li::before{
  content: counter(num);
  position: absolute;
  left: 0;
  top: 0;
}

ul.safe-line{
  list-style-position: inside;
}
ul.safe-line li.point{
  list-style-type: disc;
}
.box2box{
  display: flex;
  flex-direction: column;
  border: 1px solid #333;
  box-sizing: border-box;
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
  background: #fff;
  box-sizing: border-box;
  gap: 0 !important;
}
.box2box div{
  display:flex;
  flex-direction: column;
  margin: 0 auto;
  justify-content: center;
  align-items: center;
  border-bottom: 1px solid #333;
  text-align: center;
  width:100%;
  padding:1em .8em;
  box-sizing: border-box;
}
.box2box div:last-child{
  border-bottom: none;
}
.box2box div div.safe-logo{
  width:60%;
  height: auto;
  border: none;
  padding: 0;
}
.box2box div div.safe-logo img{
  width:100%;
  height: auto;
}
.box2box div ul{
  text-align: center;
  font-size:15px;
  font-size: 0.9375rem;
}
.box2box div ul li:first-child{
  font-size:17px;
  font-size: 1.0625rem;
  margin-bottom:15px;
  font-weight: 500;
}
.link-box{
  border: 1px solid #bababa;
  padding: 1em;
  display: flex;
  align-items: center;
  justify-content: center;
  width:40%;
  max-width: 400px;
  box-sizing: border-box;
}
.link-box a{
  color:#333;
  font-size: 14px;
  font-size: 0.875rem;
}
@media screen and (max-width:550px) {
.link-box{
  width:60%;
}
h2.chapter, h2.chapter2{
  font-size: 16px;
  font-size:1rem;
}
}


ol.wp-block-list:not(.num-list){
  margin:20px 0 20px 35px;
  list-style: decimal;
}

/* recaptcha 非表示 */
.grecaptcha-badge{
  opacity: 0;
}












