@charset "UTF-8";
/* =======================================

    lp_top.css

========================================== */

/* common
========================================== */


html,body {
	width: 100%;
}
body {
  overflow-x: hidden;
}
body#lp-top main {
    font-family: "GenJyuuGothic";
}
.pc {
    display: block;
}
.sp {
    display: none;
}
img,h1,h2,h3,p,li,a,div {
    transition: all .1s ease;
}
a:hover {
    opacity: 0.8;
}
.header-menu-left-55th,
.header.is-fixed .header-menu-left-55th {
    display: none;
}
.header-menu-right {
    display: none;
}
.youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    max-width: initial;
    margin: 0 auto 0 auto;
}	
.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    max-width: 100% !important;
    width: 100% !important;
    height: 100% !important;
}

/* fv
========================================== */

.fv {
    width: 100%;
    background: #ffecc3;
    position: relative;
    margin: 0 auto 2em auto;
}
.fv .inner {
    display: table;
    margin: 0 auto;
    text-align: center;
}
.fv .inner h1 img {
    margin: 0 auto;
    text-align: center;
}
.fv .flower-left,
.fv .flower-right {
    position: absolute;
    width: 23%;
}
.fv .flower-left {
    bottom: 0;
    left: 0;
}
.fv .flower-right {
    top: 0;
    right: 0;
}


/* section
========================================== */

section {
  max-width: 1000px;
  margin: 0 auto;
}
section.jojo,
section.title,
section.anchor {
    max-width: 960px;
}
section.jojo {
    margin: 0 auto 3% auto;
}
section.jojo a,
section.title figure {
    display: table;
    margin: 0 auto;
}
section.title {
    margin: 0 auto 2em auto;
}
section.title .catch {
  
}
section.anchor ul {
    display: flex;
    justify-content: space-between;
    margin: 0 auto 1em auto;
    align-items: flex-start;
}
section.anchor ul li figure,
section.anchor ul li p {
    display: table;
}
section.anchor ul li figure {
    margin: 0 auto 1em auto;
}
section.anchor ul li p {
    margin: 0 auto;
}
#one,
#two {
    padding-top: 60px;
    margin-top: -60px;
}
section.banners {
  width: 100%;
  margin: 0 auto 3em auto;
}
section.banners ul.lineup {
    border-radius: 10px;
    padding: 1em;
    position: relative;
}
section.banners li.one ul.lineup {
    background: #FEE9EA;
}
section.banners li.two ul.lineup {
    background: #FFE1CF;
}
section.banners ul.lineup li {
    padding-left: 2em;
    font-size: 1.65rem;
    line-height: 1.5;
    margin-bottom: 0.5em;
}
section.banners ul.lineup li:last-child {
  margin-bottom: 0;
}
section.banners li.one ul.lineup li {
  background: url("../images/check_one.jpg") no-repeat 0 0.15em;
}
section.banners li.two ul.lineup li {
  background: url("../images/check_two.jpg") no-repeat 0 0.15em;
}
section.banners .btns ul.lineup {
    display: none;
}
section.banners .bnr-bg {
    position: absolute;
    top: 0;
}
section.banners .bnr-bg.cam1 {
    left: 0;
    top: 0;
    height: 100%;
}
section.banners .ribbon {
    padding: 1em 2.5em 1em 2em;
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
}
section.banners .ribbon p:first-of-type {
    color: white;
    font-size: 3.25rem;
    line-height: 1;
}
section.banners .ribbon p:first-of-type span {
    font-size: 60%;
}
section.banners .ribbon p:nth-child(2) {
    background: white;
    line-height: 1;
    border-radius: 2em;
    padding: 0.4em 1.5em;
    font-size: 2.25rem;
    font-weight: bold;
    box-shadow: 3px 3px 6px 0px rgba(0, 0, 0, 0.16);
}
section.banners li.one .ribbon p:nth-child(2) {
    color: #F16484;
}
section.banners li.two .ribbon p:nth-child(2) {
    color: #E56B20;
}
section.banners li.one .ribbon {
    background: url(../images/banners_bg_one.png) center / 100% 100% no-repeat;
}
section.banners li.two .ribbon {
    background: url(../images/banners_bg_two.png) center / 100% 100% no-repeat;
}
section.banners .ribbon:before {
    content: "";
    position: absolute;
    bottom: -10px;
    width: 0;
    height: 0;
    border-style: solid;
}
section.banners li.one .ribbon:before,
section.banners li.two .ribbon:before {
    border-width: 0 20px 10px 0;
    left: 0;
}
section.banners li.one .ribbon:before {
    border-color: transparent #BF2A4D transparent transparent;
}
section.banners li.two .ribbon:before {
    border-color: transparent #954414 transparent transparent;
}
section.banners li .inner {
    position: relative;
    max-width: 960px;
    margin: 0 auto;
    padding: 2em;
    border-radius: 0 0 10px 10px;
}
section.banners li.one .inner {
    background: #FEE9EA;
    margin-bottom: 3em;
}
section.banners li.two .inner {
    background: #FFE1CF;
}
section.banners li.one .text dd {
  color: #e54779;
}
section.banners li.two .text dl {
    display: table;
}
section.banners li.two .text dd {
  color: #73a137;
  position: relative;
}
section.banners li.two .text dl:after {
    content: "";
    width: 122px;
    height: 101px;
    display: table;
    position: absolute;
    right: -130px;
    bottom: 0;
    aspect-ratio: 122 / 101;
    background: url("../images/new.png") center / contain no-repeat;
}
section.banners li.two .text dd span {
  font-size: 70%;
  margin-right: 0.5em;
} 
section.banners .whitebox {    
    background: white;
    border-radius: 10px;
}
section.banners .whitebox.one {
    margin-bottom: 5em;
}
section.banners .whitebox.two {
    margin-bottom: 3.5em;
}
section.banners .whitebox .box {
    display: flex;
    justify-content: space-between;
    position: relative;
    padding: 1.5em 1.5em 0 1.5em;
}
section.banners .whitebox.one .box {
    margin-bottom: -0.5em;
}
section.banners li.one .whitebox.two .box {
    align-items: flex-end;
    padding: 3em 1.5em 0 1.5em;
    margin-bottom: -0.5em;
}
section.banners li.two .whitebox.two .box {
    align-items: flex-start;
    padding-top: 3.5em;
    margin-bottom: -1.5em;
}
section.banners .whitebox.two picture img {
    margin: 0 0 0 auto;
}
section.banners .cvbtn figure {
    display: table;
    margin: 0 auto 0.3em auto;
}
section.banners .cvbtn a {
    display: table;
    margin: 0 auto;
}
section.banners .inner .whitebox figure.before,
section.banners .inner .whitebox figure.balloon {
    position: absolute;
}

