*{
    box-sizing: border-box;
    font-family: "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
    color: #707070;
}

html {
  scroll-behavior: smooth;
}

a{
    text-decoration: none;
}

header{
   background-color: rgba(34,34,34);
    height: 60px;
    display: flex;
    align-items: center;
	justify-content:space-between;
    padding:0 12px;
    width: 100%;
	min-width:393px;
	position:fixed;
	top:0;
	z-index:100;
}

.notranslate {
    color: white !important;
}

#gt_float_wrapper{
	display:flex;
	align-items:center;
}

#header-text{
    font-size: 24px;
    font-weight: 900;
    color: white;
}

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

main{
    width: 393px;
	margin:60px 0 40px;
}

#top-back-btn {
    position: fixed;
    bottom: 50px;
    right: 10px;
    z-index: 100;
	transition: transform 0.3s ease-in-out, filter 0.3s ease-in-out;
}

#top-back-img {
    display: block;
    width: 50px;
    height: auto;
    aspect-ratio: 1 / 1;
}

.swiper-pagination{
    position: relative;
    margin-top: 10px;
}

.swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal{
    bottom: 0;
}

.swiper-pagination-bullet{
    background-color: white;
    border: solid 1px #707070;
    opacity: 1;
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 11px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 11px));
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 5px);
}

.swiper-pagination-bullet-active{
    background-color: #707070;
}

.swiper-button-next, .swiper-button-prev {
    top:unset;
    bottom: 1.5px;
    color: #707070;
    height: auto;
    text-shadow: 
    0.7px 0 0 #707070, 
    -0.7px 0 0 #707070,
    0 0.7px 0 #707070,
    0 -0.7px 0 #707070;
    z-index: 100;
}

.swiper-button-prev{
    left: var(--swiper-navigation-sides-offset, 80px);
}

.swiper-button-next{
    right: var(--swiper-navigation-sides-offset, 80px);
}

.swiper-button-next::after, .swiper-button-prev::after {
    font-size: 12px;
  }

.swiper-slide{
    overflow: hidden;
    height: 393px;
}

.swiper-wrapper {
    margin-top:0 !important;
margin-left:0 !important;
}

.swiper-img{
    display: block;
    width: 100%;
    object-fit: contain;
}

button{
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
}

#btn-container{
    margin: 30px 0 40px;
    display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: 20px;
}

.btn{
    min-width: 250px;
    height: auto;
    text-align: center;
	background-color: var(--cocoon-custom-background-color, #222) !important;
    color: white;
	padding:7.5px 0 !important;
    font-size: 14px;
    font-weight: 600;
    display: block;
    transition: filter 0.3s ease; /* 好みのタイミングに調整 */
}

.btn>font {
    display: block;
    width: 200px;
    margin: auto;
    text-align: center;
}

#survey-btn{
	position: fixed !important;
    bottom: 57px;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 30px !important;
    z-index: 100;
	transition: transform 0.3s ease-in-out, filter 0.3s ease-in-out;
}

#survey-btn:hover{
  transform: translateX(-50%) scale(1.2);
  /* または、transform-origin: center center; も念のため指定 */
  transform-origin: center center;
}

#top-back-btn:hover{
	transform: scale(1.2,1.2);
	filter: brightness(0.7);
}

.btn.link{
	background-color: var(--cocoon-custom-background-color, #b9b9b9) !important;
	min-width:200px;
}

.btn.link>font>font,#survey-btn>font>font{
	color:#fff !important;
}

#btn-container>a{
	position:relative;
}

.union-img,.arrow-img{
	position:absolute;
	display:block;
	width:12.5px;
	height:auto;
	aspect-ratio: 1/1;
	top:0;
	bottom:0;
	right:17.5px;
	margin:auto;
}

.arrow-img{
	right:1.5px;
	width:40px;
}

#home-btn{
	display:flex;
	justify-content:center;
	align-items:center;
	width:200px;
	position:relative;
	transition: background-color 0.3s ease; /* 好みのタイミングに調整 */
	padding:5px 0;
}

#home-btn-img{
	display:block;
	width:35px;
	height:auto;
	position:absolute;
	top: 0;
    bottom: 0;
    left: 10px;
	margin:auto;
}

