@charset "UTF-8";
a {
  text-decoration: none; }

img {
  max-width: 100%;
  display: block; }

button {
  background: none;
  border: none; }

button:hover {
  cursor: pointer; }

html, body {
  padding: 0;
  margin: 0;
  background-color: #FFFFFF;
  font-size: 15px; }

p, a, p a, p span,
h1, h2, h3, h4, h5 {
  font-family: 'Libre Baskerville', 'Noto Sans TC', 'Helvetica', sans-serif;
  font-size: 15px;
  color: #000000;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 1px; }

html.sr .reveal,
html.sr .reveal-1,
html.sr .reveal-2,
html.sr .reveal-3,
html.sr .reveal-4,
html.sr .reveal-top,
html.sr .reveal-bot,
html.sr .reveal-left,
html.sr .reveal-right {
  visibility: hidden; }

@media screen and (max-width: 600px) {
  .mainframe {
    overflow-x: hidden; } }

.mainframe .section__intro {
  margin-bottom: 8rem; }
  .mainframe .section__intro .inner {
    max-width: 600px;
    margin: 0 auto;
    width: 80%; }
    .mainframe .section__intro .inner .title {
      height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-direction: column;
      position: relative; }
      .mainframe .section__intro .inner .title .overlay {
        display: flex;
        align-items: flex-end;
        justify-content: center;
        width: 100%;
        height: 100%;
        position: absolute; }
        .mainframe .section__intro .inner .title .overlay .overlay-link {
          display: flex;
          flex-direction: column;
          align-items: center;
          color: #FFFFFF;
          z-index: 2;
          position: relative;
          text-align: center;
          animation-name: blink;
          animation-duration: 1s;
          animation-iteration-count: infinite;
          animation-timing-function: ease-in-out;
          animation-direction: alternate;
          bottom: 2rem; }
      .mainframe .section__intro .inner .title img.logo {
        width: 28vw;
        margin: 0 auto; }
        @media screen and (max-width: 1440px) {
          .mainframe .section__intro .inner .title img.logo {
            width: 32vw; } }
        @media screen and (max-width: 1024px) {
          .mainframe .section__intro .inner .title img.logo {
            width: 36vw; } }
        @media screen and (max-width: 800px) {
          .mainframe .section__intro .inner .title img.logo {
            width: 44vw; } }
        @media screen and (max-width: 600px) {
          .mainframe .section__intro .inner .title img.logo {
            width: 94%; } }
      .mainframe .section__intro .inner .title img.heading {
        width: 32vw;
        margin: 4rem auto 0; }
        @media screen and (max-width: 1440px) {
          .mainframe .section__intro .inner .title img.heading {
            width: 34vw; } }
        @media screen and (max-width: 1024px) {
          .mainframe .section__intro .inner .title img.heading {
            width: 38vw;
            margin: 2.5rem auto 0; } }
        @media screen and (max-width: 800px) {
          .mainframe .section__intro .inner .title img.heading {
            width: 46vw; } }
        @media screen and (max-width: 600px) {
          .mainframe .section__intro .inner .title img.heading {
            width: 88%; } }
    .mainframe .section__intro .inner h1 {
      text-align: center;
      margin-bottom: 3rem;
      font-size: 30px;
      letter-spacing: 0.1em; }
      @media screen and (max-width: 600px) {
        .mainframe .section__intro .inner h1 {
          font-size: 26.25px; } }
    .mainframe .section__intro .inner #start {
      padding-top: 6rem; }
      @media screen and (max-width: 600px) {
        .mainframe .section__intro .inner #start {
          padding-top: 4rem; } }
      .mainframe .section__intro .inner #start p {
        margin-bottom: 1.2rem;
        text-align: center; }
        @media screen and (max-width: 600px) {
          .mainframe .section__intro .inner #start p {
            text-align: justify; } }
        @media screen and (max-width: 600px) {
          .mainframe .section__intro .inner #start p:first-child {
            text-align: center; } }
        .mainframe .section__intro .inner #start p:first-child span {
          font-size: 19.5px;
          font-weight: 500; }
        .mainframe .section__intro .inner #start p:last-child {
          margin-bottom: 0; }
        .mainframe .section__intro .inner #start p span {
          font-size: 13.5px;
          line-height: 3;
          display: block; }
          @media screen and (max-width: 600px) {
            .mainframe .section__intro .inner #start p span {
              line-height: 2.5;
              display: inline; } }
      .mainframe .section__intro .inner #start .special {
        margin-top: 2rem;
        text-align: center; }
        .mainframe .section__intro .inner #start .special p {
          color: #FFFFFF;
          padding: 0.65rem 1rem 0.7rem;
          display: inline-block;
          background-color: #dec5b9;
          font-size: 13.5px; }
          @media screen and (max-width: 600px) {
            .mainframe .section__intro .inner #start .special p {
              width: 100%;
              padding: 0.65rem 0 0.7rem;
              font-size: 12.75px; } }

