@charset "UTF-8";
/* reset */
*{box-sizing:border-box;}
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{border:0;font-family:inherit;font-size:100%;font-style:inherit;font-weight:inherit;margin:0;outline:0;padding:0;vertical-align:baseline;}
:focus{outline:0;}
html,body{width:100%;}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block;}
blockquote,q{quotes:none;}
blockquote:before,blockquote:after,q:before,q:after{content:"";content:none;}
input,textarea{margin:0;padding:0;}
ol, ul{list-style:none;margin:0;padding:0;}
table{border-collapse:collapse;border-spacing:0;}
caption,th,td{font-weight:normal;text-align:left;}
a img{border:0;}
a:focus,a:active,a:hover{outline:none;}
img{max-width:100%;vertical-align:bottom;}
body{
  /*スマホで勝手に文字が大きくなる対策*/
  -webkit-text-size-adjust:none;
  /* footerをbottomに固定する処理 */
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
footer{margin-top: auto;}
/* //footerをbottomに固定する処理 */
/* //reset */

body{
  font-family: "Kosugi", sans-serif;
  font-weight: normal;
  font-style: normal;
  font-size: 16px;
  color: #000;
  line-height: 1.6;
}

/* header_nav */
header{
  /*  box-shadow: 0px 0 4px 4px rgba(0, 0, 0, .5);*/
  /*  position: fixed;*/
  top: 0;
  z-index: 20;
}
header .inner{
  flex-direction: row;
  /*  background-color: rgba(33,75,102,.98);*/
  /*background-color: rgba(33,75,102,.5);*/
  justify-content: space-between;
  align-items: center;
  z-index: 1;
  margin: 0;
  padding: 0 16px;
  transition: .3s;
}
header .inner h1{
  background-color: #FFF;
  border-radius: 20px;
  padding: 0 16px;
  transition: .3s;
}
header .inner h1 a{
  display: flex;
  font-size: 26px;
  flex-direction: column;
  align-items: flex-start;
  color: rgb(33,75,102);
}
header .inner h1 img{
  width: 170px;
  padding: 6px 0 5px;
  transition: .3s;
}
header .inner h1 span{
  margin-top: -1px;
  font-size: 16px;
}
header .headerLeft{
  height: 100%;
  display: flex;
  justify-content: space-evenly;
}
header .headerRight ul{
  height: 100%;
  display: flex;
  justify-content: space-evenly;
}
header .headerRight ul li{
  width:100px;
  text-align:center;
}
.headerRight ul li img{
  height:60px;
}
header .registerNav{
  align-self: flex-end;
  display: flex;
  justify-content: space-between;
  font-size: 14px;
}
header .registerNav li::after{
  content: "/";
  margin: 0 8px;
}
header .registerNav li:last-of-type::after{
  content: none;
}
header .inner{
  width:1000px;
  padding:0px;
}
header .inner .loginMenu{
  display: flex;
  align-self: flex-end;
  justify-content: space-between;
  width: 156px;
}
header .inner .loginMenu a{
  color: #FFF;
}
header .inner .toggle{
  color: #fff;
  cursor: pointer;
  z-index: 9999;
  display: block;
  font-size: 32px;
}
header .inner .toggle::before{
  font-family: "Font Awesome 5 Free";
  content: "\f0c9";
  font-weight: bold;
}
header .inner .toggle.open::before{
  content: "\f00d";
}

header.narrow .inner{
  padding: 0 16px;/* 変更なし */
}
header.narrow .inner h1{
  /*font-size: 12px;*/
}
header.narrow .inner h1 img{
  width: 156px;
  padding: 0 0 6px;
}
header .logoutText a{
  color: #FFF;
}
header .logoutText a:hover{
  text-decoration: underline;
}

.gnavArea{
  position: fixed;
  top: 50px;
  right: 0;
  width: 300px;
  z-index: 15;
  opacity: 1;
  transition: 0.5s;
}
.gnavArea.open{
  opacity: 1;
}
.gnavArea ul{
  display: none;
  overflow-y: auto;
  height: calc(100vh - 120px);
}
.gnavArea li{
  border-bottom: 1px solid #fff;
}
.gnavArea li a{
  display: block;
  font-size: 16px;
  color: #FFF;
  padding: 16px 0;
  text-align: center;
  background-color: rgb(37, 78, 105, .98);
}
.gnavArea li a:hover{
  background-color: rgba(97,97,97,.98);
}
.gnavArea.high{
  /*top: 66px;*/
}

/* //header_nav */

/* 日時表示 */
.dateTimeOnTop{
  margin: 64px 0 14px;
  padding-left: 14px;
  font-size: 14px;
  color: #737373;
}
/* //日時表示 */

input,
label,
select,
textarea{
  font-weight: normal;
  font-family: "Kosugi", sans-serif;
}
header,
/*main,*/
section,
footer,
.inner{
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}
a,a:link,a:visited,a:hover,a:active{
  color: #000;
  text-decoration: none;
  transition: .3s;
}
.tdu{
  text-decoration: underline !important;
}

/* mainArea */
/* パンくず */
.breadCrumb{
  width: 960px;
  margin: 0 auto 12px;
  font-size: 12px;
  color: #666;
  display: flex;
}
.breadCrumb a{
  color: #666;
}
.breadCrumb a:hover{
  text-decoration: underline;
}
.breadCrumb li::after{
  content: ">";
  margin: 0 4px;
}
.breadCrumb li:last-child::after{
  content: none;
}
/* //パンくず */

/* main */
main{
  z-index: 10;
}
.inner{
  width: 100%;
  max-width: 100%;
  justify-content: center;
  align-items: flex-start;
  position: relative;
  z-index: 0;
  padding: 0 16px;
}
.inner.center{
  align-items: center;
}
.msgText{
  color: #FFF;
  background-color: #1375ba;
  text-align: center;
  width: 100%;
  padding: 32px 0;
  margin: -38px 0 16px;
}
.msgText.err{
  background-color: #a80000;
}
strong,
.emphasise{
  font-weight: bold;
}
.pageHeader{
  width: 100%;
  font-size: 24px;
  border-bottom: 1px solid #000;
  text-align: left;
  /*margin-bottom: 32px;*/
  padding-left: 16px;
}
p{
  margin-bottom: 16px;
}
table{
  border: 1px solid #bbb;
  width: 100%;
  margin-bottom: 32px;
}
th{
  border: 1px solid #bbb;
  background-color: #eee;
}
td{
  border: 1px solid #bbb;
}
.inner dl{
  width: 100%;
}

/* priceTable */
.priceTable caption{
  text-align: right;
  font-size: 14px;
}
.priceTable caption::before{
  content: "※";
}
.priceTable th{
  text-align: center;
}
.priceTable .price,
.priceTable .priceTR td{
  text-align: right;
}
/* //priceTable */

/* ボタン系。submitもこっちにとりあえず入れとく。 */
.buttonStyle,
input[type="submit"]{
  -webkit-appearance: none;
  background: #e09515;
  color: #fff !important;
  font-size: 24px;
  width: 300px;
  display: block;
  margin: 0 auto 24px;
  border: none;
  text-align: center;
  cursor: pointer;
  transition: .3s;
}
input[type="submit"]{
  padding: 16px;
  margin-top: 32px;
}
.buttonStyle a{
  padding: 16px;
  color: #FFF;
  display: block;
}
.buttonStyle:hover,
input[type="submit"]:hover{
  background: #f1bd65;
}
.buttonStyle a:hover{
  text-decoration: none;
}
.buttonStyle.disabled_btn,
.buttonStyle.disabled_btn:hover{
  background: #555;
  color: #999999;
  cursor: not-allowed;
  padding: 16px;
  line-height: 1;
}
/* ｢戻る｣とか｢パスワードを忘れたとき｣とかそんなやつ */
.navLinkText{
  width: 100%;
  text-align: center;
}
.navLinkText a{
  text-decoration: underline;
}

/* //main */
.pagetop{
  font-family: "Font Awesome 5 Free";
  font-weight: bold;
  font-size: 32px;
  line-height: 1;
  position: fixed;
  bottom: 30px;
  right: 30px;
  z-index: 999;
  margin: 0;
  cursor:pointer;
  color: #000;
}
.pagetop::before{
  content: "\f139";
}

.nowPrinting{
  width: 254px;
  margin: 0 auto 36px;
}
.devMemo{
  color:#000;
  text-align:center;
  margin:0;
  /*display: none;*/
}
.coming{
  padding: 64px;
  font-size: 24px;
  font-weight: bold;
  color: #555;
  text-align: center;
  display: block;
}
.dataAddLink{
  margin: 0 0 32px auto;
}

.mailNotice{
  margin-bottom: 32px;
}
footer .bootLINEApp{
  display: none;
}
.loggedIn footer{
  padding-bottom: 36px;
}
.loggedIn footer .bootLINEApp{
  display: block;
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  background-color: #3ab54a;
  text-align: center;
  margin: 0;
  z-index: 20;
  padding: 15px;
}
.loggedIn footer .bootLINEApp a{
  font-family: "Kosugi Maru", sans-serif;
  font-weight: bold;
  font-size: 20px;
  background-color: #FFF;
  border-radius: 8px;
  color: #3ab54a;
  padding: 4px 16px 4px 24px;
  line-height: 1;
  letter-spacing: 4px;
}
.loggedIn footer .bootLINEApp a::after{
  font-family: "Font Awesome 5 Free";
  content: "\f144";
  font-weight: bold;
  font-size: 22px;
  vertical-align: baseline;
  margin-left: 8px;
}
/* フォントに &sup2; がなさそうな時用 */
.squareText::after{
  content: "2";
  font-size: 10px;
  vertical-align: super;
}

@media only screen and (max-width: 860px){
  footer .inner ul{
    flex-direction: column;
    align-items: center;
  }
  footer .inner ul li::after{
    content: none;
  }
}
/* 狭小 */
@media only screen and (max-width: 767px){/* ipadを切ったら */
  /*header*/
  header .inner h1{
    border-radius: 12px;
  }
  header .inner h1 a{
    font-size: 16px;
  }
  header .loginMenu{
    margin: auto 0 0 auto;
    display: flex;
    font-size: 14px;
    justify-content: space-between;
    width: 130px;
  }
  .header_nav{
    width: 258px;
    position: relative;
    flex-direction: column;
    justify-content: space-between;
  }
  .header_nav ul{
    position: absolute;
    top: 100px;
    left: -258px;
    transition: .3s;
  }
  .header_nav ul.open{
    left: 0;
    transition: .5s;
  }
  .languageDIV{
    display: flex;
  }
  /*//header*/

  .listJs .search{
    width: 100%;
  }

  .errText{
    width: 100%;
    position: static;
  }
  main{
    /*margin-top: 70px;*/
  }
  footer .inner{
    flex-direction: column;
  }
  }/* このとじカッコは消さないこと */
