@charset "UTF-8";

/* ---------------------------------------------------
| 共通CSS
--------------------------------------------------- */
body{
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
  color:#555;
  font-weight:500;
  font-feature-settings:'palt';
  font-size: 1.6rem;
}
a{color:#00a5d9;}
a:hover{text-decoration:none;}
a[href^="tel:"]{pointer-events:none;}
img{
  max-width: 100%;
  /*display: block;*/
  vertical-align:bottom;
}
.ofi{object-fit:cover;font-family:'object-fit:cover;'}
.ofiv{object-fit:cover;font-family:'object-fit:cover;'}
.ofit{object-fit:contain;font-family:'object-fit:contain;'}
h2{
  margin-bottom:2em;
  font-size: 3rem;
  text-align: center;
}
h2 span{
  font-size: 1.3rem;
  color: #2e6eb1;
  display: block;
  margin: 1.5rem 0 0;
}
#corporate h3,#business h3,.newsList h3{
  position: relative;
  margin: 0 auto 4rem;
  padding-bottom:.2rem;
  font-size:2.4rem;
  line-height:1.5em;
  color: #2e6eb1;
}
#corporate h3::after,#business h3::after,.newsList h3::after{
  position: absolute;
  bottom:0;left:0;
  content:"";
  width:100%;
  height:.3rem;
  background-image:linear-gradient(90deg,#2e6eb1 25%,#00a5d9 25%);
}
h4{
  font-size: 2rem;
  line-height: 1.6;
  color: #2e6eb1;
  margin: 0 0 1rem;
}
.sp-only{
  display: none;
}
.inner{
  width: 108rem;
  margin: 0 auto;
  position: relative;
}
.centering{
  text-align:center;
}
main section{
  margin-bottom:6em;
}
#cont{
  float:left;
  width:80rem;
}
aside{
  float:right;
  width:24rem;
}
p.note{font-size:.9em !important;color:#888;}
.fw900{font-weight:900;}
.righter{text-align:right;}
/* ---------- responsive ---------- */
@media screen and (max-width:767px){
  a[href^="tel:"]{
    pointer-events: auto;
  }
  h2{
    font-size:2rem;
    text-align: center;
  }
  h2 span{
    font-size: 1rem;
    margin: .5rem 0 0;
  }
  h3{
    font-size: 1.8rem;
    margin: 0 auto 3rem;
  }
  #corporate h3,#business h3,.newsList h3{
    font-size: 1.8rem;
  }
  h4{
    font-size: 1.6rem;
  }
  p{
    font-size: 1.4rem;
  }
  main{
    padding: 6rem 0 0;
  }
  .pc-only{
    display: none;
  }
  .sp-only{
    display: block;
  }
  .inner{
    width: 100%;
    padding: 0 1rem;
  }
  #cont{
    float:none;
    width:100%;
  }
  aside{
    float:none;
    margin-top:4rem;
    width:100%;
  }
}

/* ---------------------------------------------------
| #sdnv
--------------------------------------------------- */
#sdnv{
  margin:0 0 2rem;
  font-size:.9em;
  border-width:4px 1px;
  border-style:solid;
  border-color:#666;
  background:#fff;
}
#sdnv li{
  padding:2px;
  line-height:1.5em;
}
#sdnv li a{
  position:relative;
  display:block;
  padding:1em .5em 1em 1.4em;
  color:#333;
  text-decoration:none;
}
#sdnv li.current a{
  color:#fff;
  text-decoration:none;
  background:#2e6eb1;
}
#sdnv li a:hover{text-decoration:underline;color:#2e6eb1;}
#sdnv li.current a:hover{
  text-decoration:none !important;
  color:#fff !important;
}
#sdnv li a::before{
  position:absolute;
  top:0;bottom:0;
  left:.5em;
  margin:auto;
  content:"";
  width:0;height:0;
  border-style:solid;
  border-width:.36em;
  border-color:transparent transparent transparent #2e6eb1;
}
#sdnv li a:hover::before{
  border-color:transparent transparent transparent #2e6eb1;
}
#sdnv li.current a::before{
  border-color:transparent transparent transparent #fff;
}