.mainframe .section__main .look {
  margin-top: 10rem; }
  @media screen and (max-width: 600px) {
    .mainframe .section__main .look {
      margin-top: 8rem; } }
  .mainframe .section__main .look .look__desc {
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center; }
    .mainframe .section__main .look .look__desc img {
      max-width: 160px; }
      @media screen and (max-width: 800px) {
        .mainframe .section__main .look .look__desc img {
          max-width: 130px; } }
    .mainframe .section__main .look .look__desc h2.subtitle {
      font-size: 18px;
      letter-spacing: 0.2em;
      margin-top: 1.5rem; }
      @media screen and (max-width: 600px) {
        .mainframe .section__main .look .look__desc h2.subtitle {
          font-size: 15px; } }
      @media screen and (max-width: 400px) {
        .mainframe .section__main .look .look__desc h2.subtitle {
          font-size: 14.25px; } }
    .mainframe .section__main .look .look__desc h1.maintitle {
      font-size: 45px;
      letter-spacing: 0.2em;
      margin: 1.5rem auto 2.5rem; }
      @media screen and (max-width: 600px) {
        .mainframe .section__main .look .look__desc h1.maintitle {
          font-size: 37.5px; } }
      @media screen and (max-width: 400px) {
        .mainframe .section__main .look .look__desc h1.maintitle {
          font-size: 33.75px; } }
  .mainframe .section__main .look .look__nails {
    width: 100%;
    max-width: 1400px;
    margin: 6rem auto 0; }
    .mainframe .section__main .look .look__nails .row {
      display: flex;
      justify-content: space-between;
      align-items: center; }
      @media screen and (max-width: 600px) {
        .mainframe .section__main .look .look__nails .row {
          flex-direction: column;
          align-items: center; } }
      .mainframe .section__main .look .look__nails .row img:first-child {
        width: 49%; }
        @media screen and (max-width: 600px) {
          .mainframe .section__main .look .look__nails .row img:first-child {
            width: 80%;
            margin-bottom: 6rem; } }
      .mainframe .section__main .look .look__nails .row img:last-child {
        width: 46%; }
        @media screen and (max-width: 600px) {
          .mainframe .section__main .look .look__nails .row img:last-child {
            width: 55%; } }
    .mainframe .section__main .look .look__nails p.text {
      margin-top: 6rem; }
      @media screen and (max-width: 400px) {
        .mainframe .section__main .look .look__nails p.text {
          margin-top: 5rem; } }
  .mainframe .section__main .look .look__styling {
    display: flex;
    padding: 6rem 0;
    position: relative; }
    @media screen and (max-width: 400px) {
      .mainframe .section__main .look .look__styling {
        font-size: 33.75px;
        padding: 5rem 0; } }
    .mainframe .section__main .look .look__styling .inner {
      display: flex;
      max-width: 1100px;
      justify-content: space-between;
      width: 90%;
      margin: 0 auto;
      z-index: 2; }
      @media screen and (max-width: 600px) {
        .mainframe .section__main .look .look__styling .inner {
          flex-direction: column-reverse;
          align-items: center; } }
      .mainframe .section__main .look .look__styling .inner .col {
        width: 44%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center; }
        @media screen and (max-width: 1440px) {
          .mainframe .section__main .look .look__styling .inner .col {
            width: 46%; } }
        @media screen and (max-width: 1024px) {
          .mainframe .section__main .look .look__styling .inner .col {
            width: 47%; } }
        @media screen and (max-width: 600px) {
          .mainframe .section__main .look .look__styling .inner .col {
            width: 100%; } }
        .mainframe .section__main .look .look__styling .inner .col .item-list {
          display: flex;
          flex-direction: column;
          margin-top: 5rem; }
          @media screen and (max-width: 600px) {
            .mainframe .section__main .look .look__styling .inner .col .item-list {
              text-align: center; } }
          .mainframe .section__main .look .look__styling .inner .col .item-list p.title {
            align-self: flex-start;
            font-size: 25.5px;
            border-bottom: 1px solid #000;
            letter-spacing: 0.2em;
            margin-bottom: 2rem;
            padding-bottom: 1rem; }
            @media screen and (max-width: 600px) {
              .mainframe .section__main .look .look__styling .inner .col .item-list p.title {
                align-self: center; } }
          .mainframe .section__main .look .look__styling .inner .col .item-list a.item {
            -webkit-transition: all 0.2s ease-in-out;
            -o-transition: all 0.2s ease-in-out;
            transition: all 0.2s ease-in-out;
            font-size: 12.75px;
            margin-bottom: 1.5rem; }
            .mainframe .section__main .look .look__styling .inner .col .item-list a.item:hover {
              transform: translateX(3px); }
            .mainframe .section__main .look .look__styling .inner .col .item-list a.item:last-child {
              margin-bottom: 0; }
      .mainframe .section__main .look .look__styling .inner .col--l img:nth-child(1) {
        width: 80%;
        margin-bottom: 7vw;
        align-self: flex-end; }
        @media screen and (max-width: 1440px) {
          .mainframe .section__main .look .look__styling .inner .col--l img:nth-child(1) {
            margin-bottom: 5vw; } }
        @media screen and (max-width: 600px) {
          .mainframe .section__main .look .look__styling .inner .col--l img:nth-child(1) {
            width: 60%;
            margin: 0 auto 6rem; } }
      @media screen and (max-width: 600px) {
        .mainframe .section__main .look .look__styling .inner .col--l img:nth-child(2) {
          width: 80%; } }
      @media screen and (max-width: 600px) {
        .mainframe .section__main .look .look__styling .inner .col--r img:nth-child(1) {
          width: 60%; } }
      .mainframe .section__main .look .look__styling .inner .col--r img:nth-child(2) {
        width: 80%;
        margin-top: 7vw;
        align-self: flex-start; }
        @media screen and (max-width: 1440px) {
          .mainframe .section__main .look .look__styling .inner .col--r img:nth-child(2) {
            margin-top: 5vw; } }
        @media screen and (max-width: 600px) {
          .mainframe .section__main .look .look__styling .inner .col--r img:nth-child(2) {
            width: 80%;
            margin: 6rem auto; } }
    .mainframe .section__main .look .look__styling .bg {
      width: 67%;
      height: 75%;
      bottom: 0;
      z-index: 1;
      position: absolute; }
      @media screen and (max-width: 600px) {
        .mainframe .section__main .look .look__styling .bg {
          width: 100%; } }
      @media screen and (max-width: 400px) {
        .mainframe .section__main .look .look__styling .bg {
          height: 68%; } }
      .mainframe .section__main .look .look__styling .bg--1 {
        background-color: #dec5b9;
        opacity: 0.6; }
      .mainframe .section__main .look .look__styling .bg--2 {
        background-color: #cab694;
        opacity: 0.6; }
      .mainframe .section__main .look .look__styling .bg--3 {
        background-color: #beb2ab;
        opacity: 0.55; }
      .mainframe .section__main .look .look__styling .bg--4 {
        background-color: #e4c9b3;
        opacity: 0.55; }
      .mainframe .section__main .look .look__styling .bg--5 {
        background-color: #dec49d;
        opacity: 0.5; }
      .mainframe .section__main .look .look__styling .bg--6 {
        background-color: #bfa68e;
        opacity: 0.5; }