section.banners .inner .whitebox figure.before {
    left: 0;
    top: 0;
}
section.banners .inner .whitebox figure.balloon {
    top: -2em;
    left: 0;
    z-index: 1;
}
section.banners .inner .whitebox .left {
    position: relative;
    display: flex;
    justify-content: center;
}
section.banners .inner .whitebox.one .left {
    width: 45%;
    flex: 1;
}
section.banners li.two .whitebox.one .left {
    width: 100%;
    flex: initial;
}
section.banners .inner .whitebox.two .left {
    width: 50%;
}
section.banners .inner .whitebox .right {
    width: 45%;
}
section.banners .inner .whitebox.two figure {
    position: absolute;
    top: -1em;
    right: 2%;
}
section.banners li.one .inner .whitebox.one .left.one {
    background: url("../images/banners_ha_bg.jpg") center / cover repeat;
}
section.banners li.two .inner .whitebox.one .left.one {
    display: block;
    position: relative;
}
section.banners .inner .whitebox.one picture {
    position: absolute;
    bottom: 0;
    right: 0;
}
section.banners li.two .whitebox.one picture {
    position: relative;
    width: 100%;
}
section.banners li.two figure.new {
    position: absolute;
    z-index: 1;
    left: -12px;
    top: -10px;
}
section.banners .movie {
    width: 55%;
    flex: 1.25;
}
section.banners .cvbtn,
section.cv .cvbtn {
    display: table;
    margin: 0 auto;
    position: relative;    
}
section.cv .cvbtn {
    margin: 0 auto 4em auto;
}
section.banners .whitebox.one .cvbtn {
    transform: translateY(30%);
}
section.banners .whitebox.two .cvbtn {
    transform: translateY(50%);
}
section.banners .banner-last {
    display: table;
    margin: 0 auto;
    position: relative;
}
section.banners .banner-last.first {
    margin: 1em auto 2em auto;
    display: none;
}
section.banners .banner-last .medal {
    position: absolute;
    left: -1em;
    top: -2em;
    z-index: 1;
}
section.banners .enlarge ul {
    display: flex;
    justify-content: space-between;
}
section.banners .enlarge p {
    text-align: center;
    padding: 0.5em 0 0 0;
}
.modaal-container picture {
    display: table;
    top: 10vh;
    position: relative;
    margin: 0 auto;
}
#inline1,
#inline2,
#inline3 {
	display: none;
}
section.online {
  padding: 8% 0;
  margin: 0 auto;
}
section.online a {
  display: flex;
  align-items: center;
  margin: 0 auto;
  width: 678px;
  height: 160px;
  padding-left: 1.5em;
  background: url(../images/banner_online.png) no-repeat;
}
section.online a p {
  color: white;
  font-size: 3rem;
  line-height: 1.4;
  text-align: center;
  font-weight: 500;
}
section.online a p i {
    margin-right: 0.5em;
}
section.online a p span {
  display: block;
  font-size: 70%;
}
section.online a p span br {
    display: none;
}
section.pamph a {
    display: table;
    margin: 0 auto;
}
section.pamph {
    margin: 0 auto 6em auto;
}


