@charset "UTF-8";

body {
	margin: 0px;
	padding: 0px;
	font-family: serif;
	font-style: normal;
	line-height: 2;
	background-color: #000000;
	color: #bbbbbb;
}
.topbody {
	background-color: #c11f06;
	color: #110000;
}

a {
	color: #ffffff;
	font-weight: bold;
	text-decoration:none;
}
a:hover {
	color: #c11f06;
}
.topbody a {
	color: #000000;
}
.topbody a:hover {
	color: #ffffff;
}

.amatic {
	font-family: 'Amatic SC', serif;
}

img{
	border:none;
	vertical-align:top;
}

h1{
	margin: 10px 20px 10px 10px;
	float:left;
}

h2 {
	margin: 60px 0px 0px;
	padding: 0px;
	font: bold xx-large serif;
	letter-spacing: 0.05em;
}
h3 {
	margin: 40px 0px 20px;
	font: bold x-large serif;
	letter-spacing: 2px;
}

h4 {
	font: bold large serif;
	margin: 50px 0px 40px 0px;
	letter-spacing: 1px;
}

h5 {
	font: bold medium serif;
	margin: 18px 0px 8px 0px;
	letter-spacing: 1px;
}


pre {
	margin: 0px;
	white-space: -moz-pre-wrap; /* Mozilla */
	white-space: -pre-wrap;     /* Opera 4-6 */
	white-space: -o-pre-wrap;   /* Opera 7 */
	white-space: pre-wrap;      /* CSS3 */
	word-wrap: break-word;      /* IE 5.5+ */
}


ul,ol {
	margin: 20px 20px;
	padding: 0px;
}
li {
	margin:8px 0px;
}
th {
	padding: 2px 0px;
	width: 100px;
	vertical-align: top;
	font-weight: normal;
}
td {
	padding: 2px 0px 2px 10px;
	vertical-align: top;
}
summary {
	cursor:pointer;
}
.career {
	list-style-type:none;
	margin: 30px 0px 10px;
	font-size: 0.9em;
	line-height:1.5;
}
.midashi {
	margin: 40px 20px;
	font-weight:bold;
}

iframe {
	margin:10px 0px;
}

.line {
	margin: 30px 0px;
	border-bottom: 1px dotted #553333;
	height: 1px;
	width: 100%;
	clear:both;
}
.linenone {
	height: 10px;
	width: 100%;
	clear:both;
}
.linestrong {
	margin: 90px 0px 80px;
	border-bottom: 1px solid #553333;
	height: 1px;
	width: 100%;
	clear:both;
}
.lineblood {
	margin: 50px 0px 80px;
	border-bottom: 1px solid #c11f06;
	height: 1px;
	width: 100%;
	clear:both;
}
.linewhite {
	margin: 50px 0px 80px;
	border-bottom: 1px solid #f5eeee;
	height: 1px;
	width: 100%;
	clear:both;
}
.linered {
	margin: 50px 0px 60px;
	border-bottom: 8px double #c11f06;
	height: 1px;
	width: 100%;
	clear:both;
}
.topbody .linered {
	border-color: #f5eeee;
}

.sansserif {
	font-family:sans-serif;
}

.bold{
	font-weight:bold;
}
.nonbold{
	font-weight: normal;
}
.nonmargin{
	margin:0px;
	padding:0px;
}

.big {
	font-size: large;
	letter-spacing: 1px;
}
.xbig{
	font-size: x-large;
	letter-spacing: 1px;
}
.xxbig{
	font-size: xx-large;
}
.smalltxt {
	font-size: smaller;
}
.small {
	font-size: small;
}
.xsmall {
	font-size: x-small;
}
.xxsmall {
	font-size: xx-small;
}
.medium {
	font-size: medium;
}
.subtxt{
	margin-top: -10px;
	letter-spacing: 1px;
}
.white{
	color: #ffffff;
}
.bk{
	color:#000000;
}
.blood {
	color: #c11f06;
}
.gray {
	color: #908888;
}

.photocomment div {
	width:210px
}

.right {
	text-align:right;
	clear:both;
}
.copy {
	margin-top: 0px;
	text-align:right;
	font-size: x-small;
	color:#553333;
}


.centering {
	width: 100%;
	text-align: center;
}


.titlink {
	padding:20px 0px 0px 20px;
	font-size: 1.7em;
	letter-spacing: 0.05em;
	font-family: 'Amatic SC', serif;
}
.titlink ul {
	display:flex;
	justify-content: left;
}
.titlink li {
	list-style:none;
	margin: 0px 14px;
	line-height: 110%;
}
.titlink a:hover span {
	color: #c11f06;
}
.topbody .titlink a:hover span {
	color: #ffffff;
}

.footer {
	clear:both;
	width:100%;
	margin:80px 20px 10px;
	height: 100px;
	text-align:center;
}
.footer ul {
	display:flex;
	justify-content: center;
}
.footer li {
	list-style:none;
	margin: 0px 10px;
	letter-spacing: 2px;
}
.banner a {
	border-radius: 50px;
	background-color: #ffffff;
	color: #000000;
	font-weight: bold;
	padding:10px 16px;
	cursor:pointer;
}
.banner a:hover{
	background-color: #a00d04;
	text-decoration:none;
}


