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

/* A Modern CSS Reset */
 
*,*::before,*::after{box-sizing:border-box}body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}ul[role="list"],ol[role="list"]{list-style:none}html:focus-within{scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5}a:not([class]){text-decoration-skip-ink:auto}img,picture{max-width:100%;display:block}input,button,textarea,select{font:inherit}@media(prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}

html {
	/*scroll-behavior: smooth;*/
}

#sakura {
    height: 100%;
    width: 100%;
    position: fixed;
    top: 0px;
	z-index: -1;
}

body {
    margin: 0;
    padding: 0;
    background-color: #fbf6f6;
	letter-spacing: 0.05em;
    width: 100%;
    height: 100%;
    font-feature-settings: "pkna"!important;
    color: #512e17;
	background-image:url("../img/bg.jpg");
	background-size: 400px;
	background-repeat: repeat;
    background-attachment: fixed;
	margin: 0;
    padding: 0;
	overflow-x: hidden;
	font-family: "Helvetica Neue",
    Arial,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    Meiryo,
    sans-serif;
}




ul,li {
    list-style-type: none;
}

ul, menu, dir {
    display: block;
    list-style-type: disc;
    -webkit-margin-before: 0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
    -webkit-padding-start: 0px;
}

p {
    display: block;
    -webkit-margin-before: 0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
}

img {
    width: 100%;
    height: auto;
    border-style: none;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    user-drag: none;
    pointer-events: none;
    vertical-align: bottom;
}
a:hover {
    cursor: pointer;
    opacity: .75;
}

a {
    display: block;
}

b, strong, .bold{
	font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI semibold", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic", "Segoe UI", Verdana, Meiryo, sans-serif;
}

canvas {
  display: block;
}


.container {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
	overflow: hidden;
	position: fixed
}

.star {
    position: absolute;
    background: url('../img/star.png') no-repeat center center;
    background-size: contain;
    width: 10px;
    height: 10px;
    opacity: 0;
}

@keyframes shoot {
    0% {
        transform: translate3d(0, 0, 0);
        opacity: 1;
    }
    70% {
        opacity: 1;
    }
    100% {
        transform: translate3d(100vw, 100vh, 0);
        opacity: 0;
    }
}
.star {
    animation-timing-function: cubic-bezier(0.42, 0, 0.58, 1); /* 緩急のある動きを設定 */
}

/********** ふわっと表示 ***********/
.effect-fade {
    opacity : 0;
    transform : translate(0, 100px);
    transition : all 1000ms;
}

.effect-fade.effect-scroll {
    opacity : 1;
    transform : translate(0, 0);
}



_:lang(x)::-ms-backdrop, .selector {
	font-family: "Segoe UI", Meiryo, sans-serif;
}



/********** ここから ***********/

.wrapper {
    position: relative;
    display: flex;
    height: 100%;
}

/********** 中央セールコンテンツ ***********/

.main {
    position: relative;
    height: 100%;
    width: calc(40% - 100px);
    margin-left: calc(60% - 100px);
    box-shadow: 6px 0px 10px 0px rgba(65, 64, 62, 0.15);
    z-index: 2;
    padding-top: 40px;
}

section.main-head {
    width: 100%;
    position: relative;
    padding-bottom: 70px;
    margin-bottom: 5vh;
    overflow: hidden;
}

.kikan-box {
    text-align: center;
    position: absolute;
    bottom: 70px;
    right: 0;
    left: 0;
    margin: 0 auto;
}

p.kikan-title {
    background-color: #efd564;
    color: #113755;
    font-size: 1.5rem;
    font-weight: bold;
    letter-spacing: 0.15rem;
    border-radius: 31px;
    padding: 5px 20px;
    display: inline-block;
}

p.kikan {
    background-color: #ffffff;
    padding: 40px 20px 20px;
    position: absolute;
    right: 0;
    left: 0;
    bottom: -70px;
    z-index: -1;
    font-size: 1.5rem;
	font-weight: bold;
}

section.greetings {
    width: 100%;
    margin-bottom: 15vh;
}

.ec-japan {
    width: 90%;
    margin: 0 auto 20px;
}

.greeting-box {
    width: 75%;
    margin: 0 auto;
    font-size: 12px;
    overflow: hidden;
}

.greeting-box .space {
  float: right;
  height: 10em;
}

.greeting-box .img {
    width: 105px;
    float: right;
    clear: both;
    margin: 1em 0 0 1em;
}

