@charset "UTF-8";

  /********* 表單(*)必要欄位_此段文字隱藏*******/
  .c-form__legend {
    display: none;
}

/*共用頁面框架調整-----*/
.l-content__container {
    padding-right: 0;
    padding-left: 0;
    /*讓content撐到100%滿，左右不留白*/
}

.l-content__title {
    display: none;
    /*隱藏頁面h1標題*/
}

.c-breadcrumbs__list {
    display: none;
    /*隱藏頁面所在位置指引*/
}

.l-content__main-top {
    margin: 0;
    padding: 0;
    /*調整多餘空白區塊*/
}

@media screen and (min-width: 64em) {
    .l-content__main-container {
        margin-left: 0;
        margin-right: 0;
    }

    .l-content__main-top {
        padding: 0;
        margin: 0;
        /*調整多餘空白區塊*/
    }
}

/*-----共用頁面框架調整*/

a {
    color: #000;
    /*text-decoration: none;*/
    line-height: inherit;
    cursor: pointer;
}

section {
    position: relative;
}

#loreal-campaign .ll-page-abs {
    overflow: hidden;
    color: #2d2c2c;

}


#loreal-campaign .ll-page-abs a {
    text-decoration: none;
}


/****** 新增漸層活字大標 ******/
.lan-wrapper .title,
#loreal-campaign .title {
    font-weight: 600 !important;
    line-height: 1.2;
    text-align: center;
    margin: 0 auto;
}

