@charset "utf-8";
/* reset */
*, *::before, *::after{
  box-sizing: border-box;
}
html{
  font-family: sans-serif;
  font-size: 10px;
  font-weight: 500;
  font-style: normal;
  line-height: 1.6;
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}
body, h1, h2, h3, h4, p, figure, blockquote, dl, dd{
  margin-block-end: 0;
}
ul[role="list"], ol[role="list"]{
  list-style: none;
}
body{
  min-height: 100vh;
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  line-height: 1.8;
  color: #333333;
  background: #e1f1f8;
}
h1, h2, h3, h4{
  line-height: 1.4;
}
a{
  text-decoration: underline;
  color: #de4117;
  transition: all .3s ease-out;
}
a img{
  cursor: pointer;
  transition: all .3s ease-out;
  image-rendering: -webkit-optimize-contrast;
}
a i{
  display: inline-block;
  margin: -.3em .3em 0 .3em;
  line-height: 1;
  vertical-align: middle;
  transition: all .3s ease-out;
}
a:hover img{
  opacity: .8 !important;
  image-rendering: -webkit-optimize-contrast;
}
img, picture{
  max-width: 100%;
  width: 100%;
  height: auto;
  vertical-align: bottom;
  image-rendering: -webkit-optimize-contrast;
}
:target{
  scroll-margin-block: 5ex;
}
* > p:first-child{
  margin-top: 0;
}
small, sub, sup{
  font-size: .8;
}
address{
  font-style: normal;
}
.container{
  width: 100%;
  margin: 0 auto;
  padding: 5em 0;
  background: #f3f3f0;
}
.cntbox{
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 15px;
}
/** SP/PC制御 **/
.forsp{
  display: inline-block !important;
}
.forpc{
  display: none !important;
}
.nobr{
  display: inline-block;
}
@media print, screen and (min-width: 580px){
  .fnav .forpc{
    display: inline-block !important;
  }
}
@media print, screen and (min-width: 768px){
  .nobr{
    display: inline-block;
  }
  a{
    text-decoration: none;
    color: #de4117;
  }
  a:hover{
    text-decoration: underline;
    color: #de4117;
  }
  a[href^="tel"]{
    text-decoration: none;
    color: currentColor;
    cursor: default;
  }
}
@media print, screen and (min-width: 1000px){
  .forsp{
    display: none !important;
  }
  .forpc{
    display: inline-block !important;
  }
}

/* header */
header{
  position: fixed;
  z-index: 100;
  width: 100%;
  height: 52px;
  background: #0575a3;
}
header .cntbox{
  display: flex;
  align-items: center;
  justify-content: center;
  background: #ffffff;
}
header .hdrlogo{
  padding: 5px 0;
  font-family: serif;
  font-size: 2rem;
  font-weight: bold;
}
header .hdrlogo img{
  max-width: none;
  max-height: 40px;
  width: auto;
  margin: 0 .5em 0 0;
}
@media print, screen and (min-width: 768px){
  header{
    height: 70px;
  }
  header .hdrlogo{
    padding: 11px 0;
    font-family: serif;
    font-size: 2.4rem;
    font-weight: bold;
  }
  header .hdrlogo img{
    max-width: none;
    max-height: 45px;
    width: auto;
    margin: 0 .5em 0 0;
  }
}

/* footer */
footer{
  padding: .5em 1em;
  color: #ffffff;
  background: #0575a3;
}
footer .copy{
  font-size: 1rem;
  letter-spacing: .1em;
  text-align: center;
}