p.greeting-txt {
    font-size: 14px;
    text-align: justify;
    line-height: 1.8;
	color: #ffffff;
}

#pointup-coupon {
	margin-bottom: 20vh;
	overflow: hidden;
}

#pointup-coupon .point-coupon-title {
	width: 80%;
	margin: 0 auto 2rem;
	padding-top: 40px;
}

#pointup-coupon ul {
	display: flex;
	flex-wrap: wrap;
	justify-content:center;
	gap: 10px 10px;
	width: 80%;
	margin: 0 auto;
}

#pointup-coupon ul li {
	width: calc(100%/2 - 5px);
	justify-content: space-between;
	background-color: #371804;
	height: auto;
	border:1px solid #867b73;
	box-sizing: border-box;
}

section.sale-box {
    width: 100%;
}

#sale01, #sale02, #sale03, #sale04 {
    position: relative;
    width: 90%;
	padding-top:80px;
    margin: -80px auto 20vh;
}

.sale-inner {
	background-color: #FFFFFF;
}

.sale-number {
    width: 120px;
    margin: 0 auto;
    position: absolute;
    left: 0;
    right: 0;
    top: 20px;
}

.sale-title-img {
    width: 86%;
    margin: 0 auto 20px;
    padding-top: 20px;
}

.sale-item-img .quote-wrapper {
    position: absolute;
    left: -5px;
    top: -5px;
}

.sale-item-img .quote-wrapper .text  {
	position: relative;
    border-radius: 50%;
    background-color: #bf0000;
    border: 3px solid #bf0000;
    display: inline-grid;
	width: 100px;
	height: 100px;
}

.sale-item-img .quote-wrapper .text p {
	position: absolute;
	display: inline-block;
	left: 0;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	align-content: center;
    text-align: center;
    color: #ffffff;
    font-weight: bold;
	line-height: 1.25;
	width: 94px;
}

.sale-item-img .quote-wrapper .text p span {
	font-size: 1.5rem;
}

ul.sale-list li .sale-item-img {
    position: relative;
    margin-bottom: 2rem;
    width: 90%;
    margin: 0 auto 20px;
}

.item-info {
    width: 86%;
    margin: 0 auto 20px;
    display: flex;
    gap: 15px;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
}

.item-spec-box {
    width: 62%;
}

.item-spec-box .notes {
	font-size: 0.7rem;
}

.price-box {
    width: 38%;
    border: 1px solid;
    text-align: center;
    line-height: 1.2;
}

p.name {
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1.2;
    margin-bottom: 4px;
}


.item-info .item-name ul li {
    background-color: #371804;
    display: inline-block;
    color: #ffffff;
    font-size: 0.8rem;
    padding: 2px 5px;
	margin-right: 5px;
}
.item-info .item-name ul li:last-child {
	margin-right: 0;
}

.item-name {
    margin-bottom: 10px;
    line-height: 1.5;
}

.item-name .name span {
    font-size: 1.2rem;
    display: block;
}

p.item-text {
    text-align: justify;
    font-size: 14px;
}

p.off {
    background-color: #bf0000;
    color: #ffffff;
    padding: 5px 5px 0 5px;
    font-weight: bold;
    font-size: 0.9rem;
    position: relative;
}

p.off:after {
    position: absolute;
    content: "";
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    width: 100%;
    height: 10px;
    bottom: -9.8px;
    left: 0;
    background: #bf0000;
}

p.off span {
	font-size: 1.2rem;
}

p.price {
	font-weight: bold;
    padding: 5px;
    box-sizing: border-box;
}

.price span {
    font-size: 0.75rem;
}

p.sale-price {
    padding: 14px 5px 5px;
    font-weight: bold;
    background-color: #e8e59b;
    color: #bf0000;
    font-size: 0.9em;
}

.price-box .sale-price span {
    font-size: 1.8rem;
}

p.soryo {
    background-color: #371804;
    color: #ffffff;
    padding: 5px;
    font-weight: bold;
    font-size: 0.9rem;
}

ul.multiple-sale {
    font-size: 0.8rem;
}

ul.multiple-sale li {
    padding: 5px;
    border-bottom: 1px dotted;
	font-weight: bold;
	font-size: 0.8rem;
}

ul.multiple-sale li:last-child {
	border-bottom:none;
}

.multiple-sale span {
    color: #bf0000;
    font-size: 1.2em;
}

.item-link,
.multi-item-link {
	text-align: center;
    width: 90%;
	margin: 0 auto 60px;
}