.color-text-1 {
    background: -webkit-linear-gradient(left, #6c2e16 0%, #d79470 24%, #6c2e16 36%, #d79470 46%, #6c2e16 52%, #d79470 58%, #d79470 67%, #6c2e16 100%);
    background-size: 400% 400%;
    background-clip: text;
    -webkit-background-clip: -webkit-text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
}

.color-text-2 {
    background: -webkit-linear-gradient(left, #6c2e16 0%, #d79470 24%, #6c2e16 36%, #d79470 46%, #6c2e16 52%, #d79470 58%, #d79470 67%, #6c2e16 100%);
    background-size: 400% 400%;
    background-clip: text;
    -webkit-background-clip: -webkit-text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    -webkit-animation-name: colorText;
    animation-name: colorText;
    -webkit-animation-duration: 5s;
    animation-duration: 5s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-iteration-count: masked-light infinite;
    animation-iteration-count: infinite;
}

.color-text-3 {
    background: -webkit-linear-gradient(left, #bca658 0%, #fff8cb 24%, #bca658 36%, #fff8cb 46%, #bca658 52%, #fff8cb 58%, #fff8cb  67%, #bca658 100%);
    background-size: 400% 400%;
    background-clip: text;
    -webkit-background-clip: -webkit-text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    -webkit-animation-name: colorText;
    animation-name: colorText;
    -webkit-animation-duration: 5s;
    animation-duration: 5s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-iteration-count: masked-light infinite;
    animation-iteration-count: infinite;
}

@-webkit-keyframes colorText {
    0% {
        background-position: 0 0;
    }

    100% {
        background-position: -100% 0;
    }
}

body {
    font-family: "微軟正黑體", "Microsoft JhengHei", "Noto Serif", serif, sans-serif;
    font-weight: 400;
    font-size: 15px;
    display: block;
    margin: 0 auto;
    padding: 0;
    clear: both;
    position: relative;
}

.lan-wrapper {
    font-family: "微軟正黑體", "Microsoft JhengHei", "Noto Serif", serif, sans-serif;
    width: 100%;
    max-width: 1280px;
    display: block;
    margin: 0 auto;
    clear: both;
}

section {
    margin: 0 auto;
    width: 100%;
    clear: both;
    position: relative;
    display: block;
}

* {
    box-sizing: border-box;
}

.lan-wrapper sub,
.lan-wrapper sup {
    font-size: 65%;
    line-height: 0 !important;
    position: relative;
    vertical-align: baseline;
    font-weight: 300;
}

.lan-wrapper img {
    max-width: 100%;
}

.lan-wrapper ul {
    margin: 0;
    padding: 0;
}

.lan-wrapper ul li {
    list-style-type: disc;
    list-style-position: inside;
    line-height: 1.6;
    letter-spacing: 0.7;
}

/* 字級 */

.lan-wrapper h2 {
    font-family: "微軟正黑體", "Microsoft JhengHei", "Noto Serif", serif, sans-serif;
    font-size: 42px;
    text-align: center;
    margin: auto;
}

.lan-wrapper h3 {
    font-family: "微軟正黑體", "Microsoft JhengHei", "Noto Serif", serif, sans-serif;
    font-size: 36px;
    text-align: center;
    margin: auto;
}

.lan-wrapper h4 {
    font-family: "微軟正黑體", "Microsoft JhengHei", "Noto Serif", serif, sans-serif;
    font-size: 32px;
}

.lan-wrapper h5 {
    font-family: "微軟正黑體", "Microsoft JhengHei", "Noto Serif", serif, sans-serif;
    font-size: 30px;
}

.lan-wrapper h6 {
    font-family: "微軟正黑體", "Microsoft JhengHei", "Noto Serif", serif, sans-serif;
    font-size: 21px;
}

.lan-wrapper p {
    font-size: 18px;
    line-height: 1.7;
    text-align: justify;
    text-justify: inter-ideograph;
}

.MillerDisplay,
.MillerDisplay-L {
    font-size: 110%
   }

@media (max-width: 1280px) {
    .lan-wrapper h2 {
        font-size: 3.3vw;
    }

    .lan-wrapper h3 {
        font-size: 2.8vw;
    }
    
    .lan-wrapper h4 {
        font-size: 2.5vw;
    }
  
    .lan-wrapper h5 {
        font-size: 2.3vw;
    }

    .lan-wrapper h6 {
        font-size: 1.64vw;
    }
    
    .lan-wrapper p {
        font-size: 1.41vw;
    }

}

@media (max-width: 820px) {

    .lan-wrapper h2 {
        font-size: 6.5vw;
    }

    .lan-wrapper h3 {
        font-size: 5.2vw;
    }

    .lan-wrapper h4 {
        font-size: 5.3vw;
    }    

    .lan-wrapper h5 {
        font-size: 5vw;
    }  
    
    .lan-wrapper h6 {
        font-size: 4.3vw;
    }  
    
    .lan-wrapper p {
        font-size: 3.6vw;
    }
    
}

/* divider */

.mb {
    display: none !important;
}

@media (max-width: 800px) {
    .pc {
        display: none !important;
    }

    .mb {
        display: block !important;
    }
}


.lan-wrapper .white {
    color: #fff;
}

.lan-wrapper .black {
    color: #000;
}

.lan-wrapper .yellow {
    color: #fff8cb
}

.lan-wrapper .bold {
    font-weight: 600;
}

.lan-wrapper .skew {
    font-weight: 600;
    transform: skewX(-15deg);
    -webkit-transform: skewX(-15deg);
    -moz-transform: skewX(-15deg);
    -ms-transform: skewX(-15deg);
    -o-transform: skewX(-15deg);
}

.text-shadow-w {
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.8);
}

.text-shadow-b {
    text-shadow: 0 0 10px rgba(0, 0, 0, 0.8);
}

/*********** btn ***********/

.btn {
    margin: 0 3px;
    color: #fff !important;
    background: #000;
    outline: 0;
    transition: all 0.5s ease;
    font-weight: 400;
    letter-spacing: 0.1rem;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    display: inline-block;
    border-radius: 0;
    border: 1px solid #000;
    box-shadow: 0 0 10px #fff;
    height: inherit;
    line-height:1.3;
    width: 160px;
    font-size: 18px;
    padding: 10px 16px;
    margin: 0.2% 1%;
}


.btn:hover,
.btn:focus,
.btn:active {
    border: 1px solid #000;
    color: #000 !important;
    background: #fff;
}

.shine-btn {
    transition: all 0.5s ease;
    position: relative;
    overflow: hidden;
    vertical-align: middle;
}


.shine-btn:before {
    content: '';
    display: block;
    position: absolute;
    background: url(../images/shine_light.png) center center no-repeat;
    background-size: cover;
    width: 200%;
    height: 200%;
    /*background: rgba(255, 255, 255, 0.4);
    width: 50px;
    height: 100%;
    left: 0;
    top: 0;*/
    top: -5%;
    /*
    filter: blur(10px);
    transform: translateX(-100px) skewX(-15deg);
     animation: btn-shine 5s ease 1s infinite;*/
    pointer-events: none;
    -webkit-animation: btn-shine 6s ease 2s infinite;
    animation: btn-shine 6s ease 2s infinite;
}


@keyframes btn-shine {
    0% {
        transform: translateX(-150%) skewX(-15deg);
        opacity: 1;
    }

    80% {
        transform: translateX(450%) skewX(-15deg);
        opacity: 1;
    }

    100% {
        transform: translateX(450%) skewX(-15deg);
        opacity: 0;
    }
}


@media screen and (max-width: 1024px) {
    .btn {
        padding: 8px 12.8px;
        font-size: 14.5px;
        width: 128px;
    }
}

@media screen and (max-width: 800px) {
    .btn {
        font-size: 4vw;
        letter-spacing: 0.2em;
        width: 35vw;
        padding: 2vw 2.5vw;
        padding-left: 4vw;
    }
    .sec_08 .btn {
    max-width: 30vw;
    }
}

.adjust,
.adjust2 {
    position: absolute;
    display: block;
    z-index: 1;
    width: 100px;
    top: -135px;
}

.adjust {
    top: -100px;
    position: absolute;
    display: block;
    width: 100px;
    z-index: 1;
}

@media screen and (max-width: 415px) {
    .adjust {
        top: -75px;
        position: absolute;
        display: block;
        width: 100px;
        z-index: 1;
    }
}

@media screen and (max-width: 500px) {
    .adjust {
        position: absolute;
        display: block;
        z-index: 1;
        width: 100px;
        top: -130px;
    }

    .adjust2 {
        position: absolute;
        display: block;
        z-index: 1;
        width: 100px;
        top: 140px;
    }

}

.lan-wrapper .bg-img,
.lan-wrapper .bg-img .pc{
    position: relative;
}


.lan-wrapper .bg-img img:not(:first-of-type) {
position: absolute;
width: 100%;
height: auto;
top:0;
left:0;
right:0;
margin:auto;
display: block;
}

.sec-title {
    text-align: center;
    text-shadow: 0px 0px 35px rgba(255, 255, 255, 0.9);
}
.divider {
    display: block;
    margin: auto;
    max-width: 360px;
}

.content {
    position: absolute;
    width:100%;
    height: 100%;
    top:0;
    left:0;
    padding-top: 3rem;
    box-sizing: border-box;
}

@media (max-width: 820px) {
    .content {
        padding-top: 10vw;
    }

    .divider {
        max-width: 65vw;
    }
    
    
}


/*區塊共用標題設定*/
.section-title {
    text-align: center;
    padding: 70px 0 0;
    margin: 0 auto;
}

.section-title img {
    display: block;
    margin: -5px auto;
}

/*影片style*/
.video_wrap {
    position: relative;
}

video {
    display: block;
    width: 100%;
    height: auto;
    left: 0;
    right: 0;
    top: 0;
    margin: auto;
}

/*-------KV--------*/
#loreal-campaign .sec_01 {
    position: relative
}

.sec_01 .kvBtn {
    position: absolute;
    z-index: 1;
    left: 0;
    bottom: 4%;
    width: 100%;
    text-align: center;
}


@media (max-width: 820px) {
    .sec_01 .kvBtn {
        bottom: 6vw;   
    }
    
}

/*錨點選單*/

#loreal-campaign .anchor_menu {
    padding: 0px 0 20px;
    text-align: center;
}

