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


/* 
html5doctor.com Reset Stylesheet v1.6.1
Last Updated: 2010-09-17
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
body {
    line-height:1;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}
nav ul {
    list-style:none;
}
blockquote, q {
    quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}
a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}
/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000; 
    font-style:italic;
    font-weight:bold;
}
del {
    text-decoration: line-through;
}
abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}
table {
    border-collapse:collapse;
    border-spacing:0;
}
/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}
input, select {
    vertical-align:middle;
}


/*-------------------------------------------

  Link
  
------------------------------------------ */

a{/*リンクされた文字*/
    color:#444444;
	text-decoration:none;
}
a:link {/*未訪問のリンク*/
}
a:visited {/*訪問後のリンク*/
}
a:hover {/*マウスをのせたとき*/
}
a:active {/*クリック中*/
}



/*-------------------------------------------

  Main
  
------------------------------------------ */

body {
	background-image:url(../images/back.gif);
    color:#222222;
}

.clear {
	clear:both;
}

#wrap {
	width:1004px;
	margin: 0 auto;
}

.PageTop {
	text-align:right;
	margin:60px 0 0 0;
}

.PageTop a {
	padding:0 0 0 18px;
	background-image:url(../images/btn_PageTop_arw.png);
	background-repeat:no-repeat;
	background-position:left center;
	font-size:23px;
	font-family:Georgia, "Times New Roman", Times, serif;
	font-style:italic;
}

.PageTop a:hover {
	opacity: 0.50;
	-moz-opacity: 0.50;
	filter: alpha(opacity=50);
}


/*-------------------------------------------

  Header
  
------------------------------------------ */

#top {
	width:924px;
	margin:24px 40px 0px 40px;
	position:relative;
}

#top h1 {
	display:block;
	height:66px;
	width:66px;
	text-align:center;
	margin:0 429px 0 370px;
	padding: 70px 0 0 0;
}

#top h1:hover {
	opacity: 0.50;
	-moz-opacity: 0.50;
	filter: alpha(opacity=50);
}


#top .link {
	float:right;
	margin-top:24px;
}

.link ul {
	list-style: none;
	padding: 0px;
	margin: 0px;
}

.link li {
	float:left;
	background-image:url(../images/btn_arw.png);
	background-repeat:no-repeat;
	background-position:left center;
	line-height: 16px;
	padding:0 0 0 18px;
	margin-left:26px;
}

.link a {
	font-size:21px;
/*	font-style:italic;
*/
	font-family:Consolas, Georgia, "Times New Roman", Times, serif;
	text-decoration:none;
	color:#000000;
	letter-spacing: 1px;
}

.link li:hover {
	opacity: 0.50;
	-moz-opacity: 0.50;
	filter: alpha(opacity=50);
}

/*-------------------------------------------

  Menu
  
------------------------------------------ */

#menu {
	width:42px;
	height:42px;
	margin-top:12px;
	float:left;
}

#menu a {
	display:block;
	width:42px;
	height:42px;
}
#menu a:hover {
	opacity: 0;
	-moz-opacity: 0;
	filter: alpha(opacity=0);
}
#menu:hover {
	background-image:url(../images/btn_menu_h.png);
}

#popup-menu {
	display:none;
	position: absolute;
	top: 74px;
	left: -25px;
	width: 392px;
	padding: 20px 0 10px 0;
	background-color: #ffffff;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	-o-border-radius: 4px;
	-ms-border-radius: 4px;
	border-radius: 4px;
	box-shadow: 0px 1px 6px rgba(0, 0, 0, 0.25);
	-moz-box-shadow: 0px 1px 6px rgba(0, 0, 0, 0.25);
	-webkit-box-shadow: 0px 1px 6px rgba(0, 0, 0, 0.25);
	color: #535353;
	letter-spacing: 1px;
}

div.popup-menu_arrow {
	width:392px;
	height:20px;
	margin:-40px 0 0 0px;
	background-image:url(../images/menu/menu_arw.png);
}

#instagram {
	height:160px;
	position:relative;
}

.insta {
	width:352px;
	position:relative;
	height:120px;
	margin: 0;
	padding:20px;
}
.insta:hover {
	background-color:#F1F1F1;
}

.insta_thumb {
	position:rerative;
	width:120px;
	height:120px;
/*	opacity:0;
*/}

.insta_txt {
/*	opacity:0;
*/	width:218px;
	padding-left:14px;
	position:absolute;
	bottom:22px;
	left:140px;
}

.loading {
	clear:both;
	position: absolute;
	background-image:url(../images/loader.gif);
	width:16px;
	height:16px;
	margin-top: -8px;
	margin-left: -8px;
	top:50%;
	left:50%;
}