/* footer
========================================== */

.footer-bnrlink,
.footer-contents,
.footer-links,
.footer-toggle,
.footer-lang,
.footer-mark {
    display: none;
}
.footer-logo {
    border-bottom: 0;
}
.helpfeel-content {
    display: none;
}

/* campaign
========================================== */
.cpbanner {
    position: relative;
    z-index: 2;
}
.cpbanner.pc {
    text-align: center;
}
.cpbanner img {
    margin: 0 auto 0 auto;
    position: relative;
    left: 0;
}

@media screen and (max-width : 64em) {
    
    section {
      max-width: 95%;
    }
    section.jojo,
    section.title,
    section.anchor {
        max-width: 95%;
    }
    section.panph a {
        font-size: 4vw;
    }
    section.banners {
        width: 95%;
    }
    section.title {
        margin: 0 auto 1em auto;
    }
    section.banners .inner .whitebox picture {
        width: 95%;
    }
    section.banners .inner .whitebox figure.before {
        width: 25%;
    }
    section.banners .inner .whitebox figure.balloon {
        width: 25%;
    }
    section.banners li .inner {
        padding: 1.5em;
        max-width: 95%;
    }
    section.banners .inner .whitebox .box {
        padding: 1.25em 1.25em 0 1.25em;
    }
    section.banners .inner .whitebox.two figure {
        position: relative;
        width: 100%;
    }
    section.anchor ul li {
        width: 49%;
    }
    section.banners .ribbon p:first-of-type {
        font-size: 2.8rem;
    }
    section.banners .ribbon p:nth-child(2) {
        font-size: 2rem;
    }
    section.banners .cvbtn {
        width: 50%;
    }
    section.banners li.two figure.new {
        max-width: 12%;
    }
    section.cv .cvbtn {
        width: 60%;
    }
    section.banners ul.lineup li {
        font-size: 1.35rem;
    }
    section.banners .banner-last .medal img {
        width: 100%;
        max-width: 100%;
    }
    section.banners .banner-last .medal {
        max-width: 12%;
    }
    .ladies-rn-fixedMenu {
        display: none;
    }
}

@media screen and (max-width: 47.938em) {
    
    .header-call .__55th {
        display: none;
    }
    .header-call .__logo {
        left: 20px;
    }
    .header {
        height: 40px;
    }
    main {
        padding-top: 40px;
    }

}

