@charset "UTF-8";

.txt_blue{ color: #000; }
h2.txt_blue{ font-size: 3.0rem; }
.tit__icon{ margin: auto; width: 60px; }
.tit__icon img{ width: 100%; }
.sticker__spmenu.pc{ bottom: 18%; }
.category_items img{ width: 100%; }
.layer_contents .btn_redborder.back a::before{
	border-width: 6px 7px 6px 0;
	border-color: transparent #fff transparent transparent;
}
.order_flow_img { max-width: 578px; margin: 0 auto 80px; }
.order_flow_img img { width: 100%; }
.order_flowbox { border: solid 10px #f2f2f2; padding: 2%; }
.order_flowbox .itemlist ul { display: flex; flex-wrap: wrap; }
.order_flowbox .itemlist li {
	width: 31.3%;
	margin: 1%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border: solid 1px #ccc;
	padding: 1%;
}
.order_flowbox .itemlist .image { width: 28%; margin-right: 2%; }
.order_flowbox .itemlist img { width: 100%; }
.order_flowbox .itemlist .text { width: 68%; }
.order_flowbox .itemlist .button {
	display: flex;
	justify-content: space-between;
	font-size: 82%;
	margin-top: 10px;
}
.order_flowbox .itemlist .button a{ color: inherit; }
.order_flowbox .itemlist .more {
	border: solid 1px #ccc;
	padding: 5px 10px;
	margin-right: 4%;
}
.order_flowbox .itemlist .delete { background: #ccc; padding: 5px 10px; }
.item__box .itemname{ margin-bottom: 20px; }
.item__box .itemcolor { font-size: 1.4rem; margin-bottom: 40px; }
.order_flowbox .item__box .main__nav__color ul{ display: flex; flex-wrap: wrap; }
.order_flowbox .item__box .main__nav__color ul li{ margin: 1%; width: 40px; }
.order_flowbox .item__box .main__nav__color label{ display: block; }
.radio { display: none; }
.main__nav__color ul li .radio + label div {
	border: 3.3px #ffffff solid;
    overflow: hidden;
	display: block;
}
.item__box{ flex-direction: row-reverse; }
.item__box .pho{ width: 30%; }
.item__box .pho .main{ width: auto; }
.item__box .pho .thumb-item .item__int::before{ background: none; }

.sizelist ul { display: flex; flex-wrap: wrap; }
.sizelist li {
	width: 12.6%;
	margin: 2%;
	text-align: center;
}
.sizelist .num { font-size: 120%; font-weight: bold; }
.sizelist .remaining { color: #ed6d0f; }
.sizelist input {
	border: solid 1px #ccc;
	border-radius: 4px;line-height: 2em;
    font-size: 16px;
	margin-top: 10px;
	text-align: right;
	width: 100%;
}
.phase04_item_singlewrap .sizelist p {
	padding-left: 2.4em;
}
.total_num {
	border-bottom: solid 1px #fff;
	font-size: 2.0rem;
	padding-right: 1em;
	text-align: right;
}
.total_num .num { font-size: 200%; }

.btn_width{ max-width: 500px; margin: auto; }

/* 合計金額 */
footer{ padding-bottom: 10%; }
.order_price {
	background: #f2f2f2;
	bottom: 0;
	font-size: 1.4rem;
	left: 0;
	padding: 2%;
	position: fixed;
	right: 0;
	text-align: center;
	width: 100%;
    z-index: 10;
}
.order_price .order_price01{ font-weight: bold; font-size: 1.6rem; }
.order_price .order_price01.order_price_grandtotal { font-weight: bold; font-size: 1.8rem; }
.order_price .order_price_layout { display: flex; justify-content:center; }
.order_price .order_price_layout .order_price_single { margin-left:2rem; }
.order_price .price { font-weight: bold; color: #ed6d0f; }

.order_price .breakdown .tit{ text-decoration: underline; color: #000; }
.order_price .breakdown .text { display: none; }
.choosebox_data {
    display: flex;
    align-items: flex-end;
}
.choosebox_size {
    display: flex;
    flex-wrap: wrap;
    font-size: 0.7em;
    margin-top:5px;
    justify-content: space-around;
    flex-basis: 70%;
}
.choosebox_size span {
    flex-basis: 48%;
    text-align:center;
}
.choosebox_size span.choosebox_size_head {
    border: solid 1px #ddd;
}

/* phase02 */
.frontprintbox ul { display: flex; flex-wrap: wrap; }
.frontprintbox li { width: 17%; margin: 1% 1.5%; }
.frontprintbox input[type=checkbox]:disabled + label { opacity: .4; }
.frontprintbox label {
	width: 100%;
	text-align: center;
	padding-top: 10px;
	font-size: 12px;
}
.frontprintbox .thumbnail__img { width: 100%; padding: 4%; }
.radio + label { border: 2px #ccc solid; }
.radio:checked + label { border: 2px #ffd900 solid; }
.muziprint {
	font-size: 1.6rem;
	margin: 20px 0;
	border: solid 2px #ccc;
	border-radius: 6px;
	background: #fffbe5;
	padding: 20px;
}
.muziprint input{ margin-right: 1em; }
.muziprint input[type="checkbox"]{ display: none; }
.muziprint input[type="checkbox"] + label {
	position: relative;
	padding-left: 45px;
	display: block;
}
.muziprint input[type="checkbox"] + label:before {
    position: absolute;
	content: "";
    display: inline-block;
    background-image:url("../img/list_check_off.gif");
    background-repeat: no-repeat;
    background-size:30px;
    width: 30px;
    height:30px;
	left: 0;
}
.muziprint input[type="checkbox"]:checked + label:before { background-image:url("../img/list_check.gif"); }
.colornumlistbox { display: flex; flex-wrap: wrap; }
.colornumlist { font-size: 1.3rem; width: 33%; margin-bottom: 20px;  }
.colornumlist span { position: relative; }
.colornumlist input[type="number"] {
	border: solid 1px #ccc;
	width: 3em;
	padding: 5px;
	margin: 0 30px;
	text-align: right;
}

.colornumlist input.spinner_up,
.colornumlist input.spinner_down{
	top: 0;
	bottom: 0;
	margin: auto;
	position: absolute;
    border: 0px;
    width: 20px;
    height: 16px;
	background: no-repeat 0 0 / 16px auto;
}
.colornumlist input.spinner_up{ background-image: url(../img/number_up.gif); right: 7px; }
.colornumlist input.spinner_down{ background-image: url(../img/number_down.gif); left: 0px; }


/* phase03 */
.phase03_item_tb_head {
    background: #505050;
    color: #fff;
    font-size: 1.4rem;
    text-align: center;
    padding: 20px;
    font-weight: bold;
    display: flex;
    justify-content: space-around;
    margin-bottom: 1px;
}
.phase03_item_detail {
    flex-basis: 25%;
}
.phase03_item_color {
    flex-basis: 75%;
}
.phase03_item_tb_body {
    display: flex;
    margin-bottom: 20px;
}
.phase04_item_singlewrap .phase03_item_tb_body {
    margin-bottom: 0px;
}
.phase03_item_tb_body .phase03_item_detail {
	background: #d2d2d2;
	border-bottom: solid 1px #fff;
    border-right: solid 1px #fff;
    padding: 20px;
    font-weight: bold;
    text-align: center;
}
.phase03_item_tb_body .phase03_item_color {
    display:flex;
    flex-wrap:wrap;
    background: #f2f2f2;
    font-size: 1.4rem;
}
.phase03_item_color .colorchoose_list {
	flex-basis: calc(100% / 3);
	border-bottom: solid 1px #fff;
    border-right: solid 1px #fff;
    padding: 20px;
}
.phase03_item_color .colorchoose_list select {
    border:none;
}
.order_flowbox.colorchoose .itemlist ul{ display: block; }
.order_flowbox.colorchoose .itemlist ul li{
	width: auto;
	border: none;
	padding: 0;
	margin: 0;
	text-align: left;
}
.order_flowbox.colorchoose .itemlist ul li .more{ border: solid 1px #666; }
.order_flowbox.colorchoose .itemlist ul li .delete{ background: #666; color: #fff; }
.order_flowbox.colorchoose .table01 tbody th{ width: 500px; }
.order_flowbox.colorchoose .table01 td{ vertical-align: top; text-align: left; }
.order_flowbox.colorchoose .itemlist ul li{ display: block; text-align: center; }
.order_flowbox.colorchoose .itemlist ul li .image{ width: 50%; margin: auto; }
.order_flowbox.colorchoose .itemlist ul li .text{ width: auto;}
.order_flowbox.colorchoose .itemlist ul li .more{ margin-right: 0; margin-bottom: 10px; }
.order_flowbox.colorchoose .itemlist ul li .text .button{ display: block; text-align: center; }

/* phase04 */
div #login_guide {
    margin: 0.5%;
    padding: 10px;
    text-align: center;
    background: #fff;
    border: solid 1px #ccc;
    font-size: 12px;
}
.phase04_item_totaltit {
    background: #eee;
    color: #000;
    padding: 25px 25px 15px;
    font-size: 20px;
    font-weight: bold;
    margin-top: 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
#wrap_cart .order_flowbox.cart{ border-color: #eee; }
.phase04_item_totalprice{ font-size: 16px; }
.phase04_item_singlewrap .subtitle02{ font-size: 16px; }
.phase04_item_singlewrap .subtitle02:first-child{ margin-top: 0; }
.save_d .save_d_thumbnail{ border: 6px #f2f2f2 solid; padding: 5px; }
.save_d input[type="checkbox"]:checked + .save_d_thumbnail{ border-color: #ed6d0f; }
.phase04_item_singlewrap .delete {
    background: #ccc;
    padding: 5px 10px;
    margin-top: 10px;
}
.phase04_item_singlewrap .delete:hover {
    opacity: .7;
}
.phase04_item_singlewrap .delete a {
    display: block;
    text-align: center;
    font-size: 1.3rem;
    color: #000;
}
.phase04_item_singlewrap .delete a:hover {
    text-decoration: none;
}
.calendar{ border-collapse:collapse; width:100%; margin-bottom: 20px; }
.calendar th,.calendar td{
    font-size: 14px;
    border: 1px solid #bbb;
    text-align: center;
    padding: 8px;
}
.calendar thead th{ background:#e90f32; color: #fff; }
.calendar thead th a{ color: #fff; pointer-events: none; }
.calendar tbody th:first-child{color:#f30;}
.calendar tbody th:last-child{color:#03c;}
.calendar td div{text-align:center}

.today{ background:#fffbcc; }
.saturday{ background:#f3f9fd; }
.sunday{ background:#fff5f2; }
.holiday{ background:#fff5f2; }

.calendar td a{text-decoration:underline;display:block;width:100%;}
.calendar td a:hover{background:#fe814d;color:#fff;text-decoration:none}
.calendar td a:active{background:#f30;}

.calender__block { display: flex; justify-content: space-between; }
.calender__block .calender__box { width: 45%; }
.calender__block .calender__box select{
    width: 100%;
    font-size: 1.4rem;
    height: 40px;
    padding-left: 10px;
}
.calender__block .delicery__date { width: 50%; }
.calender__block .delicery__date .display {
    border: solid 5px #f2f2f2;
    border-radius: 4px;
    padding: 30px;
    margin-bottom: 10px;
}
.calender__block .delicery__date .display .date{
    font-size: 2.4rem;
    color: #e90f32;
}
.calender__block .delicery__date .display .time{
    font-size: 1.6rem;
}
.order__item ul { display: flex; }
.order__item li { width: 31%; margin: 1%; }
.order__item input {
    display: block;
    margin: 10px auto;
    text-align: center;
}
.order__item label{ width: 100%; text-align: center; }
.order__item .img { width: 60%; margin: auto; }
.order__item img { width: 100%;}
.order__item .tit {
    color: #e90f32;
    margin-top: 10px;
    font-size: 1.6rem;
}
.order__item .price {
    font-weight: bold;
    margin-bottom: 10px;
    background: #f2f2f2;
    padding: 5px;
}
.order__item .attention { color: #666; }
.safet__form input[type="checkbox"] {
    margin-right: 10px;
    box-shadow: none;
    color: #f2f2f2;
    display: inline-block;
}
.safet__form{ font-size: 1.4rem; }

.discount.discount-num01 input[type="radio"]:checked + label { border: solid 5px #172c79; }
.discount.discount-num02 input[type="radio"]:checked + label { border: solid 5px #172c79; }
.discount input { display: none; }
.discount label {
    border: solid 2px #172c79;
    border-radius: 6px;
    padding: 20px;
    width: 100%;
}
.discount .tit {
    color: #172c79;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
}
.discount .tag {
    background: #e90f32;
    color: #fff;
    padding: 10px;
    font-size: 1.4rem;
    text-align: center;
    margin: 10px 0;
}
.discount p { font-size: 1.2rem; }
.discount__column{ display: flex; justify-content: space-between; }
.discount__column > div{ width: 48%; }
.discount__column > div .tit{ text-align: left; }
.discount__column > div p{ font-size: 1.4rem; }
.discount__column > div input{
    display: block;
    width: 100%;
    border: solid 1px #ccc;
    border-radius: 4px;
    height: 3em;
    font-size: 1.4rem;
    padding: 5px;
}
.plus{ max-width: 120px; margin: 30px auto; }
.plus img{ width: 100%; }

/* esimate */
.please__box .box{ display: block; }
.please__box .form__content{
    background: #f2f2f2;
    width: auto;
    margin: 10px 0;
}

.remarks_area{
    width: 100%;
    border: solid 1px #ccc;
    border-radius: 4px;
    height: 10em;
    font-size: 1.4rem;
}

.form__contents .form__content .name_box input{ width: 85%; margin-left: 5%; }
.form__contents .form__content .kana_box input{ width: 80%; margin-left: 5%; }


@media screen and (min-width: 768px) and (max-width: 1089px) {

.order_flowbox .itemlist li { width: 48%; }

.order_flowbox.colorchoose .itemlist ul li{ display: block; }
.order_flowbox.colorchoose .itemlist ul li .image{ width: 50%; margin: auto; }
.order_flowbox.colorchoose .itemlist ul li .text{ width: auto;}
.order_flowbox.colorchoose .itemlist ul li .text .button{ display: block; }
.order_flowbox.colorchoose .itemlist ul li .text .button .more{ margin-right: 0; margin-bottom: 10px; }
.colorchoose_list .box{ display: block; }

}
@media screen and (min-width: 0px) and (max-width: 767px) {
    h2.txt_blue{ font-size: 2rem; margin-bottom: 0 !important; }
	footer{ padding-bottom: 20%; }
	.sticker__spmenu{ display: none; }

	.order_flowbox{ padding: 4%; }
	.order_flowbox .itemlist ul { display: block; }
	.order_flowbox .itemlist li {
		width: auto;
		margin: 2% 1%;
		padding: 2%;
	}
	.order_flowbox .itemlist .button { justify-content: flex-end; font-size: 90%; }
    .order_flow_img { margin-bottom: 15px; }
    .order_flow_img img { margin: 0 auto; width: 80%; }
    .order_flow_img+.subtitle01 { display: none; }

	.item__box{ flex-direction: column-reverse; display: flex; }
	.item__box .pho{ width: 70%; margin: 30px auto; }

	.sizelist li { width: 29%; white-space: nowrap; }
	.total_num { text-align: right; font-size: 1.6rem; }
	.total_num .num { font-size: 160%; }


	/* phase02 */
	.frontprintbox li { width: 22%; margin: 1% 1.5%; }
	.colornumlist { width: auto; }
	.colornumlistbox{ display: block; }
    .muziprint {
        font-size: 1.3rem;
        padding: 10px;
    }
    .muziprint input[type="checkbox"] + label {
        padding-left: 30px;
    }
    .muziprint input[type="checkbox"] + label:before {
        background-size: 20px;
        height: 20px;
        margin-top: 0.2rem;
        width: 20px;
    }

	/* phase03 */
	.phase03_item_tb thead{ display: none; }

	.phase03_item_tb tbody tr{ display: block; }
	.phase03_item_tb tbody th{ display: block; width: auto; }
	.phase03_item_tb tbody td{ display: block; width: auto; }

	/*	.phase03_item_tb .sp_flex{ display: flex; justify-content:space-around; }*/
	.phase03_item_tb_head {display: none;}
	.phase03_item_tb_body, .phase03_item_tb_body .phase03_item_color {display: block;}
	.order_flowbox.colorchoose .itemlist ul li{ display: block; }
	.order_flowbox.colorchoose .itemlist ul li .image{ width: 50%; margin: auto; }
	.order_flowbox.colorchoose .itemlist ul li .text{ width: auto;}
	.colorchoose_list .item_input .tzSelect:nth-child(2){ display: none!important; }

	/* phase04 */
	.phase03_item_color .colorchoose_list {
		border-right: none;
	}
	.calender__block { display: block; }
	.calender__block .calender__box { width: auto; margin-bottom: 30px; }
	.calender__block .delicery__date { width: auto; }
	.calender__block .delicery__date .display { padding: 15px; font-size: 1.6rem; font-weight: bold; }

	.order__item ul { display: block; }
	.order__item li { width: auto; margin: 20px 0; }
	.discount label{ margin-bottom: 10px; }
	.colmn_under { margin-top: 0; }
	.discount__column{ display: block; }
	.discount__column > div{ width: auto; }
	.discount__column > div .tit{ text-align: center; }
	.plus{ max-width: 60px; }
	.form__contents .add_number.one_column{ display: block; }
	.form__contents .one_column .btn{ width: auto; margin-left: 0; }
	.form__contents .select_innar{ width: auto; }
	.phase04_item_totaltit{ display: block; }
}