.multi-item-link ul li {
	background-color: transparent;
    padding: 0;
    margin-bottom: 0;
}


.item-link a,
.multi-item-link ul li a {
    margin: 0 auto 20px;
	position: relative;
	text-decoration: none;
	display: inline-block;
    text-align: center;
    background: transparent;
	border-radius: 25px;
	border: solid 2px #bf0000;
    outline: none;
    /*アニメーションの指定*/
    transition: all 0.2s ease;
	width: 100%;
}

.item-link a:hover,
.multi-item-link ul li a:hover {
	border-color:transparent;
	cursor: pointer;
}



.item-link p,
.multi-item-link ul li p {
	display: inline-block;
	position: relative;
	z-index: 2;
	display: block;
    padding: 10px 30px;
	background:#e8e59b;
	border-radius: 25px;
	color:#bf0000;
    transition: all 0.3s ease;
	font-weight: bold;
	font-size: 22px;
}

 .multi-item-link ul li p {
    font-size: 16px;
    padding: 7px 20px;
}


/*影の設定*/
.pushright:before {
    content: "";
    /*絶対配置で影の位置を決める*/
    position: absolute;
	z-index: -1;
    top: 4px;
    left: 4px;
    /*影の形状*/
    width: 100%;
    height: 100%;
	border-radius: 25px;
    background-color: #bf0000;
}

/*hoverの際にX・Y軸に4pxずらす*/
#main-content #sale-box .sale-body .sale ul li .item-link .pushright:hover p,
#main-content #sale-box .sale-body .sale ul li .multi-item-link ul li .pushright:hover p {
	background-color: #bf0000;
	color: #fff;
	transform: translate(4px, 4px);
}

/***** ページ下部 *****/
.footer-content {
	max-width: 80%;
	margin: 0 auto;
	display: block;
}

.order-ranking-box {
	margin-bottom: 7rem;
}

.order-box {
	margin-bottom: 7rem;
}
.order-box,.ranking-box {
	width: 100%;
	background-color: #ffffff;
	border-radius: 20px;
	padding: 20px;
	box-sizing: border-box;
}

.footer-content .title {
	width: 86%;
	max-width: 400px;
	margin: -40px auto 20px;
	overflow: hidden;
}

.footer-content iframe {
	width: 100%;
	height:250px;
	margin-bottom: 10px;
}

.order-box p {
	text-align: center;
	color: #887b6d;
	font-size: 20px;
	font-weight: bold;
	font-family: fot-tsukuardgothic-std, sans-serif;
}

.guide-box,.tamafes-box {
	width: 100%;
	background-color: #ffffff;
	border-radius: 20px;
	padding: 20px 40px;
	font-size: 15px;
	box-sizing: border-box;
}

.guide-box .title {
	margin-bottom: 40px;
}

.guide-box ul {
	display: flex;
	flex-wrap: wrap;
	gap:10px;
}

.guide-box ul li {
	width: 100%;
}

.guide-box .in-title {
	background-color: #371804;
	text-align: center;
	font-size: 18px;
	font-weight: bold;
	color: #ffffff;
	padding: 5px 0;
}

.guide-box .guide-in {
	padding: 15px;
	box-sizing: border-box;
	background-color: #f6f0db;
}

.guide-box .haiso {
	font-size: 15px;
	text-align: center;
	margin-bottom: 10px;
}
.guide-box .haiso span {
	font-size: 20px;
}

.guide-box .holiday {
	text-align: right;
	font-size: 14px;
	font-weight: bold;
	color: #371804;
}

.guide-box iframe {
    width: 100%;
    height: 200px;
}

.guide-box .holiday span {
	width: 25px;
	height: 25px;
	background-color: #c4ae96;
	border-radius: 3px;
	display: inline-block;
	vertical-align: middle;
	margin-right: 10px;
}

.guide-box .logo-img {
	max-width: 220px;
}

.guide-box .mini-icon {
	display: inline-block;
	width: 24px;
	height: auto;
	margin-right: 5px;
}

.guide-box a {
	width: 100%;
	background-color: #371804;
	text-align: center;
	padding: 10px 0;
	color: #ffffff;
	font-weight: bold;
	margin-top: 10px;
	text-decoration: none;
	border-radius: 5px;
}

/***** タマリバ紹介 *****/
.tamaliba {
	display: block;
	width: 86%;
	height: auto;
	margin: 10rem auto 7rem;
	max-width: 800px;
}


