﻿@charset "UTF-8";

/*//////////////////////////////////////////////////

  制作タイトル | f-organics Website

//////////////////////////////////////////////////*/

/* ========================================================
                      * Layout style *
========================================================= */

/* calc(xx * yyrem / zz);
xx：SPデザインの各値
yy：PCデザインのメインコンテンツの横幅（今回のデザインだと460ピクセル）
zz：SPデザインの横幅 */

html {
  font-size: calc(10 * (100vw/600));
}

@media (min-width: 769px) {
  html {
    font-size: calc(10 * (100vw/1600));
  }
}

@media (min-width: 1600px) {
  html {
    font-size: 62.5%
  }

}

footer {
  position: relative;
  z-index: 10;
  margin-top: 0 !important;
}

#share {
  z-index: 111 !important;
  transition: all 0.6s 0.3s;
}

@media screen and (max-width: 768px) {
  #share.move:not(.hidden) {
    translate: 0 calc(-190 * 60rem / 750);
  }
}

/* ========================================================
                      * root *
========================================================= */
:root {
  --color1: #fff;
  --color2: #000000;
  --color3: #BB7B71;
  --color4: #F1E5E3;
  --color5: #C9958D;
  --font_ja: "helvetica-neue-lt-pro", "hiragino-kaku-gothic-pron", sans-serif;
  --font_en: "helvetica-neue-lt-pro", sans-serif;
}

#Wrap {
  width: 100%;
}

/* ========================================================
                      * lp_contents *
========================================================= */

.lp_contents * {
  box-sizing: border-box;
  font-feature-settings: "palt";
  line-height: 1;
  letter-spacing: .075em;
  text-align: center;
}

.lp_contents {
  width: 100%;
  max-width: 60rem;
  height: 100%;
  font-family: var(--font_ja);
  font-weight: 400;
  overflow-x: clip;
  color: var(--color2);
}

.lp_contents .pcOnly {
  display: none;
}

.lp_contents img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

.lp_contents a {
  width: 100%;
  /*height: 100%;*/
  display: inline-block;
}

.lp_contents h1,
.lp_contents h2,
.lp_contents h3,
.lp_contents h4,
.lp_contents h5 {
  font-weight: 300;
}

.lp_contents_inner {
  position: relative;
  z-index: 1;
  overflow: clip;
}


/* ========================================================
                    * SmartPhone *
========================================================= */

.sec_item {
  position: relative;
}

.sec_item .no_click{
  pointer-events: none;
}

.sec_item .fukidashi {
  position: absolute;
  top: calc(141 * 60rem / 750);
  left: 50%;
  transform: translateX(-50%) translateY(0);
  background: var(--color1);
  border-radius: calc(40 * 60rem / 750);
  white-space: nowrap;
  z-index: 2;
  font-feature-settings: "palt";
}

.sec_item .fukidashi.beige {
  background: var(--color5);
}

.sec_item .fukidashi.md {
  padding: calc(25 * 60rem / 750) calc(38 * 60rem / 750);
}

.sec_item .fukidashi.sm {
  padding: calc(23 * 60rem / 750) calc(64 * 60rem / 750);
  top: calc(-79 * 60rem / 750);
  border-radius: calc(59 * 60rem / 750);
}

.sec_item .fukidashi span {
  display: block;
  height: 100%;
  font-size: calc(30 * 60rem / 750);
  color: var(--color3);
  font-weight: 400;
  letter-spacing: .15em;
  position: relative;
}

.sec_item .fukidashi.beige span {
  color: var(--color1);
}

.sec_item .fukidashi.sm span {
  line-height: 1.2;
}

