* {
    font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "メイリオ", sans-serif;
}

img {
    image-rendering: -webkit-optimize-contrast;
}

#main {
    max-width: 1500px;
    margin: auto;
    padding: 10px 0;
}

a {
    color: #000;
    text-decoration: none;
}

address {
    font-style: normal;
}

header .sub {
    display: flex;
    justify-content: space-between;
    margin-top: -.5em;
}

header address {
}

header .menu a {
    font-size: 1.5em;
    margin-left: 3em;
}

header .menu a.active,
footer .menu a.active {
    font-weight: bold;
}

header .menu {
    display: flex;
    align-items: center;
}

header .menu a.icon {
    font-size: 3em;
    margin-left: 1.5em;
}

footer {
    display: flex;
    justify-content: space-between;
}

footer .menu {
    display: flex;
}

footer .menu a {
    padding: 0 1em;
    border-right: 1px solid #000;
    border-left: 1px solid #000;
}

footer .menu a:first-child {
    padding-left: .5em;
    border: none;
}

footer .menu a:last-child {
    padding-right: .5em;
    border: none;
}

#content {
    margin: 0;
    margin-top: .15em;
    margin-bottom: .25em;
}

#content h2 {
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: normal;
    font-size: 2em;
    letter-spacing: .25em;
    /* margin-top: -.6em; */
    margin-bottom: 2em;
    white-space: nowrap;
}
#content h2:before, #content h2:after {
    border-top: 1px solid;
    content: "";
    width: 100%;
}
#content h2:before {
    margin-right: .5em;
}
#content h2:after {
    margin-left: .5em;
}

#content h3 {
    font-weight: normal;
    font-size: 2em;
    margin: 1em 0;
}

#content .two-column {
    display: flex;
    margin: 0 3em;
    margin-bottom: 5em;
}

#content .two-column div:first-child {
    padding: 0 7em;
}


/*
 *  index
 */
.index img {
    border: 1px solid #000 ;
    width: 100%;
}

.access > div {
    display: flex;
    height: 486px;
    margin-bottom: 5em;
}

.access .map {
    width: 70%;
}

.access .map iframe {
    width: 100%;
    height: 100%;
}

.access .address {
    background: #F3F3F3;
}

.access .address h4,
.access .address p{
    font-size: .9em;
    margin: 1em;
}

.gallery-list {
    width: 90%;
    margin: auto;
    margin-bottom: 5em;
}

.gallery-list .slick-slide {
    display: block;
    width: 16%;
    height: 205px;
    padding: 10px;
}

.gallery-list .slick-slide .img-box {
    position: relative;
}

.gallery-list .slick-slide img {
    width: 100%;
    height: 100%;
    position: relative;
    cursor: pointer;
}

.gallery-list .slick-slide .box {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height:100%;
    background: rgba(0, 0, 0, 0.25);
    text-align: center;
    padding-top:200px;
    cursor: pointer;
}

.gallery-list .slick-slide .active .box {
    background: rgba(0, 0, 0, 0);
}

.slick-slider {
    position: relative;
}

.slick-arrow {
    font-size: 0;
    position: absolute;
    top: 90px;
    cursor: pointer;
}

.slick-prev {
    border: 0;
    border-top: 20px solid transparent;
    border-right: 20px solid #8D8D8D;
    border-bottom: 20px solid transparent;
    background: none;
    left: -50px;
}

.slick-next {
    border: 0;
    border-top: 20px solid transparent;
    border-left: 20px solid #8D8D8D;
    border-bottom: 20px solid transparent;
    background: none;
    right: -50px;
}

.menu table{
    width: 80%;
    margin: auto;
    margin-bottom: 5em;
    font-size: 1.25em;
}

.menu table th,
.menu table td {
    padding: 1em 0;
}

.menu table th {
    font-weight: normal;
    text-align: left;
}