#loreal-campaign .anchor_menu a {
    display: inline-block;
    color: #8c5c26;
    line-height: 40px;
    font-size: 18px;
    width: 120px;
    margin-bottom: 5px;
}

#loreal-campaign .anchor_menu a:hover {
    color: #6c2e16;
}

@media (max-width: 1280px){
#loreal-campaign .anchor_menu {
    padding: 0 0 1.1vw;
}
#loreal-campaign .anchor_menu a {
    font-size: 1.4vw;
}
}


@media (max-width: 800px) {
    #loreal-campaign .anchor_menu{
        padding: 4vw 8vw;
    }
    #loreal-campaign .anchor_menu a {
        line-height: 160%;
        font-size: 3.6vw;
        width: 30%;
    }

}


/*******************sec_02 VIDEO+sec_03 VIDEO********************/

.sec_02 .video_wrap,
.sec_03 .video_wrap  {
    width: 87.5%;
    left: 0;
    right: 0;
    margin: 2.5% auto;
    box-shadow: 0 0 30px rgba(194, 147, 105, 0.8);
}


.sec_03 .content {
    padding-top: 1rem;
}

.sec_02 p,
.sec_03 p {
  text-align: center!important;  
  color: #2d2c2c!important;  
}

@media (max-width: 820px) {
    .sec_02 .video_wrap,
    .sec_03 .video_wrap  {
        margin: 5vw auto;
    }
    

.sec_02 p,
.sec_03 p {
padding: 2vw 5vw;
}

}