/********** 右メニュー ***********/

.right-menu {
    position: fixed;
	background-color: #d6eaea;
    top: 0;
    right: 0;
    height: 100%;
    min-width: 200px;
}

.right-menu-inner {position: relative;width: 100%;height: 100%;}

.right-menu .tamalogo {
    width: 120px;
    margin: 15px auto;
}

.right-menu .sale-list {
    position: absolute;
    max-width: 120px;
    right: 0;
    left: 0;
    bottom: calc(50vh - 300px);
    margin: 0 auto;
}

.right-menu .sale-list-title {margin-bottom: 15px;}

.right-menu ul li {
    margin-bottom: 12px;
}

.btn_close,.list-page-top {
    display: none;
}

.page-top {
	margin: 100px auto;
	width: 120px;
}

.copyright {
	color: #ffffff;
	text-align: center;
	font-size: 0.8rem;
	margin-bottom: 20px;
}

/********** 左スライダー ***********/

.left-slider {
	background-color: #ffffff;
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: calc(60% - 100px);
}

.slider-wrap {
	position: relative;
}


.slider-wrap ul li {
  overflow: hidden;
  padding: 0;
}

.slider-wrap ul li img {
    display: block;
    width: 100%;
    height: 100vh;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    object-fit: cover;
}

.slide-animation img {
  width: 100%;
}
@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15); /* 拡大率 */
  }
}
.add-animation {
  animation: zoomUp 10s linear 0s normal both;
}

@media screen and (max-width: 1200px) {
	.left-slider {
		display: none;
	}
	
	.main {
        width: calc(100% - 200px);
        margin: 0;
    }
}

@media screen and (max-width: 700px) {
	
	.main {
        width: 100%;
        margin: 0;
		overflow: hidden;
    }
	
	.tamalogo {
		display: none;
	}
	
   #MenuPage_Category {
	   -webkit-transform: translate3d(0, 344px, 0); transform: translate3d(0, 344px, 0);
	}
	
	#MenuPage_Category {
        position: fixed;
        top: auto;
        bottom: 0;
        left: 0;
        width: 100%;
        border-radius: 0;
        background: #eda13b;
        color: #fbf8f6;
        padding: 0 0 30px;
        height: auto;
        z-index: 999;
        text-align: center;
        transition: .3s;
        transform: translate3d(0, 344px, 0);
        margin-top: 0;
    }
	
	    #MenuPage_Category.active {
        transform: translate3d(0, 0, 0);
    }
	
	#MenuPage_Category .sale-list-title {
        padding: 15px 0 30px;
        cursor: pointer;
        max-width: 240px;
        margin: 0 auto;
    }
	
	.right-menu .sale-list {
		position: unset;
		width: 70%;
		max-width: 280px;
		margin: 0 auto;
	}
	
	.btn_close,.list-page-top {
		display: block;
	}
	
	.list-page-top a {
        text-align: center;
        font-weight: bold;
        font-size: 1em;
        color: #371804;
        text-decoration: none;
        background-color: #e8e59b;
        padding: 5px 10px;
        box-sizing: border-box;
        border-radius: 10px;
    }
	
	.btn_close a {
		width: 32px;
		margin: 20px auto 0;
	}
	
}


@media screen and (max-width: 430px) {
    #MenuPage_Category {
        transform: translate3d(0, 306px, 0);
    }
	
	section.main-head {
    	padding-bottom: 80px;
	}
	
	.item-info {
    	width: 90%;
	}
	
	.multiple-sale span {
		display: block;
	}
	#sale01, #sale02, #sale03, #sale04 {
		width: 94%;
	}
	
	.tamaliba {
		width: 90%;
	}
	
	.footer-content {
		max-width: 90%;
	}
	
	.guide-box, .tamafes-box {
		padding: 20px 20px;
	}
	
	.footer-content .title {
		width: 100%;
	}
	
	.copyright {
		margin-bottom: 72px;
		padding: 0 20px;
	}
	
}

@media screen and (max-width: 390px) {
    #MenuPage_Category {
        transform: translate3d(0, 338px, 0);
    }
}

@media screen and (max-width: 375px) {
    #MenuPage_Category {
        transform: translate3d(0, 332px, 0);
    }
}

@media screen and (max-width: 344px) {
    #MenuPage_Category {
        transform: translate3d(0, 320px, 0);
    }
}

@media screen and (max-width: 320px) {
    #MenuPage_Category {
        transform: translate3d(0, 310px, 0);
    }
}