@charset "UTF-8";
/*common=========================*/
@font-face {
  font-family:'NotoMid'; font-weight: 500; font-style: normal;
  src: url('../font/NotoSansJP-Medium-min.otf') format('opentype');
}
@font-face {
  font-family:'NotoBd'; font-weight: 700; font-style: normal;
  src: url('../font/NotoSerifJP-Bold-min.otf') format('opentype');
}
@font-face {
  font-family:'NunitoBd'; font-weight: 700; font-style: normal;
  src: url('../font/NunitoSans-Bold.ttf') format('truetype');
}
html {text-size-adjust: none; font-size: clamp(0.9rem, 0.95rem + 0.4vw, 1rem); font-family:'NotoReg', sans-serif;}
* { margin: 0; padding: 0; box-sizing: border-box; scroll-behavior: smooth; 
  -webkit-text-size-adjust: 100%;}
body {  width: 100%; font-size: 1rem; line-height: 1.4; font-family: 'NotoMid',sans-serif; background: #fff;color: #444;}
li {list-style-type: none;}
article img, article picture, article video { display: block; width: 100%; height: 100%; line-height: 0; margin: 0; padding: 0;}
a { color: inherit; text-decoration: none;  font-family: 'NotoBd', sans-serif; cursor: pointer;}
h2, h3, h4 { font-family: 'NotoBd',sans-serif;}
.eng, h2 .eng, h3 .eng, h2.eng, h3.eng {font-family: 'NotoBd',sans-serif;}
.resize_mini{font-size: 0.865em;}

.anc{
  margin-top: -70px;
  padding-top: 60px;
}
.pc-none{display: none;}
.wrapper {
  overflow-x: hidden;
  filter: drop-shadow(0 0 8px #abc6dd);
  container: wap-cont / inline-size;
  background-color: #fcfcfc;
}

/*main
=========================*/
.movie { 
  line-height: 0; width: 100%; 
  /* height: 56.25vw; */
}
.goldfont {color: #bb9954;} 
.bluefont {color: #004884}
.redfont {color: #b5091f}
.blackfont{color: #111;}
.whitefont{color: #fff;}
.asterisk { font-size: 0.65em; vertical-align: top;}
.attend, .copyright p{
  font-size: 11px!important;
  transform: scale(0.9);
  line-height: 1.3;
  width: 110%;
  text-align: left;
  transform-origin: left;
}
.copyright p{transform: scale(0.9); font-size: 12px!important; width: 100%;transform-origin: center; }
.attend p, .vitamin-b{margin: 0.2em 0; font-size: 11px!important;  }
.salonguide_table .attend p{font-size: 11px; margin: 0.5% 0;}
.salonguide-yokohama .attend {text-align: right; padding: 1% 0.5%; margin-bottom: -8%;}
.salonguide_table .attend {margin: 1% 0 0 -4%;}
.salonguide-sendai img,.salonguide-yokohama img{object-fit: cover;height: 56.25vw;}
.sendai_photo,.yokohama_photo{margin-bottom: 10px;}
.salonguide-sendai,.salonguide-yokohama{background-color: #111; }
.sendai,.yokohama{padding-top: 10%; margin-top: 3px;}


/*header========================*/
.header {position: fixed; z-index: 9999;top: 0; left: 0; background: #f6f6f6; width: 100%; min-height: 60px;
   /* height: 16vw;  */
}
.header .logo {margin: auto; position: absolute;  bottom: 10px; left: 0;  right: 0;  width: 160px; height: 42px;}
.header .menu {position: absolute;  bottom: 20px; right: 15px; width: 25px; height: 20px;}
.header.mini { height: calc((100vh - 190vw) / 2);}
.header.mini .menu, .header.mini .logo { display: none;}
.header.logo_none .logo { display: none;}
.menubtn {height: 100%; width: 100%;}
.menubtn span {
  width: 100%;
  display: block;
  border-top: solid 2px #111;
  position: absolute;
  top: 40%;
  transition: all 0.3s;
  top: 0;
  opacity: 0;
}
.menubtn::before, .menubtn::after {
  width: 100%;
  display: block;
  content: " ";
  border-top: solid 2px #111;
  position: absolute;
  transition: all 0.3s;
}
.menubtn::before {top: 50%; transform: rotate(45deg);}
.menubtn::after {bottom: 42%; transform: rotate(-45deg);}
.menubtn.active span {top: 40%; opacity: 1;}
.menubtn.active::before {top: 0; transform: rotate(0deg);}
.menubtn.active::after {bottom: 0; transform: rotate(0deg);}
.menu_list {
  width: 100%; height: 100vh;
  transition: all 0.3s;
  display: none; left: 0;
  position: fixed;
  z-index: 0;
  top: 6.5vh;
  background: rgba(0, 0, 0, 0.85);
}
.menu_list ul {
  display: flex; flex-wrap: wrap;
  align-items: center;  align-content: center;
  width: 80%; margin: 5vh auto 0;
}
.menu_list li { width: 100%; color: #fff; font-size: 16px; font-weight: normal;}
.menu_list li a {
  border-bottom: dashed 2px #666;
  display: block;
  margin-top: 1.5em;
  padding-bottom: 1.5em;
  position: relative;
}
.menu_list li a::after {
  content: " ";
  width: 0.6em;
  height: 0.6em;
  border: 2px solid;
  border-color: #fff #fff transparent transparent;
  transform: rotate(45deg);
  position: absolute;
  right: 0.2em;
  top: 0.25em;
  transition: all 0.3s;
}
.footer2 { 
  position: fixed; width: 100%; height: calc((100vh - 190vw) / 2); bottom: 0; left: 0; z-index: 9999;}
/*article========================*/
article {  position: relative;  z-index: 10; overflow: hidden;}
.main { background: #111; color: #fff;}
.link_btn { width: 100%; text-align: center; margin: 4% 0;}
.link_btn a, .link_btn_other a {
  width: 72%;  
  max-width: 380px;
  display: block;  position:  relative; 
  color: #fff;
  font-size: 1.165rem; 
  margin: 0 auto; padding: 4%;
  line-height: 1; letter-spacing: 0.08em;
  text-align: center;
  background: #004884;
  font-family: 'NotoBd', sans-serif; 
  position: relative;
  overflow: hidden;
  animation: btnup 3s ease-in-out infinite;
}
.link_btn a::after {
  content: '';
  position: absolute;
  top: -10%;
  left: -20%;
  width: 40px;
  height: 100%;
  transform: scale(2) rotate(20deg);
  background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, .5) 100%, rgba(255, 255, 255, 0) 0%);
  animation: kirakira 2.5s ease-in-out infinite;
}
@keyframes kirakira {
  from { left: -5%; opacity:0} 10% { left: 105%; opacity:10} 100% { left: 105%; opacity:100}
}
@keyframes btnup {
  from, 100%{transform: scale(1);}  50%{ transform: scale(1.075);}
}
.link_btn a span, .link_btn_other a span {vertical-align: middle;}
.link_btn .yoyaku_info, .link_btn_other .yoyaku_info { margin-top: 3.5%; text-align: center; color: #bb9954; font-size: 0.875rem;}

/*offer========================*/
.offer_main {margin-top: 68px;}
.offer_top .offer_campaign{ background: url(../images/addition/offer_bg.png) center/cover repeat; text-align: center; padding: 7% 0 10%;}
.offer_top .offer_campaign_inner { width: 95%; margin: 0 auto 2%; padding: 6% 2% 6%; background: #fff;  border: solid 3px #164e7d;}
.offer_main_ttl{ width: 95%; margin: 0 auto 2%;  color: #004884;}
.offer_main_ttl .resize_max{font-size: 1.5rem; padding: 0 4px; }
.offer_course{margin-top: 10px;}
.offer_price{margin: 4% 0 6%;}
.ex100{width: 60%; margin: 0 auto 2%;}
.offer_campaign_inner .attend.redfont{ padding-left: 3%;}
.offer_campaign_parts .attend, .offer_campaign .attend{margin: 0 4%; width: 102%;}
.offer_campaign_mainsub .attend{margin: 0 7.5%; padding-left: 7.5%;}
.offer_campaign_parts{
  position: relative;
  border: 5px solid #1e5583;
  border-image: linear-gradient(to right,#004884 0%, #f0f56e 100%);
  border-image-slice: 1; 
}
.offer_campaign_main .price{ width: 95%; margin: 3% auto 0; text-align: left;}
.offer_campaign_parts h3 { margin: 1% 0; font-size: 1.25rem; line-height: 1.3;}
.offer_hed {
  font-size: 0.875rem;
  border: solid 1px #ccc;
  display: inline-block;
  padding: 0 .2em 0;
  color: #004884;
  background: #fff;
  font-family: 'NunitoMid', sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: .01em;
}

.woffer_link{
  background-color: #fff; border: solid 2px #004884; padding: 2%; width: 95%; margin: 5% auto 0;}
.offer_sub .offer_campaign_inner{ position: relative;}
.offer_ex { position: absolute; top: -2px; left: -1px; width: 27%; max-width: 150px; height: auto;}
.offer_w .offer_campaign{background-image:  linear-gradient(180deg,#164e7d 0%, #588bb5 50%, #004884 100%); padding: 10% 0; text-align: center;}
.offer_w .offer_campaign_inner { width: 95%; margin: 0 auto 2%; padding: 4% 2% 6%; background: #fff; }
.offer_w  h3{width: 95%; margin: 0 auto 3%;}
.offer_campaign_inner .attend{margin-left: 2%;}
/* 202306 add */
.other_pages {background: #fefefe; color: #111; margin-top: 7%;}
.other_pages section {padding-top: 4vw;}
.other_pages h2 {font-size: 1.625rem; letter-spacing: 0.05rem;  color: #939393; text-align: center;}
.other_pages .subtitle { text-align: center;}
.other_pages p {font-size: 0.9375rem; letter-spacing: 0.05rem; line-height: 1.4;}
.other_pages .gallery {padding: 2% 0; background: #111;}

/* インフォメーション */
.infomation { text-align: center;}
.infomation h2 { width: 70%; margin: 8% auto 8%;}
.infomation .gallery {  background: #ccc; max-height: 200px;}
.infomation_text {padding: 0 2%; margin: 0 0 12%;}
.infomation_text p {font-family: 'NotoMid', sans-serif; color: #444; line-height: 2;}
.infomation_text .bold { font-family: 'NotoBd', sans-serif; margin-bottom: 3.5%;}
.snapshot {margin: 14% 8% 12%;}

/* 店舗情報 */
.salonguide {  background: #eee;}
.salonguide_area{margin-top: 6%;}
.salonguide_photo { display: flex; height: 27vw; max-height: 335px; padding: 0 0.5%; background: #111;}
.salonguide_photo picture { width: 100%; height: 100%; padding: 1.5% 0.8%;}
.salonguide_photo picture img { width: inherit; object-position: top center; object-fit: cover;}
.salonguide_text {padding: 8% 6% 6%;}
.sendai_text h3 span{font-size:1rem ;}
.salonguide_subtitle{color: #b8944a; font-family: 'NotoBd', sans-serif; }
.salonguide_text h3{margin-bottom: 0.5%;}
.salonguide_table { font-size: 0.875rem;}
.salonguide_table > * + * { border-top: solid 1px #aaa; border-bottom: solid 1px #aaa;}
.salonguide_table dl { padding: 3% 0; line-height: 1.6; display: flex; align-items: flex-start; justify-content: flex-start;}
.salonguide_table dt {background: #fff; width: 6em; padding: 0.5em; margin-right: 3%; text-align: center;}
.salonguide_table .attend {margin: 1% 0 0 -4%;}
.link_btn_salon {margin: 8% auto 5%;}
.link_btn_salon a {
  position: relative;
  display: block;
  background: #939393;
  color: #fff;
  text-align: center;
  padding: 2.5% 0;
  font-size: 1rem;
  width: 80%;
  margin: 0 auto;
}
.link_btn_salon a::before {
  content: " "; position: absolute; background: url(../images/main/map.svg) no-repeat;
  width: 1.5em;  height: 1.4em; left: 1em;}
.link_btn_salon .eng { font-weight: 700; font-size: 1.06em;  margin-right: 0.05em;}
.tel_number {
  color: #111; text-align: center; padding: 1em 2em;
  font-size: 0.8125rem;
  border-bottom: solid 1px #444; 
  background: #fff;
}
.tel_net{ background: #aaa; color: #fff; padding: 0.5em;font-size: 0.8125rem;; text-align: center;}
.telguide { background: #fff; display: inline-block; color: #ebebeb; padding: 0.25em 1em; line-height: 1; margin: 0.5em 0 -1.5em;}
.tel_number .number { font-size: 2.15em; margin: 0;  font-family: 'NunitoBd', sans-serif;}
.tel_number span{font-size: 12px;}
.footer_under { padding-bottom: 12%;background: #fff;}
.footer_guide {  font-size: 0.75rem;  padding: 6%;  background: #ebebeb; color: #111; }
.footer_guide h4 {font-size: 0.75rem; font-weight: normal;}
.footer_link {padding: 6%;}
.footer_link li a { font-size: 0.75rem; display: block; color: #004884; border-bottom: solid 1px #666;  padding: 0.8em 0;}
.copyright p{color: #ccc; text-align: center;}
/*swiper========================*/
.swiper-base { width: 100%; height: 25vw; overflow: hidden;}
.swiper-base .swiper-wrapper {transition-timing-function: linear;}
.swiper-base .slider_view { overflow: hidden; }
.swiper-base .slider_view img { transition: all 0.3s;}
.swiper-base .slider_view img:hover {transform: scale(1.2);}
@media screen and (max-width: 393px) {
  .other_pages p{font-size:0.8125rem;}
  .faq_details dt{ font-size: 0.8125rem;}
  .link_btn a, .link_btn_other a {font-size: 0.95rem;}
}
@media screen and (max-width: 320px) {
  .other_pages p {font-size: 0.7rem;}
  .link_btn_salon a{font-size: 0.85rem;}
}

/*snapshot========================*/
.snapshot_swiper { position: relative;  width: 96%;  margin: 12% auto}
.snapshot_swiper .swiper-slide { width: 60%; position: relative; transform: translateX(50%);}
.snapshot_swiper .swiper-slide:nth-child(odd) .slider_view { transform: rotate(5deg);}
.snapshot_swiper .swiper-slide:nth-child(even) .slider_view {transform: rotate(-5deg);}
.snapshot_swiper .swiper-slide.swiper-slide-active .slider_view {transform: rotate(0deg); z-index: 10000;}
.snapshot_swiper .swiper-slide img {opacity: 0.4; transition: all 0.3s;}
.snapshot_swiper .swiper-slide.swiper-slide-active img {opacity: 1;}
.snapshot_swiper .slider_view img {width: 94%; margin: 2% auto 0;}
.snapshot_swiper .slider_view.large {margin-top: -5%;}
.snapshot_swiper .slider_view.large img {  width: 58%;}
.snapshot_swiper .swiper-button-next, .snapshot_swiper .swiper-button-prev {color: #939393; transform: scale(0.8);}
.snapshot_swiper .swiper-button-next {right: -8%; top: 45%;}
.snapshot_swiper .swiper-button-prev {left: -8%; top: 45%;}
.snap_dummy {width: 87%; height: 50vw; max-height: 300px; background: #ccc;  position: absolute;top: 0; left: 6%; transform: rotate(-5deg);}


/* アンケート */
.questionnaire{background: url(../images/addition/graf_bg.png) center/cover repeat;}
.questionnaire_ttl{background: url(../images/addition/questionnaire_ttl_bg.png) center/100% 100% no-repeat; margin-bottom: 5%;}
.questionnaire_ttl h2{width: 90%; margin: 0 auto; padding: 3% 0 7%;}
.graf{opacity: 0; transform: rotate(45deg) scale(0.1); transition: all .6s; width: 90%; margin: 0 auto;}
.graf.visible{opacity: 1; transform: rotate(0) scale(1);}
.graf_inner{padding: 0 4% 10%;}
.graf_fukidashi{margin-bottom: -5%;}
.voice_list li{margin: 4% 0;}
.graf_inner .attend{text-align: right; margin-top: 5%;}

/* シチュエーション */
.situation{margin-bottom: 10%;}
.situation_ttl{ background: url(../images/addition/situation_bg.png) center/100% 100% no-repeat; margin-bottom: 5%; }
.situation_ttl h2{text-align: center; color: #fff; font-size: 1rem; padding: 3% 0 5%;}
.situation_item{display: flex; padding: 0 2%; flex-wrap: wrap;}
.situation_list{width: 50%; padding:  0 2%; margin-bottom: 4%;}
.situation_list p{background-color: #1468b1; color: #fff; font-size: 0.875rem; text-align: center; padding: 4% 0;}
.situation_list picture{height: 80%;}
.situation_list img{object-fit: cover; object-position: center;}

/* ネイルコースの流れ */
.nail_taiken{ background-image: linear-gradient(180deg, rgba(1, 122, 239, 1), rgba(98, 223, 255, 1)); padding: 7% 4% 13%;}
.nail_taiken_inner{background-color: #fff; padding: 4% 2%;}
.nail_taiken_ttl{text-align: center; color: #004884;}
.nail_taiken_ttl span{font-size:1rem; font-family:'NotoReg', sans-serif; font-weight: 400;}
.nail_taiken_ttl h2{line-height: 1.2;}
.nail_taiken_ttl p{color: #fff; background-color: #1468b1; padding: 1% 8% 2%; display: inline-block; margin: 5px 0 5%;}
.nail_taiken_stepbox{border: solid 1px #86abc7; border-radius: 20px; display: flex; flex-wrap: nowrap; padding: 5% 2%; margin-top: 3%;}
.nail_taiken_stepbox:first-child{margin-top: 5%;}
.nail_taiken_stepbox picture{width: 38%; padding-right: 10px;}
.nail_taiken_stepdesc{width: 62%;}
.nail_taiken_stepdesc h3{width: 65%; margin-bottom: 3%;height: 20px;}
.nail_taiken_stepdesc div{margin-top: 3%;}
.nail_taiken_stepdesc h3 img{ object-fit: contain; object-position: left;}
.nail_taiken_stepdesc p{font-size: 0.875rem; font-family:'NotoReg', sans-serif;}
.nail_taiken_arrow{ clip-path: polygon(0 0, 100% 0, 50% 100%); background-color: #1369b1; width: 50px; height: 15px; margin: 3% auto;}
.nail_taiken .attend{margin: 5% 0;}

/* 指先がスタイリッシュに */
.nail_after_ttl{ background-image:linear-gradient(0deg, rgba(1, 122, 239, 1), rgba(20, 104, 177, 1));}
.nail_after_ttl h2{color: #fff; text-align: center; padding: 3% 0 ;}
.nail_after_ttl span{font-size: 1rem;}
.nail_after_inner{padding: 5% 4% 10%; }
.nail_after_item{display: flex; justify-content: center; align-items: center; margin-top: 10px;}
.nail_after_item p{width: 50%; text-align: center; color: #004884; font-size: 1.25rem; }
.nail_after_arrow{ clip-path: polygon(0 0, 100% 50%, 0 100%); background-color: #1468b1; width: 35px; height: 30px;  margin: 0 7px;}
.nail_after .attend{margin: 10px 0;}

/* アニメーション */
.fadeUp{ animation-name:fadeUpAnime; animation-duration:0.5s; animation-fill-mode:forwards; opacity:0;}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
    transform: translateY(100px);
  } 
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeUpTrigger{opacity: 0;}

@media (orientation: landscape){
  html {font-size: clamp(1rem, 0.625rem + 0.83vw, 1.25rem)}
  article {width: 100%;}
  .header {height: 60px;}
  .header.mini {  height: 60px;}
  .menu_list { top: 60px;}
  .menu_list ul {margin: 1.5vh auto 0;}
  .menu_list li{ font-size: 14px;}
  .menu_list li a{ margin-top: 1em; padding-bottom: 1em;}
  .footer2 {  height: 0;}
  .link_btn .yoyaku_info, .link_btn_other .yoyaku_info { margin-top: 1.85vw;}
  .link_btn, .link_btn_other{bottom: 0;}
  .movie {line-height: 0; width: auto;}
  h2.menu_title { line-height: 3rem; margin: 1.5% 0;}
  .other_pages {margin-top: 20px;}
  .other_pages section { margin-top: -4%;}
  .top_title{ width: 36%;  margin: 4% auto 4.5%;}
  .snap_dummy {height: 50vw;}
  .cont_frame { width: 80%;margin: 0 auto;}
  .other_pages .package_offer{padding-bottom: 15%;}
  .offer_course { margin-top: 20px;}
  .offer_top .offer_campaign_inner{padding:4% ;}
  .attend p, .vitamin-b{font-size: 12px!important;}
  .nail_taiken_ttl h2{font-size: 1.625rem;}
  .nail_taiken_stepdesc h3 {height: 25px;}
  .attend p, .vitamin-b { font-size: 13px !important;}
  .situation_ttl h2{font-size: 1.125rem;}
  .offer_hed {padding: 0 .7em 0;}
  .offer_price{margin-top: 4%;}
  .other_pages { margin-top: 5%;}

}

@media screen and (min-width: 600px) {
  article { width: 600px;  margin: 0 auto;}
  body{ background: #efefef;}
  .salonguide_table {font-size: 1rem;}
  .salonguide-sendai img,.salonguide-yokohama img{height: 36.25vw ; max-height: 335px;}
  .price h4{font-size: 26px;}
  .offer_campaign_inner h2 {margin: 2% 0  1%; font-size: 30px;}
}

@media screen and (max-width: 475px) {
  h2{font-size: 1.165rem;}
  .pc-none{display: block;}
  .offer_campaign_inner h3 {font-size: 1.25rem;}
  .offer_campaign_inner h2 {font-size: 22px;}
}