/* sec_04 三大科學美容成分*/


.sec_04 .content p {
    text-align: center;
    margin: 5% auto;
}

.sec_04 .element_wrap {
    width:90%;
    margin: 3% auto 0;
    display: flex;
    justify-content: space-between;
}

.sec_04 .element_wrap .arrow {
animation: scaleAnimation 2s ease-in-out infinite;
}

.sec_04 .element_wrap .element_02 .arrow {
animation-delay: 0.4s;
}

.sec_04 .element_wrap .element_03 .arrow {
    animation-delay: 0.8s;  
}


@keyframes scaleAnimation {
    0% {
      transform: scale(1);
    }
    50% {
      transform: scale(1.05);
    }
    100% {
      transform: scale(1);
    }
  }


.sec_04 .element_wrap .element {
    flex: 0 0 31%;
    position: relative;
    overflow: hidden;
    background-position:center top;
    background-repeat:no-repeat;
    width:31%;
    height: auto;
    border:1px solid #f4d5c3;
    box-shadow: 0 5px 40px rgba(54, 24, 16, 0.8);
}

.sec_04 .element_wrap .element:hover{
    transition: all 1s;
}

.sec_04 .element_wrap .element_01{
    background-image:url(../images/sec_04_01.jpg);
    background-size:100%; 
 }

 .sec_04 .element_wrap .element_01:hover{
    background-image:url(../images/sec_04_01a.jpg);
 }

 .sec_04 .element_wrap .element_02{
    background-image:url(../images/sec_04_02.jpg);
    background-size:100%; 
 }

 .sec_04 .element_wrap .element_02:hover{
    background-image:url(../images/sec_04_02a.jpg);
 }

 .sec_04 .element_wrap .element_03{
    background-image:url(../images/sec_04_03.jpg);
    background-size:100%; 
 }

 .sec_04 .element_wrap .element_03:hover{
    background-image:url(../images/sec_04_03a.jpg);
 }

 .sec_04 .element_wrap .element .text_wrap {
position: absolute;
top:0;
left:0;
padding: 2% 6%;
margin-top: 112%;
 }

 .sec_04 .element_wrap .element:hover .text_wrap.active {
    margin-top: 57%;
    transition: all 0.8s;
   }

    .sec_04 .element_wrap .element:hover.element_03 .text_wrap.active {
    margin-top: 78%;
   }
  
 .sec_04 .element_wrap .element .text_wrap h4 {
    text-align: center;
    color:#fff;
    font-weight: 600;
    margin-bottom: 25%;
 }

 .sec_04 .element_wrap .element:hover .text_wrap.active h4 {
    margin-bottom: 0;
   }

 .sec_04 .element_wrap .element .text_wrap p {
    text-align: justify;
    text-justify:inter-ideograph ;
    color: #faf4e1 !important;
 }

 @media (max-width: 820px) {
     .sec_04 .element_wrap .element.element_01{
        background-image:url(../images/sec_04_01_mb.jpg);
        background-size:100%; 
     }
    
     .sec_04 .element_wrap .element.active.element_01:hover{
        background-image:url(../images/sec_04_01a_mb.jpg);
     }
    
     .sec_04 .element_wrap .element.element_02{
        background-image:url(../images/sec_04_02_mb.jpg);
        background-size:100%; 
     }
    
     .sec_04 .element_wrap .element.active.element_02:hover{
        background-image:url(../images/sec_04_02a_mb.jpg);
     }

     .sec_04 .element_wrap .element.element_03{
        background-image:url(../images/sec_04_03_mb.jpg?v0);
        background-size:100%; 
     }
   
     .sec_04 .element_wrap .element.active.element_03:hover{
        background-image:url(../images/sec_04_03a_mb.jpg?v0);
     }
    .sec_04 .content>p {
        margin: 4vw auto;
    }


 .sec_04 .element_wrap {
    width:73%;
}

.sec_04 .element_wrap .element {
    flex: 0 0 100%;
    width: 100%;
}

.sec_04 .element_wrap .element .text_wrap h4 {
font-size: 6vw;
margin-bottom: 12vw;
letter-spacing: 0.05em;
}


 }