@media screen and (max-width : 42em) {

    /* footer */
    
    a[href^="tel:"] {
        display: block;
    }
    
    /* common */
    
    .pc {
        display: none;
    }
    .sp {
        display: block;
    }
    body#lp-top {
        min-width: 100%;
    }
    
    /* fv */
    
    .fv {
        margin-bottom: 5%;
    }
    .fv .inner h1 img {
        max-width: 100%;
    }
    
    /* section */

    section {
      max-width: 95%;
      margin: 0 auto;
    }
    #one,
    #two {
        padding-top: 40px;
        margin-top: -40px;
    }
    section.jojo {
        margin: 0 auto 8% auto;
    }
    section.anchor ul {
        margin: 0 auto 2em auto;
    }
    section.banners {
        margin: 0 auto 2em auto;
    }
    section.banners li {
      border-radius: 0 0 10px 10px;
      margin-bottom: 5em;
    }
    section.banners li:last-child {
        margin-bottom: 0;
    }
    section.banners .enlarge ul li {
        margin-bottom: 0;
    }
    section.banners .btns ul.lineup {
        display: block;
        width: 90%;
        margin: 0 auto 1em;
    }
    section.banners ul.lineup {
      padding: 0.8em;
      margin: 0 auto 1em auto;
    }
    section.banners .whitebox.two .left.two {
        width: 100%;
    }
    section.banners .ribbon {
      font-size: 1.8rem;
      padding: 1.5em 1em 0.8em 1em;
      display: block;
    }  
    section.banners li.one .ribbon {
        background: url("../images/banners_bg_one_sp.png") right / 100% 100% no-repeat;
    }
    section.banners li.two .ribbon {
        background: url("../images/banners_bg_two_sp.png") right / 100% 100% no-repeat;
    }
    section.banners li.two .text {
        background: url(../images/new_sp.png) 95% 95% / 4.5em auto no-repeat;
    }
    section.banners li.two .text,
    section.banners li.one .text {
        padding: 2em 1em 0 1em;
    }
    section.banners li.two .text dl:after {
        content: none;
    }
    section.banners li.two .text dd {
      /* padding-left: 11vw;
      background: url(../images/new_sp.png) no-repeat 0 60%;
      background-size: 10vw; */
    }
    section.banners .inner .whitebox.one picture {
        position: relative;
    }
    section.banners li.two .text dd span {
      font-size: 70%;
      margin-right: 0.5em;
    }
    section.banners li .inner {
        padding: 2em 1em 1em 1em;
    }
    section.banners .inner .whitebox.one,
    section.banners .inner .whitebox.two {
        margin-bottom: 4em;
    }
    section.banners .whitebox.one .left.one {
        background: none !important;
        width: 100%;
    }
    section.banners .inner .whitebox .box {
        flex-flow: column;
        padding: 1em 1em 0 1em;
    }
    section.banners li.two .whitebox.two .box {
        padding: 1em 1em 0 1em;
    }
    section.banners .inner .whitebox .left,
    section.banners .inner .whitebox .movie,
    section.banners .inner .whitebox figure.balloon {
        width: 100%;
    }
    section.banners .inner .whitebox picture {
        position: relative;
        width: 100%;
    }
    section.banners .inner .whitebox .right {
        width: 100%;
    }
    section.banners .inner .whitebox.two figure {
        position: relative;
        top: initial;
        right: initial;
        margin: 0 auto 1em auto;
    }
    section.banners .ribbon p:nth-child(2) {
        position: absolute;
        font-size: 1.5rem;
        top: -1em;
        border: 1px solid;
        display: table;
        text-align: center;
        transform: translate(-50%, 0px);
        -webkit-transform: translate(-50%, 0px);
        -ms-transform: translate(-50%, 0px);
        left: 50%;
        right: 0;
        white-space: nowrap;
    }
    section.banners .ribbon p:first-of-type {
        font-size: 2.8rem;
    }
    section.banners .ribbon p:first-of-type span {
        font-size: 65%;
    }
    section.banners .inner .whitebox figure.balloon {
        top: -2.5em;
    }
    section.banners .cvbtn {
        width: 90%;
    }
    section.banners li.two figure.new {
        max-width: 28%;
    }
    section.cv .cvbtn {
        width: 90%;
        margin: 0 auto 2em auto;
    }
    section.banners .banner-last .medal {
        max-width: 28%;
        top: -1em;
        left: 0;
    }
    section.online a {
      width: 100%;
      height: 0;
      padding-top: 24.2744063325%;
      background: url(../images/banner_online_sp.png) no-repeat;
      background-size: 100% auto;
      position: relative;
    }
    section.online a p {
      font-size: 5vw;
      position: absolute;
      top: 0;
      bottom: 0;
      margin: auto;
      height: 3.5em;
    }
    section.online a p i {
        display: none;
    }
    section.online a p span br {
        display: block;
    }
    section.pamph {
        margin: 0 auto 3em auto;
    }
    
    
    /* campaign */
    
    .cpbanner {
        padding: 0 3% 0 3% !important;
        position: relative;
        overflow: hidden;
    }
    .cpbanner.sp a {
        background-image: none !important;
        padding: 0 !important;
        margin: 0 0 1em 0 !important;
    }
    .cpbanner.sp.cam2 {
    }
    .cpbanner img {
        left: 0;
    }
    section.banners .bnr-bg.cam2 {
        left: 0;
        top: 0;
    }
    .header.is-fixed .header-call {
        display: block;
    }
    .header.is-fixed {
        height: 40px;
    }
}