/* ----- #sdnv responsive ----- */
@media (min-width:769px){
  #sdnv li{
    border-top:1px solid #999;
  }
  #sdnv li:first-child{
    border-top:none;
  }
  #sdnv li.ch{
    padding-left:1em;
    border-top:1px dashed #bbb;
  }
}
/*@media (min-width:800px) and (max-width:999px) {
  #sdnv{
    margin-bottom:2rem;
    font-size:0;
    border:none;
  }
  #sdnv li{
    display:inline-block;
    width:33.3%;
    font-size:.9rem;
    border-right:1px solid #888;
    border-bottom:1px solid #888;
  }
  #sdnv li:nth-child(3n-2){
    border-left:1px solid #888;
  }
  #sdnv li:first-child,#sdnv li:nth-child(2),#sdnv li:nth-child(3){
    border-top:1px solid #888;
  }
  #sdnv li a{
    padding:1em .3em 1em 1.4em;
    line-height:1.4em;
  }
  .midHid{display:none;}
}*/
@media (max-width:767px) {
  #sdnv{
    margin-bottom:2rem;
    font-size:0;
    border:none;
  }
  #sdnv li{
    display:inline-block;
    width:50%;
    font-size:1.2rem;
    border-right:1px solid #888;
    border-bottom:1px solid #888;
  }
  #sdnv li:nth-child(odd){
    border-left:1px solid #888;
  }
  #sdnv li:first-child,#sdnv li:nth-child(2){
    border-top:1px solid #888;
  }
  #sdnv li a{
    padding:1em .3em 1em 1.4em;
    line-height:1.4em;
  }
  .midHid{display:none;}
}

/* ---------------------------------------------------
| header
--------------------------------------------------- */
header{
  padding: 5.5rem 0 0;
  position: relative;
  border-bottom: .3rem solid #2e6eb1;
  z-index:1000;
}
header:before{
  content: "";
  border-top: .5rem solid #2e6eb1;
  width: 25rem;
  position: absolute;
  top: 0;
  left: calc(50% - 25rem);
}
header:after{
  content: "";
  border-top: .5rem solid #00a5d9;
  width: 25rem;
  position: absolute;
  top: 0;
  left: 50%;
}
header .header-wrapper{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 0 3.5rem;
}
header p.header-agent{
  font-size: 1.7rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-weight: 500;
  width: 33%;
  position: relative;
  padding: 0 0 0 11rem;
}
header p.header-agent span{
  font-size: 1.4rem;
  display: block;
  margin: .5rem 0 0;
}
header p.header-agent:before{
  content: "";
  background: url(/images/global/aflac-logo.png) no-repeat center center/contain;
  display: inline-block;
  width: 10rem;
  height: 3.4rem;
  position: absolute;
  left: 0;
  top: 0;
}
header p.header-tel{
  color: #2e6eb1;
  font-size: 2.8rem;
  text-align: right;
  width: 33%;
  position: relative;
}
header p.header-tel:before{
  content: "";
  display: inline-block;
  background: url(/images/global/freedial.png) no-repeat center center/cover;
  width: 3.6rem;
  height: 2.3rem;
  margin: 0 .5rem 0 0;
}
header p.header-tel span{
  color: #555555;
  font-size: 1.2rem;
  display: block;
  margin: .5rem 0 0;
}
/*header nav ul li:last-child a{
  color: #c8161d;
}*/
/* --------- responsive --------- */
@media screen and (max-width:767px){
  header{
    padding: 2rem 0 1.7rem;
    height: 6rem;
    position: fixed;
    width: 100%;
    z-index:1000;
    background:#fff;
    border-bottom: 1px solid #2e6eb1;
    box-shadow:0 .2rem .2rem rgba(0,0,0,.2);
  }
  header:before{
    border-top: .3rem solid #2e6eb1;
    width: 50%;
    left: 0;
  }
  header:after{
    border-top: .3rem solid #00a5d9;
    width: 50%;
  }
  header .header-wrapper{
    display: block;
    margin: 0;
  }
  header .header-wrapper img.header-logo{
    width: 15rem;
  }
  header .header-wrapper .header-tel-sp{
    width: 3.4rem;
    height: 3rem;
    position: absolute;
    right: 5.5rem;
    top: calc(50% - 1.6rem);
  }
}
/* ---------------------------------------------------
| #fixedHeader
--------------------------------------------------- */
#fixedHeader{
  position:fixed;
  display:flex;
  justify-content:space-between;
  top:-200px;
  width:100%;
  background:#fff;
  border-bottom: .3rem solid #2e6eb1;
  box-shadow:0 .2rem .2rem rgba(0,0,0,.2);
  transition:.5s;
  z-index:1000;
}
#fixedHeader.show{
  top:0;
}
#fixedHeader figure{
  width:20%;
  padding:1rem 2rem;
}
#fixedHeader figure .header-logo{
  width:100%;
  max-width:200px;
  max-height:30px;
}
#fixedHeader nav{
  width:80%;
}