.menu {
	margin: 0px auto;
	padding:0px 10px;
	max-width: 800px;
	text-align:left;
}
.menu p {
	margin: 0px 20px;
}

.nowon {
	margin:40px auto;
	padding:0px 20px;
	text-align:left;
	max-width: 800px;
	clear:both;
}
.nowon img {
	max-width:100%;
	margin-bottom: 20px;
}
.nowon th {
	min-width: 80px;
}

.info {
	margin: 20px auto;
	padding: 0px 20px;
	max-width: 800px;
	text-align:left;
}
.info img {
	max-width: 380px;
	max-height: 300px;
	margin: 4px 3px;
}

.main {
	margin: 20px auto;
	padding: 0px 20px;
	max-width: 800px;
	text-align:left;
	clear:both;
}


.calendar {
	width:100%;
	max-width:800px;
	margin: 80px auto 20px;
	text-align:left;
	line-height: 1.5;
}
.month {
	height:30px;
	width:100%;
	margin-bottom: 30px;
	font-size: x-large;
	font-weight: bold;
}
.month div {
	width:33.3%;
	text-align:center;
	float:left;
}
.seven div {
	width:14.28%;
	padding:4px 0px;
	float:left;
	font-weight: bold;
}
.week {
	min-height:170px;
	clear:both;
}
.week div{
	width:14.28%;
	padding:2px 0px;
	text-align:left;
	float:left;
	font-weight:bold;
}
.week img {
	width:94%;
}
.week p {
	padding:0px 3px;
}


.photo-cafe {
	margin: 20px auto;
	padding: 0px 20px;
	max-width: 800px;
	text-align:center;
	clear:both;
}
.photo-cafe img {
	width:100%;
	max-width: 800px;
	margin: 4px 2px;
}
.photo img {
	max-height: 114px;
	margin: 4px 0px;
}




.open {
	padding:34px 10px 0px 10px;
	background:url('menu_open.gif') no-repeat;
	height:126px;
}

#top-g {
	clear:left;
	margin: 0px;
	padding: 0px;
	width: 560px;
	height: 112px;
}

.square {
	clear:left;
	margin: 0px;
	padding: 40px 60px 60px 60px;
	width: 440px;
}

.long {
	margin: 0px;
	padding: 120px 60px;
	width: 440px;
}

.longred {
	margin: 0px;
	padding: 74px 60px;
	width: 440px;
}


#whitegallery {
	background: #ffffff url('logo_gallery2.gif') left top no-repeat;
	color: #553333;
}


#red {
	background-color: #c12006;
	color: #330000;
}

#red a {
	color:#ffffff
	}
#red h2 a {
	color: #000000;
	text-decoration:none;
}
#red a:hover {
	color: #550000;
	text-decoration: underline;
}


#whitegallery h2 a {
	text-decoration:none;
}
#whitegallery a:hover {
	text-decoration: underline;
}


#yellow {
	background: #ffc200 url('logo_cafe.gif') left top no-repeat;
	color: #882222;
}

#yellow a {
	color: #0088bb;
	}
#yellow a:hover {
	color: #22aadd;
	}


#white {
	background: #ffffff url('logo_information.gif') left top no-repeat;
	color: #553333;
}


.galleryimg {
	margin: 10px 0px 0px;
	clear: left;
	text-align:center;
}
.galleryimg img {
	max-width:720px;
}


.cafethumbnail {
	margin: 0px 2px;
	width:106px;
	height:170px;
	float:left;
}
.cafethumbnail img {
	margin-bottom:2px;
}

.cafethumbnail a {
	color: #c12006;
}

.cafethumbnail a:hover {
	color: #0088bb;
	text-decoration:underline;
}


.map {
	float:left;
	margin: 10px 6px 10px 0px;
}


.profile {
	float:right;
	text-align:right;
	margin: 0px 0px 2px 10px;
}
.linkedimg img {
	width:200px
}
.linkedimg350 img {
	width:350px;
	margin-bottom:4px;
}


.eye {
	text-align:right;
	clear:both;
	margin:4px;
}

.wbr {
	word-break: keep-all;
}
.wbr span{
	display: inline-block;
}

.gallery {
	margin: 0px auto;
	padding:0px 20px;
	max-width: 800px;
}
.gallery > div{
	margin: 30px auto;
}
.gallery img {
	float:left;
}
.gallery h3 {
	clear:both;
	padding-top: 15px;
	font: bold large serif;
	word-break:keep-all;
}
.gallery cite {
	font: bold medium serif;
}
.price {
	margin: 10px auto;
	width: 300px;
	border-radius: 50px;
	background-color: #221111;
	color: #ffffff;
	padding:6px 0px;
	font: bold large sans-serif;
	clear:both;
	cursor:pointer;
}
.price:hover{
	background-color: #554444;
}