.insta_photo {
	width:120px;
	height:120px;
}
.insta_created_time {
	margin-left:10px;
}

.insta dt {
	font-size:10px;
	font-family:Georgia, "Times New Roman", Times, serif;
	font-style:italic;
	margin-top:10px;
}

.insta dd {
	font-size:12px;
	margin-top:14px;
}

.insta p {
	display:inline;
	font-family:Georgia, "Times New Roman", Times, serif;
}

.insta p.title {
	font-size:16px;
	line-height:16px;
}

.insta p.sub {
	font-size:10px;
	font-style:italic;
	line-height:18px;
	margin-left:8px;
}

.insta p.sub a {
	color::#535353;
	font-style:italic;
}

#popup-menu .menu_list {
	overflow: hidden ;  
	padding: 0;
}

.menu_list ul {
	list-style: none;
}

.menu_list li {
	overflow: hidden ;  
	clear:both;
	display:block;
	padding:10px 0 10px 20px;	
}

.menu_list li:hover {
	background-color:#F1F1F1;
}

.menu_list .list_img {
	float:left;
	width:63px;
	height:42px;
}

.menu_list .list_txt {
	float:left;
	width:269px;
	margin-left:20px;
	font-family:Georgia, "Times New Roman", Times, serif;
}

.list_txt dt {
	font-size:22px;
}

.list_txt dd {
	margin-top:4px;
	font-size:10px;
	font-style:italic;
	line-height:11px;
}

/*-------------------------------------------
.list_current {
	background-color:#F1F1F1;
}
------------------------------------------ */

/*-------------------------------------------

  Body
  
------------------------------------------ */

#container {
	margin:20px 32px 0 32px;
}

#contents-list dl {
	padding:20px 0 40px 0;
	font-family:"メイリオ", "Meiryo", Consolas, Georgia, "Times New Roman", Times, serif;
}

#contents-list dt {
	font-size:33px;
	/*font-style:italic;*/
	padding-top: 54px;
	padding-bottom:14px;
	letter-spacing: 1px;
}

#contents-list dd {
	font-size:20px;
	font-style:italic;
	padding-top:12px;
	letter-spacing: 1px;
}

#contents-list img {
	padding:8px;
	background-color:#FFFFFF;
    box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
    -moz-box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
    -webkit-box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
}

#Entry-list img {
	padding:8px;
	background-color:#FFFFFF;
    box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
    -moz-box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
    -webkit-box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
	margin:0 0 35px 0;
}

.imgframe {
	padding:8px;
	background-color:#FFFFFF;
    box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
    -moz-box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
    -webkit-box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
	margin:0 0 35px 0;
}

.imgframe iframe {
	vertical-align:text-bottom;
}

dl.Entry-title {
	font-family:Georgia, "Times New Roman", Times, serif;
	text-align:center;
	padding-top:20px;
}

dl.Entry-title img {
	vertical-align:bottom;
}

dl.Entry-title dt {
	font-size:16px;
	font-style:italic;
	letter-spacing: 1px;
}

dl.Entry-title dd {
	font-size:12px;
	letter-spacing: 1px;
	line-height:20px;
	padding:14px 0 30px 0;
}

dl.Entry-title dd a:hover {
	opacity: 0.50;
	-moz-opacity: 0.50;
	filter: alpha(opacity=50);
}

.about_txt {
	font-size:20px;
	line-height:32px;
	margin-top:30px;
	text-align:center;
}
.about_txt p {
	display:inline;
	font-family:Georgia, "Times New Roman", Times, serif;
}


#footer {
	margin-top:64px;
	text-align:center;
}

#footer p {
	margin:56px 0 30px 0;
	font-size:50px;
	font-family:Georgia, "Times New Roman", Times, serif;
}

/*-------------------------------------------

 Other
  
------------------------------------------ */

#other {
	font-family:Georgia, "Times New Roman", Times, serif;
	border-top:1px solid #e4e4e4;
	border-bottom:1px solid #e4e4e4;
	text-decoration:none;
	margin-top:20px;
}

.other_title h3, .making_title h3 {
	font-size:32px;
	font-style:italic;
	font-weight:normal;
	line-height:30px;
	letter-spacing: 1px;
	text-decoration:none;
	display:inline;
}

.other_title, .making_title {
	padding:16px 0 16px 0px;
	height:32px;
	width:924px;
	cursor:pointer;
}

.other_title:hover, .making_title:hover {
	opacity: 0.50;
	-moz-opacity: 0.50;
	filter: alpha(opacity=50);
}