/* ---------------------------------------------------
| nav
--------------------------------------------------- */
nav ul.pa{
  display:flex;
  justify-content:space-between;
  margin:0 auto;
  color:#555;
}
nav ul.pa a{
  color:#555;
  text-decoration:none;
}
#glnv ul.pa{
  width:80%;
}
nav ul.pa > li{
  display:block;
  position:relative;
  width:19%;
  font-size: 1.6rem;
  text-align:center;
}
nav ul.pa > li span{
  display:block;
  padding:1.2em 0 1em;
  cursor:pointer;
}
nav ul.pa > li span:hover{
  color:#00a5d9;
}
nav li.selected span{
  color:#fff;
  background:#2e6eb1;
}
nav ul.pa > li.selected span:hover{
  color:#fff;
}
.glnv li.selected span{
  border-radius:.5em .5em 0 0;
}
nav ul.ch{
  position:absolute;
  top:3.6em;
  margin:0;
  padding:0 1em;
  color:#fff;
  font-size:.9em;
  background:rgba(46,110,177,.9);
  border-radius:0 0 .5em .5em;
  box-shadow:0 .3em .5em rgba(0,0,0,.3);
  transition:.3s;
}
.glnv ul.ch{
  left:0;
  width:100%;
}
#fixedHeader ul.ch{
  left:-15%;
  width:130%;
}
nav ul.ch li{
  width:100%;
  height:0;
  border-bottom:transparent;
  overflow:hidden;
  transition:.3s;
}
nav ul.ch li:last-child{
  border-bottom:none !important;
}
nav ul.pa li:hover > ul.ch li{
  height:4em;
  border-bottom:1px dashed rgba(255,255,255,.5);
}
nav ul.pa li:hover > ul.ch li.h2x{height:5em;}
nav ul.pa li:hover > ul.ch li.h3x{height:6em;}
nav ul.ch li a{
  display:block;
  padding:1.5em 0;
  color:#fff;
  transition:.3s;
}
nav ul.ch li a:hover{
  color:#00a5d9;
}

/* --------- responsive --------- */
@media screen and (min-width:1200px){
  #fixedHeader ul.pa{
    width:80%;
  }
}
@media screen and (min-width:768px) and (max-width:1199px){
  #fixedHeader ul.pa{
    width:90%;
    margin-left:10%;
  }
}
@media screen and (min-width:850px) and (max-width:999px){
  #fixedHeader ul.pa > li{
    font-size: 1.4rem;
  }
}
@media screen and (min-width:768px) and (max-width:849px){
  #fixedHeader ul.pa > li{
    font-size: 1.3rem;
  }
  #fixedHeader ul.ch{
    padding:0 .5em;
  }
}
@media screen and (max-width:767px){
  #fixedHeader, .glnv{
    display:none;
  }
}

/* ------------------------------------------------
navigation(#navDrawer)
------------------------------------------------ */
#navDrawer{display:none;float:right;}

/* ----- #navDrawer responsive ----- */
@media (max-width:767px) {
  #navDrawer{display:block;position:absolute;top:.1rem;right:1rem;}
  .ndHide{display:none;}
  #ndOpener{
    display:inline-block;
    width:30px;
    height:28px;
    vertical-align:middle;
    cursor:pointer;
  }
  #ndOpener span{
    display:block;
    position:absolute;
    content:"";
    width:25px;height:3px;
    border-radius:3px;
    background:#555;
    box-shadow:0 8px #555,0 16px #555;
  }
  #ndCloser{
    display:none;
    position:fixed;
    z-index:100;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:#000;
    opacity:0;
    transition:.3s ease-in-out;
  }
  #ndCont{
    overflow:auto;
    position:fixed;
    top:0;
    right:0;
    width:90%;
    max-width:330px;
    height:100%;
    background:#fff;
    transition:.3s ease-in-out;
    -webkit-transform:translateX(105%);
    transform:translateX(105%);
    z-index:9999;
  }
  #ndCheck:checked ~ #ndCloser{display:block;opacity:.5;}
  #ndCheck:checked ~ #ndCont{
    -webkit-transform:translateX(0%);
    transform:translateX(0%);
    box-shadow:-6px 0 25px rgba(0,0,0,.2);
  }
  /* ----- nav部分 ----- */
  #ndCont ul li a,#ndCont ul li label{
    display:block;
    margin:0;
    padding:1em .5em;
    color:#333;
    text-decoration:none;
    cursor:pointer;
  }
  #ndCont ul.pa > li{border-bottom:1px solid #999;}
  #ndCont ul.ch{
    height:0;opacity:0;
    padding-left:2em;
    overflow:hidden;
    transition:.3s;
  }
  #ndCont ul.ch li{border-top:1px dashed #999;}
  #ndCont ul.pa > li a,#ndCont ul.ch li a,#ndCont ul li label{position:relative;}
  #ndCont ul.pa > li a::after,#ndCont ul.ch li a::after,#ndCont ul li label::after{
    position:absolute;
    top:0;bottom:0;
    right:.5em;
    margin:auto;
    content:"";
    width:.4em;height:.4em;
  }
  #ndCont ul.pa > li a::after,#ndCont ul.ch li a::after{
    border-top:2px solid #60c1c3;
    border-right:2px solid #60c1c3;
    transform:rotate(45deg);
  }
  #ndCont ul li label::after{
    border-top:2px solid #999;
    border-right:2px solid #999;
    transform:rotate(135deg);
  }
  #ndCont input{display:none;}
  #ndCont input:checked + ul.ch{height:auto;opacity:1;}
}