.menu h3 {
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: normal;
    font-size: 1.5em !important;
    margin-bottom: 2em;
    white-space: nowrap;
}
.menu h3:before, .menu h3:after {
    border-top: 1px solid;
    content: "";
    width: 100%;
}
.menu h3:before {
    margin-right: .5em;
}
.menu h3:after {
    margin-left: .5em;
}

.pribacy-poricy p {
    width: 90%;
    margin: auto;
    margin-bottom: 5em;
}

.sitemap p {
    text-align: center;
    font-size: 1.2em;
    margin-bottom: 5em;;
}

.shop .product-list {
    display: flex;
    flex-wrap : wrap;
    width: 90%;
    margin: auto;
    margin-bottom: 5em;
}

.shop .product-list .product {
    width: 20%;
    padding: 1em;
    display: block;
}

.shop .product-list .product img {
    width: 100%;
}

.shop .product-list .product dd {
    font-weight: bold;
}

.shop .paging {
    display: flex;
    justify-content: center;
    width: 90%;
    margin: auto;
    margin-bottom: 5em;
}

.shop .paging a{
    display: block;
    height: 2em;
    width: 2em;
    padding-top: .25em;
    text-align: center;
    border: 1px solid #000;
    margin: 0 .5em;
}

.shop .paging a.active{
    background: #000;
    color: #FFF;
}

#content.product h3 {
    margin-bottom: 0 !important;
}

#content.product .price{
    font-size: 2em;
    color: #DE5D50;
    padding-left: .5em;
}

#content.product .price small {
    font-size: .5em;;
}

select, input, textarea {
    padding: 6px 12px;
    color: #333;
    border: 1px solid #C4CCCE;
    border-radius: 3px !important;
    width: auto;
}

input[type=number] {
    text-align: right;
}

#content.product select,
#content.product .number {
    margin: .5em 0;
    width: 350px;
}

#content.product .number input{
    width: 100px;
}

button, .btn {
    font-size: 1em;
    padding: .75em 2em;
    font-weight: bold;
    color: #FFF;
    cursor: pointer;
    display: block;
    text-align: center;
}

.errormsg,
span.required,
.error {
    color: #DE5D50;
}

span.required {
    padding-left: .5em;
    font-size: 0.95em
}

.question-circle {
    display: none;
}

.zip-search,
#addr02 {
    margin-top: 1em;
}

#content.product button {
    width: 350px;
    margin: 1em 0 1.5em;
    background: #DE5D50;
    border: 1px solid #DE5D50;
}

#content.product button:hover {
    background: #D85145;
    border: 1px solid #D85145;
}

a:hover {
    opacity: 0.7;
}

table {
    border-collapse: collapse;
}

.cart .details table{
    width: 70%;
    margin: 0 auto;
}

.cart .details thead th {
    background: #333;
    color: #FFF;
    font-weight: normal;
    padding: .3em 0 .25em
}

.cart .details tbody tr {
    border-bottom: 1px dotted #000;
}

.cart .details tbody td:nth-child(1) {
    width: 10%;
    text-align: center;
}

.cart .details tbody td:nth-child(2) {
    width: 10%;
    padding: .75em 0 .5em;
}

.cart .details tbody td:nth-child(3) {
    width: 50%;
    padding: .85em 1em .5em;
}

.cart .details tbody td:nth-child(4) {
    text-align: center;
}

.cart .details tbody td:nth-child(5) {
    text-align: center;
}

.cart .details tbody img {
    width: 100%;
}

.cart .details tbody .number > div {
    display: flex;
    justify-content: center;
}

.cart .details tbody .title,
.cart .details tbody .price {
    font-weight: bold;
}

.cart .details tbody .number > div div i{
    font-size: .75em;
    margin: 0 .5em;
    border: 1px solid #000;
    padding: .55em;
    width: 2.25em;
    border-radius: 10em;
    display:block;
}

.cart .total-box {
    display: flex;
    justify-content: flex-end;
    width: 70%;
    margin: 0 auto;
    margin-top: 2em;
    margin-bottom: 5em;
}

.cart .total-box dl {
    display: flex;
    justify-content: flex-end;
}