/* sec_05 改善5大老化 */

.sec_05 .sec-title {
    text-shadow: none;   
    margin-top: 2%;
} 

.sec_05 .note {
position: absolute;
right: 6%;
bottom: 2%;
text-align: right;
}

.sec_05 p.note small {
font-size: 65%;
color: #fff;
}

.sec_05 .improve {
   position: absolute; 
   top:0;
   left: 0;
}

.sec_05 .improve .text_wrap {
    position: absolute; 
    text-align: center;
    width:15%;
}

.sec_05 .improve_01 .text_wrap {
    left:12%;
    top:37.5%;
}

.sec_05 .improve_02 .text_wrap {
    left:12%;
    top:54.3%;
}

.sec_05 .improve_03 .text_wrap {
    left:12%;
    top:71.5%;
}

.sec_05 .improve_04 .text_wrap {
    right: 11.5%;
    top: 45%;
}

.sec_05 .improve_05 .text_wrap {
    right: 11.5%;
    top: 59.5%;
}

.sec_05 .improve .text_wrap h2,
.sec_05 .improve .text_wrap h6 {
line-height: 1;
margin: 0 auto;
}

.sec_05 .improve .text_wrap h2 span {
    font-size: 200%;
}

@media (max-width: 820px) {
    .sec_05 .note {
        right:0;
        left: 0;
        bottom: 2vw;
        text-align: center;
        }

    .sec_05 .improve .text_wrap h2 {
        font-size: 6vw;
    }

    .sec_05 .improve .text_wrap h2 span {
        font-size: 190%;
    }

    .sec_05 .improve .text_wrap h6 {
        font-size: 3.2vw;
    }

    .sec_05 .improve .text_wrap {
        width:26%;
    }

    .sec_05 .improve_01 .text_wrap {
        left: 11%;
        top: 25.6%;
    }
    
    .sec_05 .improve_02 .text_wrap {
        left: 11%;
        top: 45%;
    }
    
    .sec_05 .improve_03 .text_wrap {
        left: 11%;
        top: 60.3%;
    }
    
    .sec_05 .improve_04 .text_wrap {
        right: 8.5%;
        top: 25.5%;
    }
    
    .sec_05 .improve_05 .text_wrap {
        right: 9.5%;
        top: 72.5%;
    }
}


/* sec_06 使用步驟影片 */

.sec_06 {
    position: relative;
     
 }
 
 .sec_06 .step_wrap {
    width:70%;
    margin: 3% auto 0;
    display: flex;
    justify-content: space-between;
 }

 .sec_06 .step_wrap .step{
    display: flex;
    flex-direction: column;
    flex: 0 0 22%;
 }

 .sec_06 .step_wrap .step.step_04 {
    flex: 0 0 25%;
}

 .sec_06 .step_wrap .step .arrow {
    height:22px;
    width:22px;
    max-width:22px;
    display: inline-block;
    margin-left: 0.3em;
}

 .sec_06 .step_wrap .step h5 {
    font-style: italic;
    font-weight:500;
    text-align: left;
    letter-spacing: 0.05em;
    margin-top: 1em;
    margin-bottom: -10px;
 }

 .sec_06 .step_wrap .step p {
text-align: left;
letter-spacing:-0.01em;
margin-top: 0.5em;
 }

 .sec_06 .step_wrap .step h5 .larger {
font-size: 160%;
 }
 .sec_06 .video_wrap{
     width: 87.5%;
     margin-top: 5%;
     left: 0;
     right: 0;
     margin: 3.5% auto;
     box-shadow: 0 0 30px rgba(194, 147, 105, 0.8);
 }   
 
 .sec_06 .sec-title {
    text-align: center;
    text-shadow: 0px 0px 35px rgba(255, 255, 255, 0.9);
}
.sec_06 .video_wrap video{
   width: 100%;
}

 @media (max-width: 1280px) {
    .sec_06 .step_wrap .step .arrow {
    height:1.7vw;
    width:1.7vw;
    }
 }

 @media (max-width: 820px) {
    .sec_06 .sec-title {
        margin-top: 3vw;
    }

     .sec_06 .step_wrap {
        width:70%;
        flex-wrap: wrap;
        margin: 7vw auto;
     }

     .sec_06 .step_wrap .step{
        flex-direction: row;
        flex: 0 0 100%;
        justify-content: space-between;
     }

     .sec_06 .step_wrap .step.step_04 {
        flex: 0 0 100%;
    }

     .sec_06 .step_wrap .step h5 {
        font-size: 6vw;
        padding-right: 1vw;
        margin-top: 0;
     }

     .sec_06 .step_wrap .step p {
flex:0 0 67%;
margin: 3.2vw 0;
     }

 }


 