#home-btn-text{
	font-size: 12px;
    font-weight: 600;
	margin-top:1px;
}

/* --- CTA ボタン --- */
.easy-survey-btn-container{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  row-gap:3vw;
  background:#fff;
  font-size:3vw;
  font-weight:600;
  border:solid 1px #CCCCCC;
  border-radius:10px;
  cursor:pointer;
  transition:.2s;
  width:58.5vw;
  height:22.9vw;
  box-shadow: rgba(11, 42, 58, .08) 0 8px 8px 8px;
  position:fixed;
  top:75vh;
  right:2.8vw;
	z-index:10000;
	overflow: hidden;
  transition: opacity .45s ease, max-height .45s ease, margin .45s ease;
}

.easy-survey-cta{
	background-color:#097BFF;
	display:flex !important;
	column-gap:1vw;
	justify-content:center;
	align-items:center;
	width:42vw;
	height:9.2vw;
	padding:0 !important;
	color:#fff;
	font-size:3vw !important;
	font-weight:600;
	border-radius:10px;
}

/* --- 質問文（任意） --- */
.easy-survey-question{
  font-weight: 600;
  text-align: center;
  color:#707070;
  font-size:3vw;
}


@media screen and (min-width:769px) {
	/* --- CTA ボタン --- */
.easy-survey-btn-container{
  row-gap:1.5vw;
  font-size:3vw;
  width:30vw;
  height:12.5vw;
  top:70vh;
  right:3vw;
	max-width:380px;
	max-height:157px;
	right:unset;
	top:unset;
	position:relative;
	margin:4vw auto 0;
}

.easy-survey-cta{
	column-gap:1vw;
	width:22vw;
	height:5vw;
	max-width:319px;
	max-height:64px;
}

.easy-survey-question,.easy-survey-cta{
	font-size:min(1.5vw,20px) !important;
}

}

.item-name{
    font-size: 16px;
    font-weight: 900;
    margin: 41px 0 20px;
    text-align: center;
}

.item-cost{
    font-size: 12px;
    font-weight: 600;
    margin-bottom: 40px;
    text-align: center;
}
  
.item-detail{
    display: flex;
    flex-direction: column;
    row-gap: 20px;
    padding: 0 21.2px;
    overflow: hidden;
    margin: 50px 0 0;
}

.detail-text{
    font-size: 12px;
    line-height: 1.66;
}

.btn:hover{
    filter: brightness(0.7);
}

#home-btn:hover{
	background-color:#d0d0d0;
	border-radius:5px;
}

footer{
    height: 40px;
    background-color: rgba(34,34,34);
	min-width:393px;
    width: 100%;
    padding:0 20px;
    display: flex;
    align-items: center;
	justify-content:space-between;
	z-index:100;
}

#footer-text{
    color: white;
    font-size: 18px;
    font-weight: 600;
}

#copyright {
    color: white;
    font-size: 8px;
}

#swiper-nav-item{
    display: flex;
    column-gap: 2vw;
    align-items: center;
}

.swiper-button-next, .swiper-button-prev {
    position: relative;
}

.swiper-button-next{
    right: 0;
}

.swiper-button-prev{
    left: 0;
}

.swiper-pagination {
    margin-top: 0;
}

#swiper-nav-item{
    margin-top: 10px;
}

.swiper-button-next, .swiper-button-prev {
    bottom: 0;
    top: 0;
    margin: auto;
}

#HOYA-img>.swiper-slide>.swiper-img{
        width: 135%;
    }
    
    #tsumekiri-img>.swiper-slide>.swiper-img{
        width: 100%;
    }    

.swiper-pagination-bullets.swiper-pagination-horizontal{
    width: fit-content;
}

#HOYA-img>.swiper-slide,#tsumekiri-img>.swiper-slide,#sensu-img{
    display: flex;
    justify-content: center;
    align-items: center;
	height:auto;
}

.wpulike{
	position:absolute;
	right:45px;
	top:355px;
	z-index:99;
	padding:0;
	line-height:1;
}

#comment-toggle-wrapper{
	position:absolute;
	right:10px;
	top:356px;
	z-index:99;
}

