 *,
 *::before,
 *::after {
     box-sizing: border-box;
     /*outline: #c0392b 1px solid;*/
 }

 * {
     margin: 0;
     padding: 0;
     list-style: none;
 }

 a {
     text-decoration: none;
     color: currentColor;
 }

 :root {
     --bg: #ffffff;
     --white: #ffffff;
     --text-primary: #000000;
     --text-secondary: #666;
     --price: #c0392b;
     --model: #2e7bc4;
     --border: #e8e6e2;
     --radius: 12px;
 }

 img {
     width: 100%;
     height: auto;
     vertical-align: middle;
 }

 body {
     font-family: 'Noto Sans TC', sans-serif;
     background: #f9ece4;
     letter-spacing: 1;
 }

 header,
 main,
 footer {
     max-width: 1440px;
     margin: 0 auto;
 }

 .chiron-sung-hk {
     font-family: "Chiron Sung HK", serif;
     font-weight: 400;
     font-style: normal;
     letter-spacing: 1px;
 }


 .u-text-xl {
     color: #ab3b3a;
     font-size: 6.4cqi;
     font-weight: 600;
     line-height: 1.3;
 }

 .u-text-lg {
     color: #ab3b3a;
     font-size: 4.53cqi;
     font-weight: 600;
     line-height: 1.4;
 }

 .u-text-base {
     color: #000000;
     font-size: 3.73cqi;
     line-height: 1.6;
 }

 .u-text-sm {
     color: #000000;
     font-size: 3.5cqi;
 }

 .jp4000Gift,
 .m585580Title,
 .m395366Title,
 .sideTextBox-1,
 .sideTextBox-2 {
     opacity: 0;
     transform: translateY(20px);
     transition: all 0.6s ease-out;
 }

 .jp4000Gift.fade-up-active,
 .m585580Title.fade-up-active,
 .m395366Title.fade-up-active,
 .sideTextBox-1.fade-up-active,
 .sideTextBox-2.fade-up-active {
     opacity: 1;
     transform: translateY(0);
 }

 .topLink {
     max-width: 1440px;
     margin: 0 auto;
     position: absolute;
     top: 15px;
     left: 0px;
     right: 0px;
     display: flex;
     justify-content: space-between;
     align-items: center;
     padding: 0 15px;
 }

 .jp4000Act {
     max-width: 1100px;
     margin: 0 auto 40px;
     border-bottom: 1px solid #e9c4c9;
 }

 .jp4000ImgItem3 {
     max-width: 800px;
     margin: 0 auto;
     padding: 0 12px;
 }

 .jp4000Box {
     display: flex;
     flex-direction: column;
     gap: 20px;

 }

 .YtVideo {
     position: relative;
     width: 100%;
     height: 0;
     padding-bottom: 56.25%;
 }

 .YtVideo iframe {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
 }

 .jp4000PriceBox {
     flex-basis: 100%;
     padding: 0 12px;
 }

 .jp4000PriceBox hr {
     max-width: 350px;
 }

 .jp4000Gift {
     display: flex;
     margin-top: 30px;
     margin-bottom: 40px;
 }

 .jp4000Gift p {
     font-size: 26px;
     color: #ab3b3a;
     font-weight: 500;
 }

 .jp4000Gift img {
     max-width: 200px;
 }

 .proSale.jp4000Price {
     display: flex;
     align-items: center;
 }

 .saleAct-1,
 .saleAct-2 {
     max-width: 1100px;
     margin: 0 auto;
     container-type: inline-size;
 }

 .saleAct-2 {
     background: linear-gradient(355deg, #f9ece4 0%, #f9ece4 8%, #efd8cb 6%, #e1c6c4 20%, #f9ece4 50%, #f9ece4 100%);
 }

 .m585580Title {
     display: flex;
     flex-direction: column;
     align-items: center;
 }

 .m585580Title>div>a>img {
     max-width: 200px;
 }

 .m395366Title {
     text-align: center;
     padding: 20px 0;
 }

 .m395366TitleBox {
     display: flex;
     flex-direction: column;
     margin-bottom: 10px;
 }

 .m395366,
 .m585580 {
     display: flex;
     flex-direction: column;
     gap: 20px;
 }

 .A395Box,
 .A366Box {
     background: url('../images/2026M_mBox.png');
     background-repeat: no-repeat;
     background-position: center;
     background-size: 100%;
     display: flex;
     flex-direction: row;
     align-items: center;
     padding: 40px 15px;
 }

 .A585Box,
 .A580Box {
     display: flex;
     flex-direction: row;
     padding: 10px 0px;
     align-items: center;
 }

 .A395Box>div:nth-child(1),
 .A366Box>div:nth-child(1),
 .A585Box>div:nth-child(1),
 .A580Box>div:nth-child(1),
 {
 flex: 0 0 35%;
 text-align: left;
 margin-left: 5%;
 }

 .A395Box>div:nth-child(2),
 .A366Box>div:nth-child(2),
 .A585Box>div:nth-child(2),
 .A580Box>div:nth-child(2) {
     flex: 0 0 65%;
     margin-top: 30px;
 }

 .actPro-info {
     text-align: left;
     margin-top: 20px;
     margin-left: 12px;
 }

 .actPro-info>div>img {
     max-width: 150px;
 }

 .A395Box>.actPro-info>div>img {
     max-width: 70px;
 }

 .actPro-info h5 {
     font-size: clamp(10px, 3.5vw, 15px);
     font-weight: 700;
     margin-top: 5px;
 }

 .pro-text {
     font-size: clamp(12px, 4vw, 16px);
     line-height: 1.4em;
     margin-top: 5px;
 }

 .proSale {
     font-size: 12px;
     margin-top: 5px;
     font-style: italic;
 }

 .proSale span {
     font-size: 18px;
     color: #b70000;
     font-weight: 700;
 }

 .sideSale {
     position: relative;
     max-width: 1100px;
     margin: 0 auto;
     container-type: inline-size;
 }

 .sideTextBox-1 {
     position: absolute;
     left: 9%;
     top: 4%;
 }

 .sideTextBox-2 {
     position: absolute;
     left: 9%;
     top: 53%;
 }

 .fit-wrapper {
     width: 100%;
     padding: 0% 12px 20px 12px;
     background:
         url('../images/2026M_fit-bg.png'),
         linear-gradient(#ffdcdc, #ffdcdc);

     background-position: 40px center;
     background-size: cover;
 }

 .fitTopImg {
     z-index: 999;
     position: relative;
 }

 .fit-wrapper .pro-container {
     background: linear-gradient(to bottom,
             rgba(255, 255, 255, 0) 0%,
             /* 起點 0%：全透明白色 */
             rgba(255, 255, 255, 1) 4%,
             /* 5% 位置：完全不透明白色 */
             rgba(255, 255, 255, 1) 100%
             /* 終點 100%：持續完全不透明 */
         );
     padding-top: 55px;
     margin-top: -100px;
     z-index: 888;
     position: relative;
 }

 .mass-wrapper {
     width: 100%;
     padding: 40% 12px 20px 12px;
     background:
         url('../images/2026M_takMe-bg.png'),
         repeating-linear-gradient(130deg,
             #ffffff,
             /* 白色起點 */
             #ffffff 10px,
             /* 白色寬 10px */

             #f2f2f2 10px,
             /* 淺灰色起點 (你指出的淡淡灰色條紋) */
             #f2f2f2 20px,
             /* 淺灰色寬 10px */

             #ffffff 20px,
             /* 中間過渡白色起點 */
             #ffffff 30px,
             /* 中間過渡白色寬 10px */

             #ffd7de 30px,
             /* 粉紅色起點 (原圖色值約 #ffc9d2) */
             #ffd7de 40px
             /* 粉紅色寬 10px */
         );
     background-repeat: no-repeat;
     background-position: top center;
     background-size: 140% auto;
 }

 .pro-container {
     max-width: 1100px;

     display: grid;
     grid-template-columns: repeat(2, 1fr);
     gap: var(--gap);
     margin: 0 auto;
     background: linear-gradient(to bottom,
             rgba(255, 255, 255, 0) 0%,
             /* 起點 0%：全透明白色 */
             rgba(255, 255, 255, 1) 3%,
             /* 5% 位置：完全不透明白色 */
             rgba(255, 255, 255, 1) 100%
             /* 終點 100%：持續完全不透明 */
         );
 }


 .mass-item-card,
 .fit-item-card {
     transition: transform 0.25s ease;
     display: flex;
     flex-direction: column;
 }

 .mass-item-card:hover,
 .fit-item-card:hover {
     transform: translateY(-3px);
 }

 .mass-item-card a,
 .fit-item-card a {
     text-decoration: none;
     color: inherit;
     display: flex;
     flex-direction: column;
     height: 100%;
     padding-bottom: 20px;
 }

 .img-wrap {
     /* aspect-ratio: 1 / 1; */
     overflow: hidden;
     display: flex;
     align-items: center;
     justify-content: center;
     margin-bottom: 12px;
 }

 .img-wrap img {
     width: 100%;
     height: 100%;
     object-fit: contain;
 }

 .mass-item-card:hover .img-wrap im,
 .fit-item-card:hover .img-wrap img {
     transform: scale(1.03);
     transition: transform 0.25s ease;
 }

 .pro-info {
     text-align: center;
     display: flex;
     flex-direction: column;
     padding: 0 8px;
     gap: 4px;
 }

 .pro-model {
     font-size: 13px;
     font-weight: 700;
     color: #909090;
 }

 .pro-name {
     font-size: 16px;
     color: var(--text-primary);
     font-weight: 500;
 }

 .pro-price {
     font-size: 18px;
     font-weight: 700;
     color: var(--price);
     font-style: italic;
 }

 .pro-price span {
     font-size: 13px;
     font-weight: 400;
     margin-right: 1px;
 }

 /*footer*/
 footer {
     width: 100%;
     padding-top: 20px;
     color: #333333;
     background-color: #ffffff;
     border-top: 1px solid #eeeeee;
 }

 .store-section {
     text-align: center;
 }

 .section-title {
     font-size: 22px;
     letter-spacing: 2px;
     margin: 30px 0px;
     text-align: center;
 }

 .footerMap {
     max-width: 150px;
     padding-bottom: 20px;
 }

 .notes-section {
     font-size: 14px;
     width: 100%;
     max-width: 600px;
     margin: auto;
     padding: 0 15px;
 }

 .note-list {
     list-style: none;
 }

 .note-item {
     position: relative;
     padding-left: 22px;
     line-height: 1.8;
     text-align: justify;
     margin-bottom: 5px;
 }

 .note-item::before {
     content: "※";
     position: absolute;
     left: 0;
     top: 0;
     font-weight: 400;
 }

 .johnsonCopyrught {
     background-color: #9e1f24;
     color: #fff;
     font-size: 12px;
     text-align: center;
     padding: 20px 0;
     letter-spacing: 1px;
 }

 .socialink {
     margin: 30px auto;
     display: flex;
     text-align: center;
     justify-content: center;
 }

 .socialink li {
     margin: 0 10px;
 }

 .soicalIcon {
     width: 20px;
 }

 .u-mobile-only {
     display: block;
 }

 .u-desktop-only {
     display: none;
 }

 /*桌機*/
 @media (min-width: 768px) {
     .saleAct-2 {
         background: linear-gradient(358deg, #f9ece4 0%, #f9ece4 15%, #efd8cb 20%, #e1c6c4 20%, #f9ece4 50%, #f9ece4 100%);
     }

     .u-text-xl {
         color: #ab3b3a;
         font-size: 3.63cqi;
         font-weight: 500;
         line-height: 1.3;
     }

     .u-text-lg {
         color: #ab3b3a;
         font-size: 2.54cqi;
         font-weight: 500;
         line-height: 1.4;
     }

     .u-text-base {
         color: #000000;
         font-size: 1.25cqi;
         line-height: 1.6;
     }

     .u-text-sm {
         color: #000000;
         font-size: 1.27cqi;
     }

     .jp4000Box {
         flex-direction: row;
         align-items: center;
     }

     .masaChirItemYt {
         flex: 0 0 50%;
     }

     .jp4000PriceBox {
         flex: 0 0 50%;
     }

     .A366Box,
     .A395Box,
     .A585Box,
     .A580Box {
         width: 50%;
     }

     .actPro-info {}

     .m585580Title {
         flex-direction: row;
         justify-content: center;
         align-items: center;
     }

     .m395366Title {
         text-align: center;
         padding: 0 0 20px 0;
     }

     .m395366TitleBox {
         flex-direction: row;
         justify-content: center;
         align-items: flex-end;
     }

     .m395366,
     .m585580 {
         flex-direction: row;
         gap: 1%;
     }

     .saleTicket {
         max-width: 300px;
         margin-left: 55%;
     }

     .A395Box,
     .A366Box {
         padding: 40px 40px;
     }

     .A395Box>div:nth-child(1),
     .A366Box>div:nth-child(1) {
         flex: 0 0 30%;
     }

     .A395Box>div:nth-child(2),
     .A366Box>div:nth-child(2) {
         flex: 0 0 70%;
         margin-top: 70px;
     }

     .sideTextBox-1 {
         position: absolute;
         left: 3%;
         top: 6%;
     }

     .sideTextBox-2 {
         position: absolute;
         left: 52%;
         top: 19%;
     }

     .fit-wrapper {
         background-repeat: no-repeat;
         background-position: top center;
         background-size: 100%;
     }

     .fit-wrapper .pro-container {
         padding-top: 5%;
         margin-top: -12%;
     }

     .pro-container {
         grid-template-columns: repeat(3, 1fr);
         gap: 24px;
         padding: 0 5%;
     }

     .pro-info {
         gap: 10px;
     }

     .pro-model {
         font-size: 13px;
     }

     .pro-name {
         font-size: 16px;
     }

     .pro-price {
         font-size: 18px;
     }

     .pro-price span {
         font-size: 13px;
     }

     .mass-wrapper {
         padding-top: 30%;
         background-size: 100%;
     }

     .u-mobile-only {
         display: none;
     }

     .u-desktop-only {
         display: block;
     }
 }