@charset "utf-8";

/*------------------------------------------------*/
/*  template ver1.0  */
/*------------------------------------------------*/
/*  templatename [--]  */
/*  update []  */
/*  ID [NT]  */
/*------------------------------------------------*/

/*　hc　*/
/* -----------------------------------------------*/

/*　Resize　*/
/* -----------------------------------------------*/
.is-resize #header nav,
.is-resize #header nav ul li .subfield {
transition:none;
}

/*　Plugin　*/
/* -----------------------------------------------*/

/*　error　*/
/* -----------------------------------------------*/

/*　All Reset　*/
/* -----------------------------------------------*/
* {
color:#222222;
/*font-size:clamp(12px, 1.0vw, 15px);*/
letter-spacing:0px;
}
*:not(br) {
line-height:1.65;
}
*:focus {
outline:none;
}
h1,h2,h3,h4,h5,h6,p,ul,ol,li,dl,dt,dd {
margin:0;
padding:0;
font-weight:400;
word-break:break-all;
}
ul,li {
list-style:none;
}
input[type="button"],input[type="submit"] {
border-radius:0;
-webkit-appearance:none;
appearance:none;
}
input, select {
-moz-appearance:none;
-webkit-appearance:none;
appearance:none;
}
::-ms-reveal {
display:none;
}
a {
color:#000000;
-webkit-user-select:none;
-moz-user-select:none;
-ms-user-select:none;
user-select:none;
-webkit-touch-callout:none;
}
a:hover {
text-decoration:none;
}

select {
padding-right:20px;
font-family:"IBM Plex Sans JP", sans-serif;
font-weight:400;
font-style:normal;
border:none;
background:none;
-webkit-appearance:none;
appearance:none;
}
select::-ms-expand {
display:none;
}

::selection {
background-color:#333333;
color:#ffffff;
}
::-moz-selection {
background-color:#333333;
color:#ffffff;
}

::-webkit-input-placeholder { /* WebKit, Blink, Edge */
color:#bebebe;
font-family:"IBM Plex Sans JP", sans-serif;
font-weight:400;
font-style:normal;
}
:-ms-input-placeholder { /* Internet Explorer 10-11 */
color:#bebebe;
font-family:"IBM Plex Sans JP", sans-serif;
font-weight:400;
font-style:normal;
}
::placeholder { /* Others */
color:#bebebe;
font-family:"IBM Plex Sans JP", sans-serif;
font-weight:400;
font-style:normal;
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
-webkit-appearance:none !important ;
margin:0 !important ;
-moz-appearance:textfield !important ;
}

button, a, input, textarea, .navline, .close {
-webkit-tap-highlight-color:transparent;
}

input:-webkit-autofill {
box-shadow: 0 0 0 1000px #eef4eb inset;
}


/*　Base Set　*/
/* -----------------------------------------------*/
body {
margin:0;
padding:0;
font-family:"IBM Plex Sans JP", sans-serif;
font-weight:400;
font-style:normal;
line-height:1.65;
/*background-color:rgba(0,0,0,0.02);*/
background-color:rgb(255,255,255,1.0);
overflow-x:hidden;
}
img {
max-width:100%;
box-sizing:border-box;
border:none;
pointer-events:none;
user-select:none;
-webkit-user-select:none; /* Safari対応 */
-ms-user-select:none;     /* 古いIE対応 */
}
.fit {
width:100%;
height:100%;
position:absolute;
top:0; 
left:0;
}
.fit img,
.fit video {
width:100%;
height:100%;
object-fit:cover;
object-position:center center;
font-family:'object-fit: cover; object-position: center center;'
}
.clearfix {
display:block;
}
.clearfix:after {
content:"";
display:block;
clear:both;
} 
.clearfix:before {
content:"";
display:block;
clear:both;
}

/*　Wrapper　*/
/* -----------------------------------------------*/
div#Wrapper {
margin:0px auto;
width:100vw;
text-align:center;
position:relative;
}
div.Container {
margin:0px auto;
width:100%;
}