#comment-close-btn{
	position:absolute;
	right:16px;
	top:-46px;
	z-index:99;
	display:flex;
	align-items:center;
	width: fit-content;
    height: 22px;
	column-gap:3px;
}

#close-comment-img{
	display:block;
	height:100%;
	aspect-ratio:1/1;
	object-fit: contain;
}

#close-text{
	display:block;
	width:fit-content;
	font-size:15px;
	color:#707070;
}

.wpulike-heart .wp_ulike_general_class{
	box-shadow:none;
	padding:0;
	display:block;
	position:relative;
}

.wpulike-heart .count-box{
	padding:0;
	line-height:1;
	color: #707070;
	position:absolute;
	inset:0;
	margin:auto;
	display:block;
	width:fit-content;
	height:14px;
	font-size:12px;
	padding-top:2px;
}

#total-comment-count{
	font-size: 12px;
    text-decoration: none;
    line-height: 1;
    display: block;
    color: #707070;
    text-align: center;
    font-weight: 600;
	width:fit-content;
	height:12px;
    vertical-align: middle;
	position:absolute;
	inset:0;
	margin:auto;
}

.wpulike-heart .wp_ulike_put_image:after{
	width:30px;
	height:30px;
	display:block;
}

.wpulike.wpulike-heart>.wp_ulike_general_class>.wp_ulike_btn {
    background: 0 0;
    padding: 15px;
}

.wp_ulike_is_liked>.count-box{
	color:#fff !important;
}

#raden-swiper>.swiper-slide,#tsumekiri-img>.swiper-slide{
	display:flex;
	align-items:center;
	background-color:white;
}

#tsumekiri-swiper>.wpulike{
	bottom:0;
	top:285px;
	height:auto;
}

#tsumekiri-swiper>#comment-toggle-wrapper{
	top:286px;
}

#sensu-swiper>.wpulike{
	bottom:0;
	top:300px;
	height:auto;
}

#sensu-swiper>#comment-toggle-wrapper{
	top:301px;
}

#comment-container{
	height:auto;
	scroll-margin-top: 80px;
	position:relative;
	margin-top:80px;
}

#comments{
	height:100%;
}

#respond{
	visibility:visible !important;
	position:relative !important;
	padding:0 12px;
		width:94%;
	margin:20px auto !important;
}

.comment-form{
	display:flex;
	column-gap:10px;
	border-bottom:solid 1px gray;
	align-items:flex-end;
	padding-bottom:5px;
}

#comment-toggle-button{
	display:block;
	width:28px;
	aspect-ratio:1/1;
	height:auto;
	position:relative;
}

.comment-svg{
	display:block;
	width:100%;
	object-fit:contain;
}

.reply-form-container>.comment-form>.comment-form-comment>label{
	font-size:15px;
	font-weight:bold;
	margin-top:5px;
}

textarea {
    resize: none !important;
}

textarea:focus {
  /* デフォルトのアウトラインを消去 */
  outline: none;
  
  /* 固定の点線ボーダーを一旦設定 */
  border: 2px dashed #0073aa;
  
  /* アニメーションでボーダーの色を点滅させる */
  animation: blink-dotted 1s linear infinite;
}

/* 点滅アニメーション */
@keyframes blink-dotted {
  0%, 100% {
    border-color: black; /* 点線の色を指定 */
  }
  50% {
    border-color: transparent;
  }
}

.comment-form-comment{
	width:90%;
	display:block;
	height:auto;
	line-height:1;
}

.comment-form-comment>label{
	display:block;
	margin-bottom:5px;
	font-size:18px;
}

.form-submit{
	width:8%;
	display:block;
	margin-bottom:5px;
}

#submit{
	display:block;
	width:100%;
	margin:0;
}

#comment{
	min-height:18px;
	height:auto;
	overflow-y: hidden;     /* スクロールバーを隠す */
  resize: none;    
	padding:0;
	border:none;
	background-color:inherit;
	font-size:16px;
	line-height:1.33;
	overflow: hidden;
}

.comment-list{
	padding:0 25px;
	display:flex;
	flex-direction:column;
	row-gap:20px;
}

.comment-body{
position:relative;
	display:flex;
	flex-wrap:wrap;
	column-gap:10px;
	align-items:center;
	row-gap:5px;
}