.sec_item .fukidashi span::before {
  content: "";
  background: url(https://toonecosmetics.com/Contents/ProductDetail/4573623430555/img/fukidashi01.svg)no-repeat center;
  width: calc(75 * 60rem / 750);
  height: calc(35 * 60rem / 750);
  position: absolute;
  bottom: calc(-54 * 60rem / 750);
  right: calc(47 * 60rem / 750);
}

.sec_item .fukidashi.beige span::before {
  background: url(https://toonecosmetics.com/Contents/ProductDetail/4573623430555/img/fukidashi02.svg)no-repeat center;
}

.sec_item .fukidashi.md span::before {}

.sec_item .fukidashi.md.toge_reverse span::before {
  transform: scaleX(-1);
  /* bottom: calc(-54 * 60rem / 750); */
  left: calc(47 * 60rem / 750);
  right: auto;
}

.sec_item .fukidashi.sm span::before {
  right: calc(-3 * 60rem / 750);
}

.sec_item .fukidashi.sm.toge_reverse span::before {
  right: auto;
  left: 0;  
  transform: scaleX(-1);
}

.sec_item .fukidashi.lg span::before {
  bottom: calc(-84 * 60rem / 750);
  right: calc(84 * 60rem / 750);
}

.sec_item .fukidashi.lg.toge_reverse span::before {
  right: auto;
  left: calc(82 * 60rem / 750);
  transform: scaleX(-1);
}

.sec_item .visual {
  width: calc(660 * 60rem / 750);
  margin: 0 auto;
}

.sec_item .txt {
  margin-top: calc(107 * 60rem / 750);
  font-size: calc(28 * 60rem / 750);
  line-height: 2;
  letter-spacing: .15em;
  color: var(--color3);
}

.sec_item .img {
  width: calc(460 * 60rem / 750);
  margin: calc(25 * 60rem / 750) auto 0;
}

.sec_item .name {
  color: var(--color3);
  font-size: calc(24 * 60rem / 750);
  letter-spacing: .15em;
  margin-top: calc(30 * 60rem / 750);
}

.sec_item .price {
  color: var(--color3);
  font-size: calc(20 * 60rem / 750);
  font-weight: 400;
  letter-spacing: .15em;
  margin-top: calc(30 * 60rem / 750);
}

.sec_item .price span{
  letter-spacing: .15em;
}

.sec_item .price span:nth-of-type(1) {
  font-size: calc(22 * 60rem / 750);
}

.sec_item .price span:nth-of-type(2) {
  font-size: calc(24 * 60rem / 750);
  margin-left: calc(12 * 60rem / 750);
  margin-right: calc(2 * 60rem / 750);
}

.sec_item .btn {}

.sec_item .btn.btn_buy {
  background: var(--color1);
  border: calc(2 * 60rem / 750) solid var(--color3);
  border-radius: calc(38 * 60rem / 750);
  width: calc(280 * 60rem / 750);
  margin: calc(45 * 60rem / 750) auto 0;
}

.sec_item .btn.btn_buy a {
  color: var(--color3);
  font-size: calc(32 * 60rem / 750);
  font-weight: 400;
  letter-spacing: .15em;
  padding: calc(19 * 60rem / 750) 0;
}

.sec_item .border_box {
  position: relative;
  border: calc(2 * 60rem / 750) solid var(--color3);
  width: calc(700 * 60rem / 750);
  margin: calc(218 * 60rem / 750) auto 0;
  padding-bottom: calc(78 * 60rem / 750);
}

.sec_item .border_box.border_box_01 {}

.sec_item .border_box.border_box_02 {
  margin: calc(180 * 60rem / 750) auto 0;
}

.sec_item .border_box .fukidashi.sm {}

.sec_item .fukidashi.lg {
  position: static;
  transform: none;
  width: calc(600 * 60rem / 750);
  margin: 0 auto 0;
  border-radius: calc(80 * 60rem / 750);
  padding: calc(51 * 60rem / 750) 0;
}

.sec_item .fukidashi.lg .fukidashi_lead {
  font-size: calc(26 * 60rem / 750);
  letter-spacing: .15em;
  line-height: 1.75;
  color: var(--color3);
  text-decoration: underline;
  text-decoration-color: rgba(241, 229, 227);
  text-decoration-thickness: 0.6em;
  text-underline-offset: -0.3em;
  text-decoration-skip-ink: none;
}

.sec_item .fukidashi.lg .fukidashi_txt {
  font-size: calc(22 * 60rem / 750);
  letter-spacing: .15em;
  line-height: 2;
  color: var(--color3);
  margin-top: calc(21 * 60rem / 750);
  display: block;
}

.sec_item .fulodashi_wrap {
  margin-top: calc(70 * 60rem / 750);
}

.sec_item .border_box .txt {
  margin-top: calc(97 * 60rem / 750);
}

.sec_item .border_box_02 .txt {
  margin-top: calc(94 * 60rem / 750);
}

.sec_item .border_box .flex {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-top: calc(43 * 60rem / 750);
  margin-inline: calc(50 * 60rem / 750);
}

.sec_item .border_box .flex.flex_bottom {
  margin-top: calc(60 * 60rem / 750);
}

.sec_item .border_box .flex.column {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: calc(65 * 60rem / 750);
  gap: calc(50 * 60rem / 750);
}

.sec_item .border_box .flex_inner {
  width: calc(260 * 60rem / 750);
}

.sec_item .border_box .flex.column .flex_inner {
  width: calc(380 * 60rem / 750);
}

.sec_item .border_box .process {
  color: var(--color3);
  font-size: calc(22 * 60rem / 750);
  text-align: left;
  letter-spacing: .15em;
  position: relative;
}

.sec_item .border_box .process::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: calc(-8 * 60rem / 750);
  height: calc(2 * 60rem / 750);
  width: 100%;
  background: var(--color3);
  transition: width 1s ease;
  transition-delay: .2s;
}

.sec_item .border_box .explanation {
  color: var(--color3);
  font-size: calc(20 * 60rem / 750);
  text-align: left;
  letter-spacing: .15em;
  line-height: 1.75;
  white-space: nowrap;
  margin-top: calc(23 * 60rem / 750);
}

.sec_item .border_box .img {
  position: relative;
  width: calc(340 * 60rem / 750);
  margin: calc(71 * 60rem / 750) auto 0;
}

.sec_item .border_box .img>img {
  position: relative;
  z-index: 2;
}

.sec_item .border_box .icon {
  width: calc(126 * 60rem / 750);
  position: absolute;
  top: calc(-73 * 60rem / 750);
  right: calc(-69 * 60rem / 750);
}

.sec_item .border_box .process_bg {
  width: calc(635 * 60rem / 750);
  height: calc(550 * 60rem / 750);
  margin: calc(105 * 60rem / 750) auto 0;
  position: relative;
}

.sec_item .border_box .process_bg .process {
  font-size: calc(26 * 60rem / 750);
  font-weight: 400;
  position: absolute;
  left: calc(70 * 60rem / 750);
  padding-left: calc(60 * 60rem / 750);
  padding-bottom: calc(8 * 60rem / 750);
}

.sec_item .border_box .process_bg .process:nth-of-type(1) {
  top: calc(52 * 60rem / 750);
}

.sec_item .border_box .process_bg .process:nth-of-type(2) {
  top: calc(190 * 60rem / 750);
}

.sec_item .border_box .process_bg .process:nth-of-type(3) {
  top: calc(331 * 60rem / 750);
}

.sec_item .border_box .process_bg .process:nth-of-type(4) {
  top: calc(472 * 60rem / 750);
}

.sec_item .border_box .process_bg .process::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: calc(0 * 60rem / 750);
  height: calc(2 * 60rem / 750);
  height: 1px;
  width: 100%;
  background: var(--color3);
  transition: width 1s ease;
  transition-delay: .2s;
}