.cart .total-box dt {
    vertical-align: bottom;
    padding-top: .8em;
}

.cart .total-box dd {
    color: #DE5D50;
    font-size: 1.75em;
    font-weight: bold;
}

.cart .total-box a {
    width: 200px;
}

.cart .total-box a:nth-child(2) {
    background: #DE5D50;
    border: 1px solid #DE5D50;
    margin: 1em 0 1em;
}

.cart .total-box a:nth-child(3) {
    background: #474757;
    border: 1px solid #474757;
    margin: 1em 0 1.5em;
}

#content.address table{
    width: 60%;
    margin: 0 auto;
    border-top: 1px dotted #000;
}

#content.address table th small {
    margin-left: 1em;
}

#content.address table th,
#content.address table td {
    border-bottom: 1px dotted #000;
    padding: 1em 1em;
}

#content.address table th {
    font-weight: normal;
    text-align: left;
    width: 250px;
    vertical-align: top;
    padding-top: 1.5em;
}

#content.address table .name input:first-child,
#content.address table .kana input:first-child {
    margin-right: .75em;
}

#content.address table .name input,
#content.address table .kana input,
#content.address table .company input {
    width: 45%;
}

#content.address table .jusho .post {
    margin-bottom: 1em;
}

#content.address table .jusho .post input {
    width: 4em;
    margin-right: .5em;
}

#content.address table .jusho .post input:nth-child(2) {
    margin-left: .5em;
}

#content.address table .jusho button {
    color: #000;
    font-weight: normal;
    padding: .5em .25em;
    margin-bottom: 1em;
    width: 175px;
}

#content.address table .jusho select {
    display: block;
    color: #000;
    font-weight: normal;
    padding: .5em .25em;
    margin-bottom: 1em;
    width: 175px;
}

#content.address table .jusho td > input[type="text"] {
    display: block;
    color: #000;
    font-weight: normal;
    padding: .5em 12px;
    margin-bottom: 1em;
    width: 90%;
}

#content.address table .tel input {
    width: 6em;
    margin-right: .35em;
}

#content.address table .email input {
    display: block;
    width: 90%;
}

#content.address table .email input:first-child {
    margin-bottom: 1em;
}

#content.address .btn-box{
    width: 300px;
    margin: 0 auto;
    margin-bottom: 5em;
    margin-top: 3em;
}

#content.address .btn-box .btn,
#content.address .btn-box a{
    display: block;
    width: 100%;
    margin: 1em 0 1.5em;
    background: #DE5D50;
    border: 1px solid #DE5D50;
}

#content.address .btn-box a:last-child {
    background: #474757;
    border: 1px solid #474757;
    margin: 1em 0 1.5em;
}

#content.shopping .cart .product {
    display: flex;
    padding: 1em 1em;
    border-bottom: 1px dotted #000;
}

#content.shopping .cart .product:first-child {
    border-top: 1px dotted #000;
}

#content.shopping .cart .product img {
    width: 100px;
    margin-right: 1em;
}

#content.shopping .cart > a {
    color: #000;
    font-weight: normal;
    padding: .5em .25em;
    margin-bottom: 2em;
    width: 230px;
    background: #EEE;
    border: 1px solid #DDD;
    margin-top: 1em;
}

#content.shopping h4 {
    font-size: 1.25em;
    font-weight: normal;
    padding: .25em .25em;
    border-bottom: 1px solid #000;
    margin-bottom: 1em;
}

#content.shopping .customer,
#content.shopping .address,
#content.shopping .pay{
    position: relative;
    margin-bottom: 2em;
}

#content.shopping .customer .btn,
#content.shopping .address .btn {
    position: absolute;
    color: #000;
    font-weight: normal;
    padding: .5em .25em;
    background: #EEE;
    border: 1px solid #DDD;
    right: 0;
    top:50px;
}

#content.shopping .customer .btn:disabled {
    display: none;
}

#content.shopping .customer #customer-ok .btn,
#content.shopping .customer #customer-cancel .btn {
    width: 100px
}