/******************sec_07********************/

.lan-wrapper .sec_07 .sec-title {
    width: 100%;
    position: absolute;
    top: 70px;
    color: #fff;
    text-align: center;
}

.lan-wrapper .sec_07 .slidershow {
    position: absolute;
    width: 91.5%;
    top: 20%;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.lan-wrapper .sec_07 .family {
    width: 100%;
    display: flex;
    justify-content: space-between;
}

.lan-wrapper .sec_07 .family .product {
    width: 20%;
    position: relative;
    text-align: center;
}

.lan-wrapper .sec_07 .family .product img {
    margin: 0 auto;
}

.lan-wrapper .sec_07 .family .product dl {
    width: 100%;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
}

.lan-wrapper .sec_07 .family .product dl a {
    margin: 0 auto;
}

.lan-wrapper .sec_07 .family .product dl dt,
.sec_QA dt {
    font-size: 21px;
    line-height: 1.6;
    font-weight: 700;
}

.lan-wrapper .sec_07 .family .product dl dd {
    font-size: 16px;
    margin: 2% auto 5%;
}

.lan-wrapper .sec_07 .family .product .step {
    position: relative;
}

.lan-wrapper .sec_07 .family .product .step img {
    width: 100%;
}

.lan-wrapper .sec_07 .step:before {
    content: '';
    position: absolute;
    z-index: 1;
    width: 35%;
    height: 35%;
    background: url('../images/stepArrow.png') no-repeat center;
    background-size: 100%;
    right: -14%;
    top: 29%;
}

.lan-wrapper .sec_07 .product:last-of-type .step:before {
    display: none;
}

@media(max-width:1024px) {
    .lan-wrapper .sec_07 .sec-title {
        top: 56px;
    }

    .lan-wrapper .sec_07 .family .product img {
        width: 80%;
    }

    .lan-wrapper .sec_07 .family .product dl dt,
    .sec_QA dt {
        font-size: 15px;
    }

    .lan-wrapper .sec_07 .family .product dl dd {
        font-size: 13px;
    }
}

@media(max-width:800px) {

    .lan-wrapper .sec_07 .slidershow {
        top: 28vw;
    }

    .lan-wrapper .sec_07 .family .product {
        width: 100%;
    }

    .lan-wrapper .sec_07 .family .product img {
        width: 42%;
        z-index: 1;
        position: relative;
    }

    .lan-wrapper .sec_07 .family .product .step {
        margin-bottom: -5vw;
    }

    .lan-wrapper .sec_07 .family .product .step img {
        width: 75%;
    }

    .lan-wrapper .sec_07 .family .product dl {
        background-color: #fff;
        width: 90%;
        display: block;
        position: relative;
        padding: 15% 5% 8%;
        margin-top: -15%;
    }

    .lan-wrapper .sec_07 .family .product dl dt,
    .sec_QA dt {
        font-size: 15px;
    }

    .lan-wrapper .sec_07 .family .product dl dd {
        font-size: 13px;
    }

    .lan-wrapper .sec_07 .family .product dl a {
        width: 50%;
    }

    .lan-wrapper .sec_07 .family .product dl dt,
    .sec_QA dt {
        font-size: 28px;
    }

    .lan-wrapper .sec_07 .family .product dl dd {
        font-size: 25px;
    }

    .lan-wrapper .bg>img {
        width: 100%
    }
}

@media(max-width:500px) {

    .lan-wrapper .sec_07 .family .product dl dt,
    .sec_QA dt {
        font-size: 15px;
    }

    .lan-wrapper .sec_07 .family .product dl dd {
        font-size: 13px;
    }
}

@media(max-width:320px) {

    .lan-wrapper .sec_07 .family .product dl dt,
    .sec_QA dt {
        font-size: 14px;
    }

    .lan-wrapper .sec_07 .family .product dl dd {
        font-size: 12px;
    }
}

/* sec_08 */
#loreal-campaign .sec_08 {
    position: relative;
    height: auto;
    padding: 0;
    background: none;
}
#loreal-campaign .sec_08 .text {
    position: absolute;
    z-index: 2;
    top: 3%;
    left: 0;
    width: 100%;
    text-align: center;
}