.mainframe .section__about-uka .inner {
  max-width: 540px;
  margin: 8rem auto;
  width: 75%; }
  @media screen and (max-width: 600px) {
    .mainframe .section__about-uka .inner {
      width: 85%; } }
  .mainframe .section__about-uka .inner img {
    max-width: 160px;
    margin: 0 auto; }
  .mainframe .section__about-uka .inner h1 {
    font-size: 18px;
    text-align: center;
    margin: 2rem auto 2rem;
    letter-spacing: 0.1em;
    font-weight: 500; }
  .mainframe .section__about-uka .inner p {
    line-height: 2.5;
    font-size: 13.5px;
    text-align: justify; }
    @media screen and (max-width: 600px) {
      .mainframe .section__about-uka .inner p {
        width: 90%;
        margin: 0 auto;
        font-size: 12.75px; } }
  .mainframe .section__about-uka .inner .sep {
    margin: 4rem auto; }
  .mainframe .section__about-uka .inner .coupon {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    border: solid 1px black;
    width: 80%;
    margin: 0 auto;
    padding: 3rem 0; }
    @media screen and (max-width: 600px) {
      .mainframe .section__about-uka .inner .coupon {
        width: 100%; } }
    .mainframe .section__about-uka .inner .coupon p.heading {
      letter-spacing: 0.1em;
      font-size: 19.5px;
      text-align: center; }
    .mainframe .section__about-uka .inner .coupon p.text {
      display: flex;
      flex-direction: column;
      align-items: center; }
      .mainframe .section__about-uka .inner .coupon p.text span {
        display: inline-flex; }
      .mainframe .section__about-uka .inner .coupon p.text span.code {
        border: 1px dashed black;
        padding: 0.25rem 1.25rem;
        margin: 0.75rem 0;
        background-color: #f5f5f5; }
    .mainframe .section__about-uka .inner .coupon a.btn {
      -webkit-transition: all 0.2s ease-in-out;
      -o-transition: all 0.2s ease-in-out;
      transition: all 0.2s ease-in-out;
      background-color: #000000;
      font-size: 13.5px;
      padding: 1.25rem 2rem;
      color: #FFFFFF;
      margin-top: 2rem; }
      @media screen and (max-width: 400px) {
        .mainframe .section__about-uka .inner .coupon a.btn {
          font-size: 12px;
          margin-top: 1rem;
          letter-spacing: 0.05em; } }
      @media screen and (max-width: 320px) {
        .mainframe .section__about-uka .inner .coupon a.btn {
          padding: 1rem 1.5rem; } }
      .mainframe .section__about-uka .inner .coupon a.btn:after {
        content: '→';
        font-size: 13.5px;
        margin-left: 0.5rem; }
      .mainframe .section__about-uka .inner .coupon a.btn:hover {
        transform: translateX(3px); }
    .mainframe .section__about-uka .inner .coupon p.tc {
      text-align: center;
      margin-top: 1rem; }
      .mainframe .section__about-uka .inner .coupon p.tc span {
        font-size: 10.5px;
        display: block;
        letter-spacing: 0.05em;
        line-height: 2; }
        @media screen and (max-width: 320px) {
          .mainframe .section__about-uka .inner .coupon p.tc span {
            font-size: 9px; } }

.mainframe p.text {
  text-align: center; }
  .mainframe p.text span {
    display: block;
    line-height: 2.5;
    font-size: 14.25px;
    letter-spacing: 0.2em;
    color: #222222; }
    @media screen and (max-width: 400px) {
      .mainframe p.text span {
        font-size: 12.75px;
        letter-spacing: 0.1em; } }

.mainframe .sep {
  margin: 0 auto; }
  .mainframe .sep span {
    display: block;
    border-radius: 50%;
    background-color: #aaaaaa;
    width: 2px;
    height: 2px;
    margin: 0 auto 0.7rem; }
    .mainframe .sep span:last-child {
      margin-bottom: 0; }

@-webkit-keyframes blink {
  0% {
    opacity: 1; }
  20% {
    opacity: 1; }
  100% {
    opacity: 0; } }