#content.shopping .customer #customer-cancel .btn {
    top:100px;
}

#content.shopping .address > div {
    margin: 1em 0;
}

#content.shopping .address > div select {
    margin-right: 1em;
}

#content.shopping .pay dd {
    margin: .5em 0;;
}

#content.shopping textarea {
    width: 100%;
    height: 6em;
}

#content.shopping .price-block .price {
    border: 1px solid #000;
    padding: 1em 1em;
}

#content.shopping .price-block table {
    width: 100%;
    margin-bottom: 1em;;
}

#content.shopping .price-block table th {
    text-align: left;
    font-weight: normal;
}

#content.shopping .price-block table td {
    text-align: right;
    font-weight: normal;
    padding: .25em 0;
}

#content.shopping .price-block .total {
    border-top: 1px dotted #000;
    padding-top: 1em;
    color: #DE5D50;
    font-size: 2em;
    text-align: right;
}

#content.shopping .price-block .total small {
    font-size: .5em;
}

#content.shopping .price-block .total small:first-child {
    color: #000;
}

#content.shopping .price-block .total small:last-child {
    margin-left: .5em;
}

#content.shopping .price-block .btn {
    background: #DE5D50;
    border: 1px solid #DE5D50;
    margin-top: .5em;
    width: 100%;
}

#content.shopping .body-block {
    position: relative;
    margin-bottom: 5em;
}

#content.shopping .detail-block {
    width: 70%;
}

#content.shopping .price-block {
    position: absolute;
    right: 0;
    top: 0;
    width: 25%;
}

#content.complete h4 {
    text-align: center;
    font-size: 2em;
    margin-top: 0;
}

#content.complete p {
    text-align: center;
    width: 60%;
    margin: 0 auto;
    margin-top: 2em;
}

#content.complete a {
    background: #474757;
    border: 1px solid #474757;
    width: 200px;
    margin: 0 auto;
    margin-bottom: 5em;
}

#content.profile .movie {
    margin: 0 10em;
    align-items: flex-end;
}

#content.profile .name {
    margin: 0 10em;
    align-items: flex-end;
}

#content.profile .name img {
    margin-right: 5em;
}

#content.profile .name p {
    font-size: 1.5em;
}

#content.profile .discription {
    display: flex;
    margin: 0 10em;
    align-items: flex-start;
    margin-top: 5em;
    margin-bottom: 5em;
}

#content.menu h2{
    margin-bottom: .5em;
}

#content.menu .menu-block {
    display: flex;
    margin: 0 0em;
}

#content.menu .menu-block > div {
    width: 33%;
    padding: 0 2.25em;
}

#content.menu .menu-block > div:nth-child(2) {
    border-right: 1px solid #000 ;
    border-left: 1px solid #000 ;
}

#content.menu h4{
    margin-top: 1.5em;
    margin-bottom: .5em;
}

#content.menu .menu-block dl{
    display: flex;
}

#content.menu dt {
    position: relative;
    width:350px;
    /* padding-right:175px; */
}

#content.menu dt::after{
    content: " ";
    border-bottom: 1px dotted #000;
    width: 140px;
    height: .75em;
    display: block;
    position: absolute;
    top: 0;
    left: 180px;
}

#content.menu .short dt {
    padding-right: 112px;
}

#content.menu .short dt::after {
    left: 240px;
    width: 80px;
}

.sp {
    display: none;
}

.sp-inline {
    display: none;
}

.pc {
    display: block;
}

.pc-inline {
    display: inline;
}

.leagal-infomation .table {
    width: 60%;
    margin: 0 auto;
    margin-bottom: 5em;
}

.leagal-infomation table {
    width: 100%;
}

.leagal-infomation table tr{
    border-bottom: 1px dotted #AAA;
}

.leagal-infomation table th,
.leagal-infomation table td {
    padding: 1em 2em;
}

.leagal-infomation table th {
    width: 300px;
    text-align: left;
    color: #333
}