#loreal-campaign .sec_08 .text.text02 {
    top:6%;
}

#loreal-campaign .sec_08 .text.product_text h2 {
    font-size: 24px;
    padding: 2px 0;
    background: -webkit-linear-gradient(left, #3d120a 0%, #b06233 24%, #3d120a 36%, #b06233 46%, #3d120a 52%, #b06233 58%, #b06233 67%, #3d120a 100%);
    background-size: 400% 400%;
    background-clip: text;
    -webkit-background-clip: -webkit-text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    -webkit-animation-name: colorText;
    animation-name: colorText;
    -webkit-animation-duration: 5s;
    animation-duration: 5s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-iteration-count: masked-light infinite;
    animation-iteration-count: infinite;
}

#loreal-campaign .sec_08 .text.product_text p {
    font-size: 19px;
    margin: 10px 0;
    text-align: center;
}

#loreal-campaign .sec_08 .text.product_text.product_text01 {
    top: 75%;
    width: 30%;
    left: 9%;
}

#loreal-campaign .sec_08 .text.product_text.product_text02 {
    top: 78%;
    width: 30%;
    left: 37%;
}

#loreal-campaign .sec_08 .text.product_text.product_text03 {
    top: 75%;
    width: 30%;
    left: 63%;
}

#loreal-campaign .sec_08 .text>p {
    margin-top: 10px;
    letter-spacing: -0.1px;
}

@media (max-width: 1280px) {
    #loreal-campaign .sec_08 .text.product_text h2 {
        font-size: 1.85vw;
    }

    #loreal-campaign .sec_08 .text.product_text p {
        font-size: 1.5vw;
        margin: 2.5% 0;
        text-align: center;
    }
}

@media (max-width: 810px) {
    #loreal-campaign .sec_08 {
        position: relative;
        height: auto;
        padding: 0;
        background: none;
    }

    #loreal-campaign .sec_08 .text {
        top: 10vw;
    }

    #loreal-campaign .sec_08 .text>p {
        text-align: justify;
        width: 80%;
        max-width: 850px;
        margin: 3vw auto 0 auto;
    }

    #loreal-campaign .sec_08 .text.product_text h2 {
        font-size: 4vw;
    }

    #loreal-campaign .sec_08 .text.product_text p {
        font-size: 3.7vw;
        margin: 4.5% 0 7.5% 0;
    }

    #loreal-campaign .sec_08 .text.product_text a {
        width: 90%;
    }

    #loreal-campaign .sec_08 .text.product_text.product_text01 {
        top: 59%;
        width: 32%;
        left: 2%;
    }

    #loreal-campaign .sec_08 .text.product_text.product_text02 {
        top: 64%;
        width: 32%;
        left: 35%;
    }

    #loreal-campaign .sec_08 .text.product_text.product_text03 {
        top:59%;
        width: 32%;
        left: 66.5%;
    }
}

/* QA縮合頁籤 */
.sec_QA {
    background: url('../images/sec_09.jpg') no-repeat center bottom;
    background-size: cover;
    padding: 1% 0 ;
}