/* content */
.content{
  padding: 50px 2% 0;
}
.content .cntbox{
  padding: 2em 1em;
  background: #ffffff;
}
.content h1{
  font-size: 2.4rem;
}
.content h2{
  font-size: 2rem;
}
.content h3{
  margin-top: 2em;
  font-size: 1.6rem;
  text-align: center;
}
.content dl{
  display: flex;
  flex-wrap: wrap;
}
.content dt{
  width: 50%;
  margin: 0;
}
.content dd{
  width: 50%;
  margin: 0;
}
#main h1{
  margin: 0;
  padding: .5em 0 .3em;
  font-size: 3rem;
  text-align: center;
  border: 5px solid #0575a3;
  border-right: 0;
  border-left: 0;
}
#main h1 span{
  display: block;
  font-size: .6em;
}
#main h1 + p{
  margin: .5em auto 0;
  line-height: 1.4;
}
#main dl{
  border-bottom: 1px dotted #999999;
}
#main dt, #main dd{
  padding: .3em 0;
  border-top: 1px dotted #999999;
}
#main dt{
  width: 28%;
}
#main dd{
  width: 72%;
  padding-left: 2%;
}
#main dl + p{
  margin: .5em auto 0;
  font-size: 1.1rem;
  line-height: 1.4;
}
#main h2{
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.8;
}
#main h2 span{
  font-size: 2rem;
  background: linear-gradient(to bottom, #ffffff 0%,#ffffff 92%,#de4117 100%);
}
#main h2 + p{
  text-align: left;
}
#info .cntbox{
  padding: 0 1em 2em;
}
#info dl{
  border-bottom: 1px dotted #999999;
}
#info dt, #info dd{
  padding: .3em 0;
  border-top: 1px dotted #999999;
}
#info dt{
  width: 28%;
}
#info dd{
  width: 72%;
  padding-left: 2%;
}
#area h2{
  text-align: center;
}
#area dl{
  border-bottom: 1px dotted #999999;
}
#area dt, #area dd{
  padding: .3em 0;
  border-top: 1px dotted #999999;
}
#area dt{
  width: 20%;
}
#area dd{
  width: 80%;
  padding-left: 2%;
}
@media print, screen and (min-width: 768px){
  .content{
    padding: 70px 0 0;
  }
  .content .cntbox{
    padding: 3em;
  }
  #main h1{
    margin: 0;
    padding: .7em 0 .5em;
    font-size: 4rem;
  }
  #main h1 + p{
    margin: 2em auto;
    line-height: 1.4;
    text-align: center;
  }
  #main dl{
    width: auto;
    margin: 0 auto;
  }
  #main dt, #main dd{
    padding: .5em 0;
  }
  #main dt{
    width: 50%;
    padding-right: 2%;
    text-align: right;
  }
  #main dd{
    width: 50%;
  }
  #main dl + p{
    margin: 1em auto 0;
    font-size: 1.4rem;
    text-align: center;
  }
  #main h2{
    font-size: 2rem;
    text-align: center;
  }
  #main h2 span{
    font-size: 2.8rem;
  }
  #main h2 + p{
    width: 80%;
    margin: 1em auto 0;
    font-size: 1.6rem;
  }
  #info .cntbox{
    padding: 0 3em 3em;
  }
  #info dl{
    width: 50%;
    margin: 1em auto;
  }
  #info dt, #info dd{
    padding: .5em 0;
  }
  #info dt{
    width: 28%;
  }
  #info dd{
    width: 72%;
    padding-left: 2%;
  }
  #area dl{
    width: 70%;
    margin: 1em auto;
  }
  #area dt, #area dd{
    padding: .5em 0;
  }
  #area dt{
    width: 15%;
  }
  #area dd{
    width: 85%;
  }
  #area dl + p{
    text-align: center;
  }
  #other ul{
    padding: 0;
  }
  #other li{
    list-style: none;
    text-align: center;
  }
  #other p{
    text-align: center;
  }
  #other p + ul{
    margin: 0;
  }
}


/* recruit */
#recruit{
  color: #333333;
  background: 0;
}
#recruit *{
  box-sizing: border-box;
}
#recruit .header{
  padding: .5em 0;
  text-align: center;
  background: #d1edfb;
}
#recruit .header h1{
  font-size: 20px;
  font-weight: normal;
}
#recruit footer{
  padding: .5em 0;
  font-size: 10px;
  text-align: center;
  background: #c6c6c6;
}
#recruit .container{
  width: 100%;
  padding: 0 10px 20px;
  background: #ffffff;
}
#recruit h2{
  padding: .5em 0;
  font-size: 18px;
  text-align: center;
}
#recruit dl{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  border-top: 1px solid #cccccc;
}
#recruit dt{
  width: 100%;
  padding: .7em 0 .3em;
  border-bottom: 1px dotted #cccccc;
}
#recruit dt::before{
  content: "●";
}
#recruit dd{
  width: 100%;
  margin: 0;
  padding: .3em 0 .7em;
  border-bottom: 1px solid #cccccc;
}
#recruit dd .ttl{
  margin-top: 20px;
  font-size: 20px;
  line-height: 2;
}
#recruit dd .ttl:nth-of-type(1){
  margin-top: 0;
}
#recruit dd ul{
  margin: 0;
  padding: 0;
}
#recruit dd li{
  list-style: none;
  position: relative;
  padding: 0 0 .5em 1em;
}
#recruit dd li::before{
  content: "■";
  position: absolute;
  left: 0;
}
#recruit dd strong{
  font-weight: bold;
  color: #ed2a2a;
}
@media print, screen and (min-width: 768px){
  #recruit a[href^="tel"]{
    text-decoration: none;
    color: #333333;
    cursor: default;
  }
  #recruit .container{
    max-width: 800px;
    margin: 0 auto;
    padding: 2em;
  }
}