@media (max-width: 1498px) {
	#content.menu dt {
		width: 300px
	}
	#content.menu dt::after {
		width: 90px
	}
	#content.menu .short dt::after {
		left: 200px
	}
	#content.profile .name,
	#content.profile .discription {
		margin-left: 5em;
		margin-right: 5em;
	}
}

@media (max-width: 1345px) {
	#content.menu dt {
		width: 250px
	}
	#content.menu dt::after {
		width: 40px
	}
	#content.menu .short dt::after {
		left: 150px
	}
}

@media (max-width: 1435px) {
	header .menu a {
		margin-left: 2em;
	}
}

@media (max-width: 1196px) {
	header .sub {
		display:block;
	}
	#content.menu dt {
		width: 240px
	}
	#content.menu dt::after {
		width: 40px
	}
	#content.menu dt::after {
		display:none;
		left: 150px
	}
	#content.profile .name,
	#content.profile .discription {
		margin-left: 2em;
		margin-right: 2em;
	}
}

@media (max-width: 1317px) {
	header .menu a {
		margin-left: 1em;
	}
}

@media (min-width: 767px) {
	

    h1 img {
        width: 30%;
    }
    
    #content.gallery h2 {
    	margin-bottom:1.5em
    }
    
    #content.menu h3 {
    margin: .35em 0 .1em
    }
    
    #content.gallery .two-column,
    #content.gallery .gallery-list,
    .gallery-list {
    	margin-bottom:1.25em
    }
    
     #content.menu .gallery-list .slick-slide img {
     cursor:auto
     }
}