.other_title_arw, .making_title_arw {
	margin:3px 10px 3px 0;
	vertical-align:top;
}

.other_contents {
	margin-top:0px;
}

.other_list_img {
	width:150px;
	height:150px;
}

.other_list_img img {
	padding:4px;
	background-color:#FFFFFF;
    box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.2);
}

.other_list_txt {
	position:absolute;
	top:50%;
	left:150px;
	height:56px;
	vertical-align:middle;
	margin:-28px 0 0 40px;
	letter-spacing: 1px;
}

.other_contents  li {
	list-style:none;
	display:block;
	padding:16px 0;
	border-bottom:1px solid #e4e4e4;
	position:relative;
}

.other_contents dt {
	font-size:16px;
	font-weight:bold;
	font-style:italic;
}
.other_contents dd {
	margin-top:4px;
	font-size:12px;
	line-height:18px;
}


/*-------------------------------------------

Making
  
------------------------------------------ */

#making {
	font-family:Georgia, "Times New Roman", Times, serif;
	border-top:1px solid #e4e4e4;
	border-bottom:1px solid #e4e4e4;
	text-decoration:none;
	margin-top:40px;
}

.making_title small {
	font-size:20px;
}

.making_contents {
	overflow:hidden;
	margin:12px 0 40px 0;
	padding:4px;
	background-color:#FFFFFF;
    box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
    -moz-box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
    -webkit-box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.35);
}

.making_contents img {
	padding:4px;
	margin:0;
	float:left;
}

/*　ハンバーガーボタン　*/
.hamburger {
  display : block;
  position: inherit;
  z-index : 3;
  left : 13px;
  top   : 12px;
  width : 42px;
  height: 42px;
  cursor: pointer;
  text-align: center;
}
.hamburger span {
  display : block;
  position: absolute;
  width   : 60px;
  height  : 2px ;
  left    : 6px;
  background : #555;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition   : 0.3s ease-in-out;
  transition        : 0.3s ease-in-out;
}
.hamburger span:nth-child(1) {
  top: 10px;
}
.hamburger span:nth-child(2) {
  top: 20px;
}
.hamburger span:nth-child(3) {
  top: 30px;
}

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1),
.hamburger.active span:nth-child(3) {
  width : 14px;
}
.hamburger.active span:nth-child(1){

  -webkit-transform:    translate(17px,5px) rotate(45deg);
  -moz-transform   : translate(17px,5px) rotate(45deg);
  transform        : translate(17px,5px) rotate(45deg);
}
.hamburger.active span:nth-child(3){
 
  -webkit-transform: translate(17px,-5px) rotate(-45deg);
  -moz-transform   : translate(17px,-5px) rotate(-45deg);
  transform        : translate(17px,-5px) rotate(-45deg);
}
nav.globalMenuSp {
  position: fixed;
  z-index : 2;
  top  : 0;
  left : 0;
  color: #000;
  background: #fff;
  text-align: center;
  transform: translateX(-100%);
  transition: all 0.6s;
  width: 30%;
}

nav.globalMenuSp ul {
  background: #ccc;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

nav.globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  border-bottom: 1px solid #fff;
}
nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
  border-bottom: none;
}
nav.globalMenuSp ul li:hover{
  background :#ddd;
}

nav.globalMenuSp ul li a {
  display: block;
  color: #000;
  padding: 1.5em 0;
  text-decoration :none;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
  transform: translateX(0%);
}

<!-- カスタムCSS for トップに戻るボタン -->
.back-to-top {
  text-align: center;
  margin: 30px 0;
  padding: 20px 0;
}

.back-to-top-btn {
  display: inline-block;
  background: linear-gradient(135deg, #6c6c6c 0%, #6a6a6a 100%);
  color: #ffffff;
  padding: 4px 10px;
  text-decoration: none;
  border-radius: 25px;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: all 0.3s ease;
  border: 2px solid #444;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
  position: relative;
  overflow: hidden;
}

.back-to-top-btn:before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  transition: left 0.5s;
}

.back-to-top-btn:hover {
  background: linear-gradient(135deg, #444 0%, #2c2c2c 100%);
  border-color: #666;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
  color: #fff;
}

.back-to-top-btn:hover:before {
  left: 100%;
}

.back-to-top-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

/* アイコン付きバージョン */
.back-to-top-btn-icon {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.back-to-top-btn-icon::before {
  content: '↑';
  font-size: 16px;
  font-weight: bold;
}

/* セクション区切り線 */
.section-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, transparent, #333, transparent);
  margin: 20px 0;
}