.sec_QA ul {
    list-style: none;
    display: table;
    margin: 5% auto 0 auto !important;
    width: 90%;
}

.sec_QA ul li{
    list-style-type: none;
}

.sec_QA .QAtab {
    cursor: default;
    margin-bottom: 3%;
    line-height: 1.7;
}

.sec_QA .QAtab .problem,
.sec_QA .QAtab .answer {
    padding-right: 50px;
}

.sec_QA .QAtab .answer p {
    margin:0 auto;
}

.sec_QA .QAtab .problem {
    margin-bottom: 1%;
    position: relative;
}

.sec_QA .QAtab .problem:before,
.sec_QA .QAtab .problem.openQA:before {
    content: '';
    position: absolute;
    z-index: 1;
    width: 40px;
    height: 40px;
    right: 0;
    top: -4px;
}

.sec_QA .QAtab .problem:before {
    background: url('../images/+_white.svg') no-repeat center;
    background-size: 100%;
}

.sec_QA .QAtab .problem.openQA:before {
    background: url('../images/-_white.svg') no-repeat center;
    background-size: 100%;
}

.sec_QA .QAtab .answer {
    display: none;
}

@media screen and (max-width: 1200px) {

    .sec_QA .QAtab .problem:before,
    .sec_QA .QAtab .problem.openQA:before {
        width: 3.4vw;
        height: 3.4vw;
        top: -0.4vw;
    }

    .sec_QA .QAtab .problem,
    .sec_QA .QAtab .answer {
        padding-right: 4vw;
    }
}

@media screen and (max-width: 1023px) {

    .sec_QA .QAtab .problem:before,
    .sec_QA .QAtab .problem.openQA:before {
        width: 5.4vw;
        height: 5.4vw;
    }

    .sec_QA .QAtab .problem,
    .sec_QA .QAtab .answer {
        padding-right: 6vw;
    }
}

.o2oAnchor {
    border: 0 !important;
}

@media (max-width: 991px) {

    .sec_QA .QAtab .problem dt {
        font-size: 4.1vw;
    }

    .sec_QA .QAtab .answer {
        font-size: 3.7vw;
    }

}

@media (max-width: 820px) {
.sec_QA {
    background: url('../images/sec_09_mb.jpg') no-repeat center bottom;
    background-size: cover;
    padding:3vw 0;
}
}


/* 寵粉無極限！gift box */

#loreal-campaign .gift_box {
    float: right;
    width: 45%;
    vertical-align: middle;
    padding: 2% 2%;
    box-sizing: border-box;
    background: rgba(255, 255, 255, .8);
    color: #000;
    text-align: center;
    margin-right: 4%;
    margin-top: 41%;
}

#loreal-campaign .gift_box h3 {
    font-weight: 500;
}

#loreal-campaign .gift_box .product_wrap {
margin-top: 3%;
}

#loreal-campaign .gift_box .product_wrap .surpriseIten {
    width: 100%;
    display: flex;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: space-between;
}

#loreal-campaign .gift_box .product_wrap .surpriseIten span {
    padding: 5px 15px;
    background-color: #92451f;
    background-image: linear-gradient(145deg, #eead8a 25%, #92451f 100%);
    line-height: 1.5;
    display: table;
    margin: 0 auto;
    font-size: 140%;
    color: #fff;
}

#loreal-campaign .gift_box .product_wrap .surpriseIten p {
    line-height: 1.5;
    font-weight: 300;
    text-align: center;
    padding: 3px 0;
    margin: 1rem auto;
}

#loreal-campaign .gift_box .note {
    font-size: 15px;
    margin-top: 1%;
    text-align: left;
    font-weight: 300;
}

@media (max-width: 1280px) {
    #loreal-campaign .gift_box .note {
        font-size: 1.18vw;
    }
}

@media (max-width: 800px) {
    #loreal-campaign .gift_box {
        width: 90%;
        margin:10vw auto;
        display: block;
        float: none;
        padding: 6% 4%;
    }

    #loreal-campaign .gift_box .note {
        font-size: 2.7vw;
    }

    #loreal-campaign .gift_box .product_wrap img {
        width: 55%;
    }

    #loreal-campaign .gift_box .product_wrap .surpriseIten span {
        padding: 1vw 2vw;
        font-size: 110%;
    }
}
