@charset "utf-8";
/* CSS Document */

/*
Theme Name: Webサイトリンク集
Theme URI:
Description:
Author: Little Beach
Version: 1.0
*/

@import url('https://fonts.googleapis.com/css2?family=Pacifico&family=Sawarabi+Gothic&display=swap')
	
body {
	line-height: 1.8;
	font-family: "Sawarabi Gothic", sans-serif;
}
.clearfix:after {
	content:" ";
	display:block;
	clear:both;
}
div::-webkit-scrollbar {
 width: 10px;
}
div::-webkit-scrollbar-track {
background: #fff;
border: none;
border-radius: 10px;
box-shadow: inset 0 0 2px #777;
}
div::-webkit-scrollbar-thumb {
 background: #aaa;
 border-radius: 10px;
 box-shadow: none;
}
/* header
-----------------------------------------------*/
#header h1 {
	float:left;
	padding:7px 0;
	font-size: 28px;
	font-family: "Pacifico", cursive;
	font-weight: 400;
	font-style: normal;
}
#header h1 a {
	color: #000;
	text-decoration: none;
}
#header h1 a:hover {
	color: #555;
	text-decoration: underline;
}
#header #headerbanner {
	float:right;
	width:500px;
}
#header {
	padding: 30px 0 0 90px;
}

/* content
-----------------------------------------------*/
#content {
	padding: 30px 0 0 90px;
	width: 90%;
}
#content a {
	text-decoration: none;
	color: #000;
}
.container {
	position: relative;
	overflow: hidden;
	margin-top: 20px;
}
.container ul {
  /* position: relative; */
  /* left: 50%; */
  float: left;
}
.container ul li {
  /* position: relative; */
  /* left: -50%; */
  list-style: none;
  float: left;
}
.box {
	/* height: 288px; */
	margin: 0;
	padding: 0;
	/* border:solid 1px #EEEEEE; */
	font-size: 11px;
	line-height: 1.4em;
}
.col {
	width: 24%;
	padding: 0 1%;
}
.disc { padding: 5px; }
.title {
	font-weight: bold;
	font-size: 120%;
	margin:10px 0;
	clear:both;
}
.term {
	padding-top:6px;
}
.term a {
	font-weight:normal;
}

.col figure img {
	width: 100%;
}


/* side-menu
-----------------------------------------------*/
#side-menu {
	position: fixed;
	top: 0;
	left:  -350px;
	width: 400px;
	height: 100%;
	padding: 0 0 80px 15px;
	background: #58c3e0;
	transition: all 400ms cubic-bezier(0.61, 0.92, 0.68, 1.14) 0s;
	box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.25);
}

#side-menu div.title {
    position: absolute;
    top: 50%;
    right: 20px;
    margin-top: -50px;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: upright;
	font-size: 17px;
    letter-spacing: -.2em;
}

#side-menu div.title div.menu {
  position: relative;
  height: 20px;
  width: 28px;
  display: inline-block;
  box-sizing: border-box;
}
#side-menu div.title div.menu span {
  position: absolute;
  left: 0;
  height: 2px;
  width: 28px;
  background-color: #444;
  border-radius: 2px;
  display: inline-block;
  box-sizing: border-box;
}
#side-menu div.title div.menu span:nth-of-type(1) {
  bottom: 20px;
}
#side-menu div.title div.menu span:nth-of-type(2) {
  bottom: 10px;
}
#side-menu div.title div.menu span:nth-of-type(3) {
  bottom: 0;
}


#side-menu.open nav {
	width: 100%;
	height: 100%;
	overflow-y: auto;
}
.nav-open {
	position: fixed;
}
.nav-open #header, .nav-open #content {
	-webkit-filter: blur(3px);
	filter: blur(3px);
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	-ms-transition: all .3s ease;
	-o-transition: all .3s ease;
	transition: all .3s ease;
}
#side-menu.open {
	left: 0;
}
#side-menu h2.cat-item {
	margin-bottom:20px;
	font-size:90%;
	font-family:lato;
	font-weight:900;
}
#side-menu ul {
	margin-bottom:40px;
	line-height: 1.8;
}
#side-menu ul li {
	white-space:nowrap;
	font-size:90%;
	letter-spacing:-0.05em;
	list-style:none;
}
#side-menu nav {
	padding: 30px 0 0 15px;
}
#side-menu nav a {
	-webkit-transition:all 100ms ease-in;
	-moz-transition:all 100ms ease-in;
	-o-transition:all 100ms ease-in;
	transition:all 100ms ease-in;
	text-decoration:none;
	color:#000;
}
#side-menu nav a:hover {
	padding: 2px;
	padding-left:.75em;
	background:#fff
}