.btn_all {
  border: 1px solid var(--color5);
  background: var(--color1);
  border: calc(2 * 60rem / 750) solid var(--color5);
  border-radius: calc(60 * 60rem / 750);
  width: calc(430 * 60rem / 750);
  margin: calc(80 * 60rem / 750) auto 0;
}

.btn_all a {
  color: #bb7b71;
  font-size: calc(20 * 60rem / 750);
  font-weight: 500;
  letter-spacing: .15em;
  line-height: 1.75;
  padding: calc(7 * 60rem / 750) 0 calc(12 * 60rem / 750);
}

.btn_all a span {
  display: block;
  font-size: calc(36 * 60rem / 750);
  font-weight: 400;
  letter-spacing: .15em;
}

.sec_item01 {
  padding-top: calc(200 * 60rem / 750);
  padding-bottom: calc(140 * 60rem / 750);
  background: url(https://toonecosmetics.com/Contents/ProductDetail/4573623430555/img/bg_sp.jpg) no-repeat center top;
  background-size: auto 101%;
}

.sec_item01 .ttl {}

.sec_item01 .border_box_01 .process_bg {
  background: url(https://toonecosmetics.com/Contents/ProductDetail/4573623430555/img/process_bg01.png) no-repeat center;
  background-size: 100%;
}

.sec_item01 .border_box_02 .process_bg {
  background: url(https://toonecosmetics.com/Contents/ProductDetail/4573623430555/img/process_bg02.png) no-repeat center;
  background-size: 100%;
}



/* ========================================================
                      * PC *
========================================================= */

@media (min-width: 769px) {
  .lp_contents {
    position: relative;
    width: 100%;
    max-width: 100vw;
    height: 100%;
  }

  .sec_item {
    position: relative;
  }

  .sec_item .mv_wrap{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10.7rem;
  }

  .sec_item .txt_blk{
    height: fit-content;
    padding-bottom: 3.6rem;
    margin-right: 2rem;
  }

  .sec_item .fukidashi {
    top: -2.8rem;
    border-radius: 2.8rem;
  }

  .sec_item .fukidashi.md {
    padding: 1.25rem 2rem;
  }

  .sec_item .fukidashi.sm {
    padding: 1.2rem 3rem;
    top: -3.9rem;
    border-radius: 3rem;
  }

  .sec_item .fukidashi span {
    font-size: 1.5rem;
  }

  .sec_item .fukidashi span::before {
    width: 3.8rem;
    height:1.8rem;
    bottom: -3rem;
    right: 2rem;
  }

  .sec_item .fukidashi.md.toge_reverse span::before {
    left: 2rem;
  }

  .sec_item .fukidashi.sm span::before {
    right: -0.5rem;
  }

  .sec_item .fukidashi.sm.toge_reverse span::before {
    left: 0;
    bottom: -2.9rem;
  }

  .sec_item .fukidashi.lg span::before {
    bottom: -4rem;
    right: 4rem;
  }

  .sec_item .fukidashi.lg.toge_reverse span::before {
    left:4rem;
  }

  .sec_item .visual {
    position: relative;
    width: 34rem;
    margin: 0 auto;
  }

  .sec_item .txt {
    margin-top: 0;
    font-size: 1.4rem;
  }

  .sec_item .img {
    width: 23rem;
    margin: 1.5rem auto 0;
  }

  .sec_item .name {
    font-size: 1.2rem;
    margin-top:1.4rem;
  }

  .sec_item .price {
    font-size: 1rem;
    margin-top: 2rem;
  }

  .sec_item .price span:nth-of-type(1) {
    font-size: 1.1rem;
  }

  .sec_item .price span:nth-of-type(2) {
    font-size: 1.2rem;
    margin-left: 0.6rem;
    margin-right: 0;
  }

  .sec_item .btn {}

  .sec_item .flex_wrap{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8rem;
    margin: 4.2rem auto 0;
  }

  .sec_item .variation_blk{
    width: 30rem;
    margin-left: 4.2rem;
  }

  .sec_item .border_box {
    position: relative;
    border: 1px solid var(--color3);
    width: 90rem;
    margin: 12rem auto 0;
    padding-bottom: 4.5rem;
  }

  .sec_item .border_box.border_box_02 {
    margin: 10rem auto 0;
  }

  .sec_item .border_box .txt {
    margin-top: 5.5rem;
    font-size: 1.6rem;
  }

  .sec_item .border_box .flex {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 0;
    margin-inline: 0;
  }

  .sec_item .border_box .flex.flex_bottom {
    margin-top: 2.5rem;
  }

  .sec_item .border_box .flex_inner {
    width: 13rem;
  }

  .sec_item .border_box .process {
    font-size: 1.1rem;
  }

  .sec_item .border_box .process::before {
    bottom: -0.4rem;
    height: 1px;
  }

  .sec_item .border_box .explanation {
    font-size: 1rem;
    margin-top: 1rem;
  }

  .sec_item .border_box .img {
    width: 17rem;
    margin: 3rem auto 0;
  }

  .sec_item .border_box .icon {
    width: 6.3rem;
    top: -4rem;
    right: -3.6rem;
  }

  .sec_item .border_box .process_bg {
    width: 38.5rem;
    height: 33rem;
    margin: 0;
  }

  .sec_item .border_box .process_bg .process {
    font-size: 1.6rem;
    left: 4.5rem;
    padding-left: 3.4rem;
    padding-bottom: 0.4rem;
  }

  .sec_item .border_box .process_bg .process:nth-of-type(1) {
    top: 3rem;
  }

  .sec_item .border_box .process_bg .process:nth-of-type(2) {
    top: 11.5rem;
  }

  .sec_item .border_box .process_bg .process:nth-of-type(3) {
    top: 19.7rem;
  }

  .sec_item .border_box .process_bg .process:nth-of-type(4) {
    top: 28.2rem;
  }

  .btn_all {
    border: 1px solid var(--color5);
    border-radius: 2.4rem;
    width: 21.5rem;
    margin:5rem auto 0;
  }

  .btn_all a {
    font-size: 1rem;
    font-weight: 400;
    padding: 0.4rem 0 0.6rem;
  }

  .btn_all a span {
    font-size: 1.8rem;
  }

  .sec_item01 {
    padding-top: 11rem;
    padding-bottom: 8rem;
    background: url(https://toonecosmetics.com/Contents/ProductDetail/4573623430555/img/bg_pc.jpg) no-repeat center top;
    background-size: auto 101%;
  }
}