/*　header　*/
/* -----------------------------------------------*/
header#header #cart-icon {
position:fixed;
bottom:20px;
right:20px;
}
header#header #cart-icon a {
display:inline-block;
text-decoration:none;
}
header#header #cart-icon p {
padding:0px 30px 0px 60px;
height:50px;
display:inline-block;
color:rgb(255,255,255,1.0);
font-family:"Roboto", sans-serif;
font-size:14px;
font-weight:600;
letter-spacing:0px;
line-height:50px;
text-decoration:none;
cursor:pointer;
background-color:rgb(0,0,0,1.0);
border-radius:25px;
position:relative;
}
header#header #cart-icon p:before {
margin-top:-2px;
content:"";
height:20px;
aspect-ratio:1 / 1;
display:inline-block;
background:url("../images/icon_cart.svg") center center no-repeat;
background-size:100% 100%;
position:absolute;
top:50%;
left:25px;
transform:translateY(-50%);
}
header#header #cart-icon p strong {
height:50px;
display:inline-block;
color:rgb(255,255,255,1.0);
font-family:"Roboto", sans-serif;
font-size:14px;
font-weight:600;
letter-spacing:0px;
line-height:50px;
text-decoration:none;
cursor:pointer;
}
header#header #cart-icon p span {
margin-left:5px;
width:16px;
height:16px;
display:inline-block;
color:rgb(0,0,0,1.0);
font-family:"Roboto", sans-serif;
font-size:12px;
font-weight:600;
letter-spacing:0px;
line-height:17px;
text-decoration:none;
cursor:pointer;
background-color:rgb(255,255,255,1.0);
border-radius:8px;
transform:translateY(-1px);
}

/*　xxxxxxx　*/
/* -----------------------------------------------*/
.sample {
width:90%;
width:-webkit-calc(100% - 160px);
width:calc(100% - 160px);
height:calc(var(--vh, 1vh) * 100);
font-family:"IBM Plex Sans JP", sans-serif;

white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;

box-sizing:border-box;
border-radius:25px;
border:rgb(72,149,37,0.3) solid 1px;
background-color:rgb(255,255,255,1.0);

user-select:none;
-webkit-user-select:none; /* Safari対応 */
-ms-user-select:none;     /* 古いIE対応 */
}
.loginset .input_set input[type="text"]:focus,
.loginset .input_set input[type="password"]:focus,
.loginset .input_set input[type="email"]:focus {
background-color:rgba(72,149,37,0.05);
}