@media (max-width: 767px) {

#content.profile .movie {
margin:0;
}
    .sp {
        display: block;
    }
    
    .sp-inline {
        display: inline;
    }

    .pc {
        display: none !important;
    }
    
    .pc-inline {
        display: none !important;
    }

    #main {
        width: 100%;
        padding-top: 0;
    }

    #main header {
        margin: 0;
        position: relative;
    }

    #main header {
        display: flex;
        width: 100%;
        align-items: flex-end;
        margin-bottom: 1em;
    }

    #main header h1 {
        width: 50%;
        padding-right: 10px;
    }

    #main header h1 a{
        display: flex;
    }

    #main header h1 img{
        width: 100%;
    }

    #main header .menu {
        display: none;
    }

    #main header .sub {
        display: block;
        width: 40%;
    }

    #main header address {
        font-size: .25em;
    }

    #main header .sp-menu {
        width: 10%;
        background: #000;
        color: #FFF;
        padding: 10px 0;
        text-align: center;
    }

    .sp-menu-list {
        position: absolute;
        right: 0;
        top: 0;
        background: #000;
        width: 30%;
        display: none;
        z-index:999;
    }

    .sp-menu-list .menu-btn a {
        font-size: 1em;
        padding-top: 10px;
        padding-right: 12px;
    }

    .sp-menu-list > div {
        text-align: right;
    }

    .sp-menu-list a {
        display: block;
        color: #FFF;
        font-size: .75em;
        padding: 1em .5em 1em 0em;
    }

    .sp-menu-list .sub-menu {
        margin-top: 4em;
    }

    .sp-menu-list .sub-menu a {
        font-size: .5em;
        padding: 2em .5em 2em 0em;
    }

    .sp-menu-list  .icon {
        margin-top: .5em;
    }

    .sp-menu-list .icon a {
        display: inline;
        font-size: 1.5em;
    }

    footer .copylight {
        font-size: .75em;
        margin-left: 1em;
    }

    #content.index img {
        border: none;
    }

    #content.access > div {
        display: block;
        height: auto;
        margin-bottom: .5em;
    }

    #content h2 {
        margin-bottom: .5em;
        font-size: 1em;
    }


    #content.access .map,
    #content.access .map iframe{
        width: 100%;
    }

    #content.access .map {
        height: 500px;
    }

    #content.access .address {
        background: none;
    }

    #content.legal-infomation p,
    #content.pribacy-poricy p {
        margin: 0;
        margin-bottom: .5em;
        padding: 0 1em;
        width: 100%;
    }

    #content.profile .name{
        margin: 0;
        padding: 0 1em 0 0;
        margin-bottom: 3em;
    }

    #content.profile .name img{
        width: 50%;
        margin: 0;
        margin-right: .5em;
    }

    #content.profile .name h3 {
        font-size: 1.5em;
        margin-bottom: .25em;
    }

    #content.profile .name p {
        font-size: .75em;
    }

    #content.profile .discription {
        display: block;
        margin: 0;
        padding: 0 1em;
    }

    #content.profile .discription div {
        text-align: right;
    }

    #content.profile .discription img{
        width: 50%;
    }

    #content .two-column {
        display: block;
        margin: 0;
        padding: 0 1em;
        margin-bottom: 3em;
    }

    #content .two-column h3 {
        margin: .5em 0;
    }

    #content .two-column div:first-child {
        padding: 0;
    }

    #content .two-column img{
        width: 100%;
    }

    .sp-gallery-list {
        padding: 0 1em;
        display: flex;
        flex-wrap: wrap;
        margin-bottom: 5em;
    }

    .sp-gallery-list > div {
        width: 33%;
        padding: 1%;
    }

    .sp-gallery-list img {
        width: 100%;
    }

    #content.menu .menu-block {
        display: block;
    }

    #content.menu .menu-block > div {
        width: 100%;
        padding: 0 1em;
    }
    
    #content.menu dt {
        width: 180px;
    }
    
    #content.menu dt::after,
    #content.menu .short dt::after {
    	left: 190px;
    	width: 100px;
    }
    
    #content.menu .short dt{
    	padding-right: 0;
    }
    
    #content.menu .menu-block > div:nth-child(2) {
    	border:0
    }
    
    #content.menu dd {
    	position: absolute;
    	right: 1em;
    	text-align:right;
    }

    .sitemap p {
        margin-top: 3em;
    }

    .shop .product-list {
        display: block;
        margin: 0;
        width: 100%;
        font-size: 1.5em;
    }

    .shop .product-list .product {
        width: 100%;
    }

    #content.product select, #content.product .number, #content.product button {
        width: 100%;
    }

    .cart .details thead th {
        display: none;
    }

    .cart .details {
        margin-top: 1em;
        padding: 0 1em;
    }

    .cart .details  table{
        width: 100%;
        margin: 0;
    }

    .cart .details tbody tr:first-child td {
        border-top: 1px dotted #000;
    }

    .cart .details tbody tr td:last-child {
        display: none;
    }

    .cart .details tbody td:nth-child(2) {
        width: 100px;
    }

    .cart .total-box {
        margin-left: 0;
        margin-right: 0;
        display: block;
        padding: 0 1em;
        text-align: right;
        width: 100%;
    }

    .cart .total-box dl {
        justify-items: right;
    }

    .cart .total-box a {
        width: 100%;
    }

    #content.shopping .detail-block {
        width: 100%;
        padding: 0 1em;
    }

    #content.shopping .price-block {
        position: relative;
        padding: 0 1em;
        width: 100%;
        margin-top: 2em;
    }

    #content.shopping .body-block {
        width: 100%;
    }

    #content.shopping .customer .btn, #content.shopping .address .btn {
        padding: .3em .25em;
    }

    #content.complete h4 {
        padding: 0 1em;
    }

    #content.complete p {
         width: 100%;
         padding: 0 1em;
    }

    .leagal-infomation .table {
        width: 100%;
        padding: 0 1em;
    }

    .leagal-infomation .table th,
    .leagal-infomation .table td {
        padding: 1em .5em;
    }

    .leagal-infomation .table th {
        width: 40%;;
    }

    #content.address {
        padding: 0 1em;
    }

    #content.address table {
        width: 100%;
    }
	#content.menu dt::after {
		display:block;
		width: 50%
	}
	
	#main header {
		position:fixed;
		background: #FFF;
		z-index:998;
		top:0;
		left:0;
		padding-bottom: 12px;
	}
	
	#main {
		padding-top: 57px;
	}
}