.comments-title{
	font-weight:bold;
	padding-left:20px;
	height:auto;
	line-height:1;
	margin-bottom:15px;
}

.comment-content{
	display:flex;
	flex-wrap:wrap;
	row-gap:5px;
	column-gap:10px;
	align-items:center;
}

.reply-icon-container{
	height:16px;
}

.reply-icon-container>a,.reply-icon-container>a>img{
	display:block;
	height:100%;
	object-fit:contain;
}

.reply-link.active {
  background-color: #f0f0f0;
}

.comment-actions{
	height:auto;
	line-height:1;
	padding-left:5px;
	margin-top:5px;
}

.comment-actions>a{
	font-size:14px;
}

.toggle-arrow{
	height:15px;
	width:auto;
	display:inline-block;
}

.comment-content>p{
	display:block;
	width:100%;
	font-size:17px;
	line-height:1.33;
	height:auto;
}

.wpulike.wpulike-default{
display:none;
}

.wpulike.wpulike-default button.wp_ulike_btn{
	background-color:transparent;
	min-height:unset;
	min-width:unset;
}

.wpulike-default .count-box {
	line-height:22px;
	padding:0 5px;
	font-weight:bold;
	font-size:12px;
}

.wpulike button.wp_ulike_btn{
	color:#707070;
	padding:8px;
}

.child-comments-container{
	margin-top:7.5px;
}

.child-comments-container>.children{
	padding-left:30px !important;
	display:flex;
	flex-direction:column;
	row-gap:15px;
}

.children{
	list-style:none !important;
}

#toc,.logged-in-as,.required,.comment-author.vcard,.comment-meta.commentmetadata,#reply-title,.comment-list>.children{
	display:none !important;
}

@media screen and (min-width:769px){

    body{
        min-height: 100vh;
    }

    header{
        width: 100vw;
        padding-left: 2vw;
    }

    main{
        width: 100vw;
        border: none;
        flex:1;
        display: flex;
        align-items: center;
        justify-content: center;
		margin:3.5vw 0 3vw;
    }

    #main-flex{
        display: flex;
        padding: 5vw 3vw 3vw;
        column-gap: 4vw;
        justify-content: center;
    }
	
#top-back-btn {
            bottom: 50px;
        right: 2.5vw;
}

#top-back-img {
            width: 7.5vw;
        max-width: 70px;
}

    .swiper-pagination-bullet{
        width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 1.2vw));
        height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 1.2vw));    
    }

    .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
        margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 0.6vw);
    }   
    
    .swiper-button-next::after, .swiper-button-prev::after {
        font-size: 1.5vw;
    }

    .swiper-slide{
        aspect-ratio: 1/1;
        height: auto;
    }    
	
	#swiper-nav-item{
	margin-top:2vw;
	}

    #item-slide{
        width: 38vw;
		position:relative;
    }
    
    #HOYA-img>.swiper-slide{
        align-items: flex-start;
    }    
    
    #HOYA-img>.swiper-slide>.swiper-img{
        width: 135%;
    }
    
    #tsumekiri-img>.swiper-slide>.swiper-img{
        width: 115%;
    }    

    #item-description{
        width: 34vw;
    }

    .item-name{
        margin: 0 0 1.5vw;
        font-size: 1.7vw;
    }

    .item-cost{
        font-size: 1.2vw;
        margin-bottom: 3vw;
    }

    .item-detail{
        margin-top: 0;
        padding: 0;
        row-gap: 1.6vw;
    }

    .detail-text{
        font-size: 1.04vw;
    }

    #btn-container{
        justify-content: center;
		row-gap:2vw;
		margin:3vw 0 3.5vw;
    }

    .btn{
        margin: 0 !important;
        width: 23vw !important;
        height: auto;
        aspect-ratio: 100/21;
        font-size: min(1.6vw, 50px);
    }
	
#home-btn{
	width:20vw;
	padding:0.5vw 0;
}

#home-btn-img{
	width:4vw;
    left: 1vw;
}

#home-btn-text{
	font-size: 1.2vw;
	margin-top:0.5%;
}

    footer{
        width: 100vw;
        padding:0 2vw;
    }