/*　commonblock　*/
/* -----------------------------------------------*/
.commonblock {
width:300px;
height:calc(var(--vh, 1vh) * 100);
position:fixed;
top:0px;
left:0px;
}
.commonblock .logo {
width:100%;
height:300px;
position:relative;
}
.commonblock .logo p {
width:70%;
aspect-ratio:25 / 9;
display:inline-block;
text-indent:100%;
white-space:nowrap;
overflow:hidden;
background:url("../images/logo-by.svg") center center no-repeat;
background-size:100% 100%;
position:absolute;
top:50%;
left:50%;
transform:translate(-50%, -50%);
}
.commonblock .inner {
margin:10px 10px;
width:280px;
height:calc(100% - 320px);
overflow-y:auto;
text-align:center;
box-sizing:border-box;
background-color:rgb(0,0,0,0.05);
border-radius:10px;
}
.commonblock .block {
margin:25px auto 0px auto;
width:90%;
width:-webkit-calc(100% - 40px);
width:calc(100% - 40px);
}
.commonblock .block .block_title {
margin-bottom:10px;
width:100%;
color:rgb(0,0,0,0.7);
font-size:13px;
font-weight:500;
line-height:1.3;
text-align:left;
}
.commonblock .block .narrowdown {
width:100%;
display:flex;
flex-wrap:wrap;
gap:5px 5px;
}
.commonblock .block .narrowdown .color-option {
width:19.5px;
height:19.5px;
cursor:pointer;
}
.commonblock .block .narrowdown .color-option input[type="checkbox"] {
display:none;
}
.commonblock .block .narrowdown .circle {
width:19.5px;
height:19.5px;
border-radius:50%;
display:inline-block;
border:1px solid rgb(0,0,0,0.1);
box-sizing:border-box;
transition:border 0.2s;
}
/* 選択時の外枠 */
.commonblock .block .narrowdown .color-option input[type="checkbox"]:checked + .circle {
border:1px solid rgb(0,0,0,1.0);
}
/* 各カラー */
.circle.white     { background-color: #fff; border: 1px solid #ccc; }
.circle.black     { background-color: #000; }
.circle.red       { background-color: #e74c3c; }
.circle.blue      { background-color: #3498db; }
.circle.green     { background-color: #2ecc71; }
.circle.yellow    { background-color: #f1c40f; }
.circle.pink      { background-color: #ff69b4; }
.circle.orange    { background-color: #f39c12; }
.circle.purple    { background-color: #9b59b6; }
.circle.gray      { background-color: #95a5a6; }
.circle.navy      { background-color: #34495e; }
.circle.beige     { background-color: #f5f5dc; }
.circle.brown     { background-color: #8b4513; }
.circle.turquoise { background-color: #1abc9c; }
.circle.khaki     { background-color: #bdb76b; }

.commonblock .block .narrowdown .size-option {
width:56.25px;
height:20px;
cursor:pointer;
}
.commonblock .block .narrowdown .size-option input[type="checkbox"] {
display:none;
}
.commonblock .block .narrowdown .box {
width:56.25px;
height:20px;
color:rgb(0,0,0,0.3);
font-family:"Roboto", sans-serif;
font-weight:500;
letter-spacing:0px;
font-size:13px;
line-height:20px;
border-radius:3px;
display:inline-block;
border:1px solid rgb(0,0,0,0.2);
box-sizing:border-box;
transition:border 0.2s;
}
/* 選択時の外枠 */
.commonblock .block .narrowdown .size-option input[type="checkbox"]:checked + .box {
color:rgb(0,0,0,1.0);
border:1px solid rgb(0,0,0,1.0);
}

.commonblock .block .narrowdown .print-option {
width:56.25px;
height:56.25px;
cursor:pointer;
}
.commonblock .block .narrowdown .print-option input[type="checkbox"] {
display:none;
}
.commonblock .block .narrowdown .tshirt {
width:56.25px;
height:56.25px;
display:inline-block;
box-sizing:border-box;
background-position:center center;
background-repeat:no-repeat;
background-size:80% 80%;
background-color:rgb(255,255,255,0);
transition:background-color 0.2s;
border-radius:3px;
}
/* 選択時の外枠 */
.commonblock .block .narrowdown .print-option input[type="checkbox"]:checked + .tshirt {
background-color:rgb(255,255,255,1.0);
}
/* 各カラー */
.tshirt.fo     { background-image:url("../images/icon_fo.svg"); }
.tshirt.fs     { background-image:url("../images/icon_fs.svg"); }
.tshirt.fl     { background-image:url("../images/icon_fl.svg"); }
.tshirt.bo     { background-image:url("../images/icon_bo.svg"); }
.tshirt.bs     { background-image:url("../images/icon_bs.svg"); }
.tshirt.bl     { background-image:url("../images/icon_bl.svg"); }
.tshirt.sl     { background-image:url("../images/icon_sl.svg"); }

.commonblock .block .narrowdown .brand-option {
width:100%;
aspect-ratio:25 / 4;
cursor:pointer;
}
.commonblock .block .narrowdown .brand-option input[type="checkbox"] {
display:none;
}
.commonblock .block .narrowdown .brandlogo {
width:100%;
aspect-ratio:25 / 4;
display:block;
background-position:center center;
background-repeat:no-repeat;
background-size:100% 100%;
transition:opacity 0.2s;
opacity:0.2;
}
/* 選択時の外枠 */
.commonblock .block .narrowdown .brand-option input[type="checkbox"]:checked + .brandlogo {
opacity:1.0;
}
/* 各ブランド */
.brandlogo.blanvaskids    { background-image:url("../images/logo_blanvas_kids.svg"); }
.brandlogo.blanvasnft     { background-image:url("../images/logo_blanvas_nft.svg"); }

/*　common　*/
/* -----------------------------------------------*/
/*　photo　*/
.photo {
width:100%;
height:100%;
overflow:hidden;
position:relative;
}
.photo span {
width:100%;
height:100%;
display:block;
overflow:hidden;
position:relative;
}
.photo span img {
width:100%;
height:100%;
object-fit:cover;
transition:transform 0.3s ease;
transform-origin:center center; /* 初期値 */
}
/*　price　*/
.price {
font-family:"Roboto", sans-serif;
font-weight:600;
}
/*　uniq　*/
.uniq {
display:inline-block;
}
.uniq span {
margin-right:5px;
display:inline-block;
text-indent:100%;
white-space:nowrap;
overflow:hidden;
vertical-align:middle;
}
.uniq .cartin {
background:url("../images/icon_cart_.svg") center center no-repeat;
background-size:100% 100%;
}
.uniq .kids {
background:url("../images/icon_kids.svg") center center no-repeat;
background-size:100% 100%;
}
/*　size　*/
.uniq .size {
display:inline-block;
color:rgb(255,255,255,1.0);
font-family:"Roboto", sans-serif;
font-weight:600;
letter-spacing:0px;
text-align:center;
background-color:rgb(0,0,0,1.0);
border-radius:50%;
text-indent:0%;
}

/*　itemlist　*/
/* -----------------------------------------------*/
.itemlist {
margin-left:300px;
padding:10px 10px 10px 0px;
width:80vw;
width:-webkit-calc(100vw - 300px);
width:calc(100vw - 300px);
box-sizing:border-box;
}
.itemlist ul {
width:100%;
display:flex;
flex-wrap:wrap;
gap:10px 10px;
}
.itemlist ul li {
width:20%;
width:-webkit-calc((100% - 40px) / 5);
width:calc((100% - 40px) / 5);
aspect-ratio:1 / 1;
overflow:hidden;
background-color:rgb(0,0,0,0.05);
border-radius:10px;
cursor:pointer;
position:relative;
user-select:none;
-webkit-user-select:none; /* Safari対応 */
-ms-user-select:none;     /* 古いIE対応 */
}
.itemlist ul li .title {
display:none;
}
.itemlist ul li .shop {
display:none;
}
.itemlist ul li .category {
display:none;
}
.itemlist ul li .price {
display:inline-block;
color:rgb(0,0,0,1.0);
font-size:15px;
line-height:1.5;
letter-spacing:0px;
position:absolute;
bottom:7px;
right:10px;
z-index:2;
}
.itemlist ul li .uniq {
position:absolute;
bottom:7px;
left:10px;
z-index:2;
}
.itemlist ul li .uniq .size {
width:16px;
height:16px;
font-size:13px;
line-height:16px;
}
.itemlist ul li .uniq .cartin {
width:20px;
height:20px;
}
.itemlist ul li .uniq .kids {
width:19px;
height:19px;
}

/*　itemdetail　*/
/* -----------------------------------------------*/
.itemdetail {
display:none;
width:100vw;
height:calc(var(--vh, 1vh) * 100);
position:fixed;
inset:0; /* top, right, bottom, left すべて0 */
background:rgba(255, 255, 255, 0.6); /* 白の半透明 */
backdrop-filter:blur(10px);         /* 背景ぼかし */
-webkit-backdrop-filter:blur(10px); /* Safari対応 */
z-index:9999;
opacity:0;
transition:opacity 0.3s ease;
}
.itemdetail.active {
display:block;
opacity:1;
}
.itemdetail.showing {
animation:fadeZoomIn 0.4s ease forwards;
}
.itemdetail.hiding {
animation:fadeZoomOut 0.3s ease forwards;
}
.itemdetail .inner {
padding:100px 100px;
width:100%;
height:100%;
display:table;
box-sizing:border-box;
transform: scale(0.9);
opacity:0;
position:relative;
animation:contentZoomIn 0.4s ease forwards;
}
.itemdetail.hiding .inner {
animation:contentZoomOut 0.3s ease forwards;
}
.itemdetail .inner .itemdata {
display:table-cell;
text-align:center;
vertical-align:middle;
}
/* アニメーション定義 */
@keyframes fadeZoomIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes fadeZoomOut {
  from { opacity: 1; }
  to { opacity: 0; }
}
@keyframes contentZoomIn {
  from { transform: scale(0.9); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}
@keyframes contentZoomOut {
  from { transform: scale(1); opacity: 1; }
  to { transform: scale(0.8); opacity: 0; }
}

.itemdetail .block {
margin:0px auto;
width:100%;
max-width:600px;
text-align:left;
position:relative;
}
.itemdetail .itemphoto {
width:100%;
display:flex;
justify-content:center;
gap:0px 10px;
}
.itemdetail .itemphoto .photo {
width:50%;
width:-webkit-calc((100% - 10px) /2);
width:calc((100% - 10px) /2);
height:auto;
aspect-ratio:2 / 3;
border-radius:10px;
}
.itemdetail .price {
display:block;
color:rgb(0,0,0,1.0);
font-size:15px;
line-height:1.5;
letter-spacing:0px;
position:absolute;
top:15px;
right:20px;
z-index:2;
}
.itemdetail .uniq {
position:absolute;
top:15px;
left:20px;
z-index:2;
}
.itemdetail .uniq .size {
width:16px;
height:16px;
font-size:13px;
line-height:16px;
}
.itemdetail .uniq .cartin {
width:20px;
height:20px;
}
.itemdetail .uniq .kids {
width:16px;
height:16px;
}
.itemdetail .shopinfo {
margin-top:20px;
position:relative;
}
.itemdetail .category {
padding:3px 5px 1px 5px;
max-width:200px;
display:inline-block;
color:rgb(255,255,255,1.0);
font-size:12px;
font-weight:600;
line-height:1.3;
letter-spacing:0px;
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
box-sizing:border-box;
background-color:rgb(0,0,0,1.0);
border-radius:3px;
position:absolute;
top:0px;
right:0px;
}
.itemdetail .title {
color:rgb(0,0,0,1.0);
font-size:15px;
font-weight:700;
line-height:1.5;
letter-spacing:0px;
}
.itemdetail .shop {
color:rgb(0,0,0,0.7);
font-size:13px;
font-weight:700;
line-height:1.5;
letter-spacing:0px;
}
.itemdetail .introduction {
margin-top:10px;
color:rgb(0,0,0,1.0);
font-size:13px;
line-height:1.5;
letter-spacing:0px;
}

.itemdetail .cart {
display:inline-block;
position:absolute;
top:20px;
right:20px;
}
.itemdetail .cart p {
padding:0px 30px 0px 60px;
height:50px;
display:inline-block;
color:rgb(255,255,255,1.0);
font-family:"Roboto", sans-serif;
font-size:14px;
font-weight:600;
letter-spacing:0px;
line-height:50px;
text-decoration:none;
cursor:pointer;
background-color:rgb(0,0,0,1.0);
border-radius:25px;
position:relative;
}
.itemdetail .cart p:before {
margin-top:-2px;
content:"";
height:20px;
aspect-ratio:1 / 1;
display:inline-block;
background:url("../images/icon_cart.svg") center center no-repeat;
background-size:100% 100%;
position:absolute;
top:50%;
left:25px;
transform:translateY(-50%);
}

/*　footer　*/
/* -----------------------------------------------*/
#footer {
width:300px;
position:fixed;
bottom:20px;
left:0px;
}
#footer p {
color:rgb(0,0,0,0.3);
font-family:"Roboto", sans-serif;
font-size:9px;
font-weight:400;
text-align:center;
letter-spacing:1.2px;
}





.itemlist li {
  opacity: 0;
  transform: scale(0.96);
  filter: blur(8px); /* ← 追加: 初期はぼやけた状態 */
  transition:
    opacity 0.3s ease-out,
    transform 0.3s ease-out,
    filter 0.5s ease-out; /* ← 追加: フィルターにもアニメーション */
  will-change: opacity, transform, filter;
}

.itemlist li.show {
  opacity: 1;
  transform: scale(1);
  filter: blur(0); /* ← showでシャープに */
}







@media screen and (max-width:500px) {
}