@charset "utf-8";
/* CSS Document */

    
	
        @media screen and (min-width: 768px) and (max-width: 1447px) {
        #fixed-cta-side-pc{
            display: none;
        }}
        
        .app-pc{
            display: block;
        }
        
        .app-sp{
            display: none!important;
        }
        
        
        @media (max-width: 770px) {
        .app-pc{
            display: none!important;
        }
        
        .app-sp{
            display: block!important;
        }
        
        }
        
        .step h2{
            font-family: 游明朝, YuMincho, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, HG明朝E, MS P明朝, MS 明朝, serif;
            letter-spacing: 0.1rem;
            line-height: 3.5rem;
            font-size: 2.3rem!important;
            margin: 1.8rem 0!important;
        }
        
        #download h2{
            font-family: 游明朝, YuMincho, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, HG明朝E, MS P明朝, MS 明朝, serif;
            letter-spacing: 0.1rem;
            line-height: 3.5rem;
            font-size: 2.3rem!important;
            margin: 1.8rem 0!important;
        }
        .font-eng {
            font-family: 'Montserrat', sans-serif;
        }
        .bg-salon {
            background-color: #faf9f6;
        }
        .bg-salon-dark {
            background-color: #f5f2ed;
        }
        .text-accent {
            color: #8d7b68;
        }
        .bg-accent {
            background-color: #8d7b68;
        }
        .border-accent {
            border-color: #8d7b68;
        }
        .gradient-gold {
            background: linear-gradient(135deg, #ad8a17 0%, #f7d766 50%, #ad8a17 100%);
        }
        .phone-mockup {
            box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
            border: 10px solid #1a1a1a;
            background: white;
            border-radius: 2.5rem;
            position: relative;
        }        
        @media (max-width: 1023px) {
        .phone-mockup{
            width: 65%!important;
            height:auto!important;
        }}    
        .phone-mockup-top img {
            width: å%;
        }

        .phone-mockup-top{
            width: 100%;
        }
        
        @media (max-width: 1023px) {
        .phone-mockup-top{
            width: 85%;
            filter: drop-shadow(1px 4px 10px rgb(0 0 0 / 50%));    
        }}    
        
        .app-ttl{
            font-size: 3rem!important;
            line-height: 1.55;
            margin-top: 2rem;
            letter-spacing: 0.05rem;
            font-family: 游明朝, YuMincho, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, HG明朝E, MS P明朝, MS 明朝, serif;
        }
        
        @media (max-width: 768px) {
        .app-ttl{
            font-size: 1.8rem!important;
        }}
        
        .app-banner{
            width: 48%;
            max-width: 240px;
        }
        
        @media (max-width: 991px) {
        .app-banner{
            max-width: 100%;
        }}
        
        .top-txt p{
            font-size: 0.9rem;
            line-height: 1.5rem;
        }

        @media (max-width: 349px) {
        .top-txt h1{
            font-size: 1.4rem;
        }}    
        
        @media screen and (min-width: 350px) and (max-width: 624px) {
        .top-txt h1{
            font-size: 1.7rem;
        }}
        
        @media screen and (min-width: 440px) and (max-width: 540px) {
        .top-txt h1{
            font-size: 2.2rem!important;
        }}        
        
        @media screen and (min-width: 541px) and (max-width: 770px) {
        .top-txt h1{
            font-size: 2.6rem!important;
        }}    
        
        @media (min-width: 771px) {
        .top-txt h1{
            font-size: 3.1rem;
        }}
        

        
            
        
        
        .app-price{
            font-family: 游明朝, YuMincho, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, HG明朝E, MS P明朝, MS 明朝, serif;
            line-height: 1.1;
            display: block;
            margin-top: 1rem;
            font-size: 10rem;
            right: 0.5rem;
            position: relative;
        }
        
        @media (max-width: 623px) {
        .app-price{
            margin-top: 1rem;    
            font-size: 5.9rem;
        }}
        
        
        @media screen and (min-width: 390px) and (max-width: 540px) {
        .app-price{
            font-size: 7.9rem!important;
        }}    
        
        @media screen and (min-width: 624px) and (max-width: 1023px) {
        .app-price{
            font-size: 7rem;
        }}
        
        @media screen and (min-width: 1024px) and (max-width: 1180px) {
        .app-price{
            font-size: 9rem;
        }}
        @media (min-width: 1181px) {
        .app-price{
            font-size: 12rem;
            margin-top: 0;
        }}
        .top-banner{
            justify-content: flex-start!important;
        }
        .app-txt{
            font-size: 0.95rem;
            line-height: 2;
            
        }
        
        .merit-ttl{
            font-size: 1rem;
            letter-spacing: 0.2rem;
            font-weight: bold;
        }
        
        @media (min-width: 769px) {
        .underline{
            margin-top: 0.5rem;
        }}
        
        .sp-top{
            position: absolute!important;
            top: 6%;
            width: 46%;
            right: 0rem;    
            filter: drop-shadow(1px 2px 5px rgb(0 0 0 / 15%));
            paddingm: 13rem;
        }
        
        @media (max-width: 540px) {
        .sp-top{
            max-width: 200px;
        }}    
        
        
        @media screen and (min-width: 636px) and (max-width: 770px) {
        .sp-top{
            right: 0rem!important;        
            width: 46%;
            top: 5% !important;
            max-width: 300px;
        }}
        
        @media screen and (min-width: 771px) and (max-width: 991px) {
        .sp-top{
            right: 3rem!important;        
            top: 6% !important;
            width: 29rem!important;
        }}    
        
        
        @media screen and (min-width: 681px) and (max-width: 991px) {
        .sp-top{
            right: 0!important;        
            top: 9% !important;
            width: 27rem!important;
        }}
        
        @media (min-width: 992px) {
        .sp-top{
            position:relative!important;
            top: 6%;
            height: 100%;
            width: 100%;
            max-width: 32rem;
            filter: drop-shadow(1px 2px 5px rgb(0 0 0 / 50%));
        }}
        @media (min-width: 771px) {
        .top-wrap{
            display: flex!important;
            justify-content: space-between;
        }}
        

        
        @media (max-width: 768px) {
        .top-en{
            font-size: 0.65rem!important;
        }}
        /* Box Style for Summary Section */
        .point-box {
            background: white;
            border-radius: 2rem;
            padding: 2.5rem 2rem;
            transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
            box-shadow: 0 4px 20px rgba(141, 123, 104, 0.05);
            border: 1px solid rgba(141, 123, 104, 0.1);
            display: flex;
            flex-direction: column;
            align-items: center;
            cursor: pointer;
            text-decoration: none;
            color: inherit;
        }
        
        
        
        .point-box:hover {
            transform: translateY(-10px);
            box-shadow: 0 20px 40px rgba(141, 123, 104, 0.12);
            border-color: #8d7b68;
        }

        /* Circle Icon Container */
        .icon-circle {
            width: 80px;
            height: 80px;
            border-radius: 50%;
            background-color: #8d7b68;
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 1.5rem;
            color: white;
            transition: transform 0.3s ease;
        }
        .point-box:hover .icon-circle {
            transform: scale(1.1);
        }
        /* Step Card Style */
        .step-card {
            background: white;
            border-radius: 2.5rem;
            padding: 3rem 2.5rem 2rem;
            transition: all 0.3s ease;
            box-shadow: 0 10px 30px rgba(141, 123, 104, 0.05);
            height: 100%;
            position: relative;
        }
        
        @media (max-width: 768px) {
        .step-card {
            padding: 3rem 1.5rem 2rem;
        }}    
        
        .step-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 20px 40px rgba(141, 123, 104, 0.1);
        }
        
        .step-card p{
            text-align: center;
            margin: 0 auto;
            font-size: 0.8rem;
        }
        
        @media (max-width: 768px) {
        .step-card p{
               width: 100%;
        }}    
            
        @media (max-width: 768px) {
        .card-wrap{
            display: flex!important;
            flex-direction: column;
        }}    
            
        /* Step Circle positioned at top center */
        @media (max-width: 768px) {
        .step{
            padding-bottom: 0!important;
        }}    
        .step-number-circle {
            width: 50px;
            height: 50px;
            border-radius: 50%;
            background-color: #8d7b68;
            color: white;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.25rem;
            box-shadow: 0 8px 20px rgba(141, 123, 104, 0.25);
            position: absolute;
            top: -25px;
            left: 50%;
            transform: translateX(-50%);
            z-index: 10;
        }

        /* --- New Additions for Display Effects --- */
        .bg-number-symbol {
            top: -3.5rem;
            left: -1rem;
            position: absolute;
            font-size: 20rem;
            font-weight: 900;
            line-height: 1;
            color: #8d7b68;
            opacity: 0.08;
            pointer-events: none;
            z-index: 0;
            transition: all 1s ease-out;
        }
        
        @media (max-width: 768px) {
        .bg-number-symbol {
            top: -2rem;
            font-size: 15rem;
        }}
        .merit-section {
            position: relative;
            overflow: hidden;
        }
        .fade-up-item {
            opacity: 0;
            transform: translateY(30px);
            transition: all 0.8s ease-out;
        }
        .fade-up-item.is-visible {
            opacity: 1;
            transform: translateY(0);
        }
        /* Vertical Step Image Adjustment */
        .step-img-vertical {
            width: 100%;
            /aspect-ratio: 3/4;/
            object-fit: cover;
            border-radius: 1.5rem;
            border: solid 7px;
            margin-top: 2rem;
        }
        
        @media (max-width: 768px) {
        .step-img-vertical {
            width: 70%;
            margin: 1.5rem auto;
        }}
        
        .notice-box{
            border: solid 2px #ef4444;
        }
        
        @media (max-width: 768px) {
        .notice-box{
            padding: 3rem!important;
        }}    
        .qr-box{
            width: 80%;
            max-width: 400px;
        }
  
        
        .banner-box{
            display: flex;
            flex-direction: column;
            align-items: center;
        }
        
        .banner-box a{
            width: 80%;
            max-width: 600px;
        }