.linkbanner {
	margin: 40px auto;
}
.linkbanner a {
	border-radius: 50px;
	background-color: #c11f06;
	color: #ffffff;
	padding:10px 30px;
	font: bold large sans-serif;
	cursor:pointer;
}
.linkbanner a:hover{
	background-color: #554444;
	text-decoration:none;
}
.fetishism a {
	background-color: #ff1a5e;
	color: #2b3396;
	
}
.fetishism a:hover {
	background-color: #2b3396;
	color: #ff1a5e;
}


.gallery details {
	width: 100%;
	text-align:left;
}
.gallery summary {
	margin: 20px auto;
	width: 300px;
	border: 1px solid;
	border-radius: 25px ;
	padding:6px 0px;
	font:bold small sans-serif;
	text-align:center;
}
.spec {
	width: 380px;
	margin: 20px 20px 20px 0px;
	font-family: sans-serif;
	font-size: small;
	float:left;
	word-break:keep-all;
	vertical-align:top;
}
.spec caption {
	text-align:left;
	font-family: serif;
}
.spec th {
	width: 80px;
	vertical-align:top;
}


.artists{
	margin: 0px auto;
	max-width: 760px;
}
.artists p {
	position:relative;
	margin: 4px;
	height: 60px;
	width: 245px;
	line-height: 60px;
	float:left;
}
.artists img{
	margin: 5px 10px 5px 5px;
	width: 50px;
	height: 50px;
	border-radius: 25px;
	float:left;
}
.artists p a {
	position:absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	border-radius: 30px;
}
.artists p a:hover{
	opacity: 0.7;
	background-color: #cddeef;
	color: #110000;
	text-decoration:none;
}

.items figure {
	margin:0px 20px 20px 0px;
	float:left;
}
.items img {
	height: 250px;
	width: 250px;
}
.items div{
	float:left;
}
.items h3{
	margin:0px;
	padding:0px;
	font-size:x-large;
}
.switchimg {
	margin: 0px 20px 0px 0px;
	width:380px;
	float:left;
}
.switchimgl {
	margin: 0px 50px;
	width:700px;
}
.switchimg p {
	clear:both;
	margin:0px;
}
.switchimgl p {
	clear:both;
	margin:0px;
}
.switchimg img {
	max-width:380px;
	max-height:380px;
}
.switchthumb img {
	margin: 10px 10px 10px 0px;
	height:50px;
	width:50px;
	cursor:pointer;
}
.switchthumb img:hover {
	opacity:0.6;
}
.half {
	width:400px;
	float:left;
}
.pricetable {
	max-width:380px;
	margin: 10px 20px 20px 0px;
	font-family: sans-serif;
	font-size: small;
}
.pricetable th {
	vertical-align:top;
	font-weight:normal;
}
.pricetable td {
	text-align:right;
}

.infotable {
	margin: 10px 10px 20px 10px;
	border-collapse:collapse;
	width: 780px;
}
.infotable tr {
	border-top:1px dotted #332222;
	border-bottom:1px dotted #332222;
}
.infotable th {
	width:160px;
	vertical-align: middle;
	font-family: sans-serif;
}
.infotable td {
	padding: 10px;
	vertical-align: middle;
}


.event {
	display:flex;
	justify-content: left;
	width: 800px;
}
.event li {
	position:relative;
	width: 245px;
	height: 300px;
	background-color: #f5eeee;
	list-style:none;
	margin: 0px 6px;
	border-radius: 20px;
}
.event a {
	position:absolute;
	top: 0;
	left: 0;
	height: 120px;
	width: 90%;
	border-radius: 20px;
	padding: 180px 5% 0px;
	cursor:pointer;
	color: #000000;
	font-size: 1.3em;
	line-height: 1.3;
}
.event a:hover{
	opacity: 0.6;
	background-color: #c19999;
	text-decoration:none;
}
.event p{
	margin: 8px 0px;
}
.eventdate{
	margin: 0px 8px 0px 8px;
	font-size: 1.6em;
}
.event img{
	width: 100%;
	height: 180px;
	border-radius: 20px 20px 0px 0px;
	object-fit:cover;
}

.eventbanner {
	display:flex;
	justify-content: left;
	width: 800px;
}
.eventbanner li {
	position:relative;
	width: 245px;
	height: 245px;
	list-style:none;
	margin: 0px 6px;
	border-radius: 20px;
}
.eventbanner a {
	position:absolute;
	top: 0;
	left: 0;
	height: 120px;
	width: 90%;
	border-radius: 20px;
	padding: 125px 5% 0px;
	cursor:pointer;
	color: #000000;
	line-height: 1.3;
}
.eventbanner a:hover{
	opacity: 0.6;
	background-color: #c19999;
	text-decoration:none;
}
.eventbanner img{
	width: 100%;
	height: 245px;
	border-radius: 20px;
	object-fit:cover;
}



.statement {
	width: 90%;
	padding: 30px 5%;
	border-radius: 20px;
	background-color: #f5eeee;
	color: #000000;	
}


.shirasu a:hover{
	opacity: 0.8;
}