.ex-nav{
	margin-top:-
}
	
#sensu-swiper>.wpulike{
	bottom:2.5vw;
		top:unset;
}
	
.union-img,.arrow-img{
	width:1.2vw;
	right:1.5vw;
}

.arrow-img{
	right:0.03vw;
	width:4vw;
}
	
	#raden-swiper>.swiper-slide,#tsumekiri-img>.swiper-slide{
	display:flex;
	align-items:center;
	background-color:white;
}

#sensu-swiper>.wpulike{
	bottom:0;
}
	
.wpulike{
	right:3.7vw;
	top:35vw;
}

#comment-toggle-wrapper{
	right:1vw;
	top:35vw;
}
	
#total-comment-count{
		top:0.1vw;
	font-size:1vw !important;
	height:1vw;
	}

.wpulike-heart .count-box{
	font-size: 1vw !important;
	height:1vw;
	padding-top:0.15vw;
}

.wpulike-heart .wp_ulike_put_image:after{
	width:2.5vw;
	height:2.5vw;
}

.wpulike.wpulike-heart>.wp_ulike_general_class>.wp_ulike_btn {
    padding:1.2vw 1.25vw;
}

#respond{
	padding:0 1.2vw;
	margin:1.5vw 0 !important;
}

#toc2{
	font-size:1.3vw;
}

.comment-form{
	column-gap:1vw;
	border-bottom:solid 1px gray;
	padding-bottom:0.3vw;
}

#comment-toggle-button{
	width:2.3vw;
}

.comment-svg{
	display:block;
	width:100%;
	object-fit:contain;
}

.reply-form-container>.comment-form>.comment-form-comment>label{
	font-size:15px;
	font-weight:bold;
	margin-top:5px;
}

.comment-form-comment{
	width:90%;
	display:block;
	height:auto;
	line-height:1;
}

.comment-form-comment>label{
	font-size:1.6vw;
	margin-bottom:0.3vw;
}

.form-submit{
	width:8%;
	display:block;
	margin-bottom:0.3vw;
}

#comment{
	font-size:1.3vw;
	height:1.75vw !important;
}

.comment-list{
	padding:0 2vw;
	row-gap:2vw;
}

.comments-title{
	padding-left:1.2vw;
	margin-bottom:1.5vw;
}

.comment-content{
	row-gap:0.5vw;
	column-gap:1vw;
}

.reply-icon-container{
	height:1.6vw;
}

.comment-actions{
	padding-left:0.5vw;
	margin-top:0.3vw;
}

.comment-actions>a{
	font-size:1.1vw;
}

.toggle-arrow{
	font-size:1.4vw;
	height:1.4vw;
}

.comment-content>p{
	font-size:1.5vw;
}
	
.wpulike button.wp_ulike_btn{
	padding:0.8vw;
}
	
.wpulike-default .wp_ulike_put_image:after{
	width:1.5vw;
	height:1.5vw;
}
	
.wpulike-default .count-box {
	line-height:1.8vw;
	padding:0 0.5vw;
	font-size:0.8vw;
}

.child-comments-container{
	margin-top:0.8vw;
}

.child-comments-container>.children{
	padding-left:2vw !important;
	row-gap:1.5vw;
}
	
#sensu-swiper>.wpulike{
	top:31.5vw;
}

#sensu-swiper>#comment-toggle-wrapper{
	top:31.5vw;
}
	
#tsumekiri-swiper>.wpulike{
	top:34.2vw;
}

#tsumekiri-swiper>#comment-toggle-wrapper{
	top:34.2vw;
}
	
	#survey-btn{
		width: 420px !important;
        height: auto;
        aspect-ratio: 100 / 11;
        font-size: 16px;
        bottom: 60px;
        min-width: unset;
	}
	
	 .btn>font {
        width: auto;
        margin: 0;
    }
	
	.btn>font>font{
		        font-size: 15px !important;
        padding: 0 0.5vw;
	}
	
	#comment-container{
		scroll-margin-top:9vw;
		margin-top:9vw;
	}
	
	#comment-close-btn{
	right:1vw;
	top:-4.8vw;
	height: 1.5vw;
	column-gap:3px;
}

#close-text{
	font-size:1.4vw;
}

}