/* ---------------------------------------------------
| footer
--------------------------------------------------- */
footer{
  background: #f9f9f9;
}
footer .footer-wrapper{
  width: 108rem;
  margin: 0 auto;
  padding: 3rem 0;
}
footer .footer-wrapper::after{content:"";clear:both;display:block;}
footer .pmark{float:right;width:80px;height:80px;}
footer .pmark img{width:80px;height:80px;}
footer .footer-wrapper dl{
  display: flex;
  align-items: center;
}
footer .footer-wrapper dl dt{
  width: 23.5rem;
  margin: 0 3rem 0 0;
  padding: 0 3rem 0 0;
  border-right: .1rem solid #555555;
}
footer .footer-wrapper ul{
  display: flex;
  margin-top:1.5em;
}
footer .footer-wrapper ul li{
  margin: 0 2rem 0 0;
  padding: 0 2rem 0 0;
  border-right: .1rem solid #555555;
}
footer .footer-wrapper ul li:last-child{
  margin:0;
  padding:0;
  border-right:none;
}
footer .footer-wrapper ul li a{
  text-decoration: underline;
}
footer .footer-wrapper ul li a:hover{
  text-decoration: none;
}
footer .footer-copyright{
  background: #2e6eb1;
  padding: 1rem 0;
}
footer .footer-copyright p{
  color: #ffffff;
  font-size: 1.2rem;
}

/* --------- responsive --------- */
@media screen and (max-width:767px){
  footer .footer-wrapper {
    width: 100%;
    padding: 2rem 0 1.5rem;
    display: block;
  }
  footer .pmark,footer .pmark img{width:50px;height:50px;}
  footer .footer-wrapper dl {
    display: block;
  }
  footer .footer-wrapper dl dt {
    width: 100%;
    margin: 0 0 1rem;
    padding: 0;
    border-right: none;
  }
  footer .footer-wrapper dl dt img {
    width: 50%;
    display: block;
    margin: 0 auto 1rem;
  }
  footer .footer-wrapper dl dd {
    text-align: center;
    font-size: 1.2rem;
    line-height: 1.4;
  }
  footer .footer-wrapper ul {
    margin: 1rem 0 0;
    justify-content: center;
  }
  footer .footer-wrapper ul li {
    margin: 0 1rem 0 0;
    padding: 0 1rem 0 0;
    font-size: 1.2rem;
  }
  footer .footer-copyright p {
    font-size: 1rem;
    text-align: center;
    line-height: 1.2;
  }
}


/* ---------------------------------------------------
| お問合せ
--------------------------------------------------- */
#contact{
  margin:6rem auto !important;
}
#contact h2{
  margin-bottom:1em !important;
}
/*#contact .inner p.contact{
  text-align: center;
  font-size: 1.8rem;
  border: .1rem solid #555555;
  padding: 1rem 0;
  margin: 3rem 0 2rem;
  border-radius: 1rem;
}*/
#contact .inner p.contact-tel{
  text-align: center;
  font-size: 4.4rem;
}
#contact .inner p.contact-tel a{
  position:relative;
  padding-left:5rem;
  color: #2e6eb1;
  text-decoration:none;
}
#contact .inner p.contact-tel a:before{
  position:absolute;
  top:.2em;
  left:0;
  content: "";
  background:url(/images/global/icon-phone.png) no-repeat center center/contain;
  width:37px;
  height:44px;
  margin: 0 1rem 0 0;
}
#contact .inner p.contact-tel span{
  color: #555555;
  display: block;
  font-size: 1.4rem;
  margin: 1rem 0 0 2rem;
}
/* --------- responsive --------- */
@media screen and (min-width:768px) and (max-width:1079px) {
  #contact .inner{
    width:96%;
    margin:0 auto;
  }
}
@media screen and (max-width:767px){
  #contact{
    margin:3rem auto !important;
  }
  #contact .inner p.contact{
    font-size: 1.4rem;
    padding: .5rem 0;
    margin: 2rem 0 1rem;
    border-radius: .5rem;
  }
  #contact .inner p.contact-tel{
    font-size: 2.5rem;
  }
  #contact .inner p.contact-tel span{
    font-size: 1.2rem;
    margin: .5rem 0 0;
  }
  #contact .inner p.contact-tel a{
    padding-left:2.5rem;
  }
  #contact .inner p.contact-tel a:before{
    top:0em;
    width:18px;
    height:22px;
  }
}
