/*---------------------------------------------------------------------
setting
---------------------------------------------------------------------*/
html,body {height:100%;}
body {width:100%;}

/*---------------------------------------------------------------------
CSS3 animation & parts layout
---------------------------------------------------------------------*/
/* link */
.trans_bg a {opacity:1; filter:alpha(opacity=100); display:block; overflow:hidden; height:0; -moz-transition:all 0.2s ease-in; -webkit-transition:all 0.2s ease-in;}
.trans_bg a:hover {opacity:0; filter:alpha(opacity=0); -moz-transition: all 0.2s ease-in; -webkit-transition:all 0.2s ease-in;}
.trans_bg_disabled a {opacity:1; display:block; overflow:hidden; height:0; cursor: default;}

.obj  {position:absolute; z-index:0;}
.bimg {border: 1px solid #000000;}
.t_disabled {color: #cacaca;}

/*---------------------------------------------------------------------
Common layout
---------------------------------------------------------------------*/
#header  {
  width: 100%;
  height: 65px;
  z-index: 9999;
  padding: 10px 10px 10px 10px;
  background-color: #fff;
}
#header h1 img { width: 130px; }

/*********************************************************
ナビゲーション
*********************************************************/
#header #gnav {
  display: none;
}
#header .header-navbtn {
  position: absolute;
  top: 20px;
  right: 10px;
  display: block;
  width: 40px;
  height: 41px;
  font-size:20px;
  background: 0;
  border: 0;
  padding: 0;
  outline: none;
  border-radius: 5px;
  box-shadow: 0 0 3px #aaaaaa;
  background-color: #665230;
  color: #fff;
}
.offleft {
  position: fixed;
  top: -100px;
  left: -100px;
}
.sp-nav {
  width:200px;
  height:400px;
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  background: rgba(0, 0, 0, .75);
  overflow: auto;
  display: none;
  z-index: 40;
}
.sp-nav.is-open {
  display: block;
}
.sp-nav .nav-closebtn {
  position: fixed;
  top: 20px;
  right: 10px;
  width: 40px;
  height: 41px;
  color: #fff;
  font-size:20px;
  background: transparent;
  border: 0;
  outline: none;
}
.sp-nav ul {
  padding: 40px 0 10px;
}
.sp-nav li {
  padding: 10px 0 10px 20px;
}
.sp-nav a {
  color: #fff;
}

/* page layout */
#wrapper    {width:100%; overflow:hidden;}
#content    {margin: 30px auto 0;z-index: 0;}
#footer     {height: 100px; text-align: center; }
#footer p   {margin-top: 20px;} 

/* フッター上部のSNSリンク */
#sns-img {
  display: table;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  margin-top: 20px;
}
#sns-img .img-sns {
  display: table-cell;
  vertical-align: middle;
}
#sns-img .img-sns a img {
  display: inline-block;
  margin: 0 0 0 13px;
  width: 40px;
  height: 39px;
}


/* common title */
#title      {height:80px;}
#title h2   {font-size: 200%; padding-top: 20px; }
h3.title    { padding:15px; display:inline-block; font-size: 150%;  border-bottom: 1px dashed #000;}

/*---------------------------------------------------------------------
Top layout
---------------------------------------------------------------------*/
#top_wrapper{
  width: 100%;
  height: 2200px;
  margin: 0 auto;
  position: relative;
}
#top_wrapper .lnk    {z-index: 4;}
#top_wrapper .stitch {z-index: 3;}
#top_wrapper .photo  {z-index: 2;}

#top_wrapper #photo_01     { top: 0px;      left:0px; max-width:200px;}
#top_wrapper #photo_02     { top: 220px;  right:0px; max-width:150px;}
#top_wrapper #photo_03     { top: 350px;  left:0px; max-width: 130px; }
#top_wrapper #photo_04     { top: 540px; left:0px; max-width: 210px; }
#top_wrapper #photo_05     { top: 790px; right:0;  max-width: 140px; }
#top_wrapper #photo_06     { top: 1080px; left:0; max-width: 200px;}
#top_wrapper #photo_07     { top: 1310px; right:0px; max-width:200px;}
#top_wrapper #photo_08     { top: 1900px; left:0px; max-width:100%;}
/*#top_wrapper #fb           { top: 1680px; left:0px; width:100%;}
#top_wrapper #insta        { top: 2060px; left:0px; width:100%;}
#top_wrapper #insta iframe { width:100%;}  */
#top_wrapper #description  { top: 20px; right: 0px; max-width:90px}
#top_wrapper #description img { max-width: 90px; }

#top_wrapper #lnk_01       { top:230px;   left:10%; }
#top_wrapper #lnk_02       { top:560px;  right:5%; }
#top_wrapper #lnk_03       { top:800px;  left:15%; }
#top_wrapper #lnk_04       { top:1070px;  right:5%; }
#top_wrapper #lnk_05       { top:1320px;  left:5%; }
#top_wrapper #lnk_06       { top:1650px;  right:5%; }
#top_wrapper #lnk_sns      { top:1550px;  right:35%; }

#top_wrapper h2#lnk_01 {
  background:url(../images/top/lnk_01_on.gif) no-repeat 0 0;
  text-align: center;
}
#top_wrapper h2#lnk_01 a { 
  background:url(../images/top/lnk_01.gif) no-repeat 0 0;
  color: #333;
  padding-bottom: 5px;
}
#top_wrapper h2#lnk_01 .number {
  width: 50px;
  color: #333;
  font-size: 20px;
  border-bottom: solid 1px #333;
  padding: 0 0 25px 0;
  margin: 0 0 25px 0;
  display: block;
}
#top_wrapper h2#lnk_01 .title  {
  margin-left: -10px;
  padding-bottom: 5px;
  font-size: 16px;
}
#top_wrapper h2#lnk_01 a .title:hover {
  border-bottom: 1px dashed #000;
}
#top_wrapper h2#lnk_02 {
  background:url(../images/top/lnk_02_on.gif) no-repeat 0 0;
  width: 50px;
  text-align: center;
}
#top_wrapper h2#lnk_02 a {
  background:url(../images/top/lnk_02.gif) no-repeat 0 0;
  color: #333;
  font-size: 16px;
  padding-bottom: 5px;
}
#top_wrapper h2#lnk_02 .number {
  color: #333;
  font-size: 20px;
  border-bottom: solid 1px #333;
  padding: 0 0 25px 0;
  margin: 0 0 25px 0;
  text-align: center;
  display: block;
}
#top_wrapper h2#lnk_02 .title:hover {
  border-bottom: 1px dashed #000;
}
#top_wrapper h2#lnk_02 .title {
  display: block;
  padding-bottom: 5px;
  font-size: 16px;
}
#top_wrapper h2#lnk_03 {
  background:url(../images/top/lnk_03_on.gif) no-repeat 0 0;
  text-align: center;
  width: 50px;
}
#top_wrapper h2#lnk_03 a {
  background:url(../images/top/lnk_03.gif) no-repeat 0 0;
  color: #333;
}
#top_wrapper h2#lnk_03 .number {
  color: #333;
  font-size: 20px;
  border-bottom: solid 1px #333;
  padding: 0 0 25px 0;
  margin: 0 0 25px 0;
  display: block;
}
#top_wrapper h2#lnk_03 .title {
  margin-left: -40px;
  padding-bottom: 5px;
  font-size: 16px;
}
#top_wrapper h2#lnk_03 a .title:hover {
  border-bottom: 1px dashed #000;
}
#top_wrapper h2#lnk_04 {
  background:url(../images/top/lnk_04_on.gif) no-repeat 0 0;
  width: 50px;
  text-align: center;
}
#top_wrapper h2#lnk_04 a {
  background:url(../images/top/lnk_04.gif) no-repeat 0 0;
  color: #333;
  font-size: 16px;
  padding-bottom: 5px;
}
#top_wrapper h2#lnk_04 .number {
  color: #333;
  font-size: 20px;
  border-bottom: solid 1px #333;
  padding: 0 0 25px 0;
  margin: 0 0 25px 0;
  display: block;
}
#top_wrapper h2#lnk_04 .title:hover {
  border-bottom: 1px dashed #000;
}
#top_wrapper h2#lnk_04 .title {
  margin-left: -5px;
  padding-bottom: 5px;
  font-size: 16px;
}
#top_wrapper h2#lnk_05 {
  background:url(../images/top/lnk_01_on.gif) no-repeat 0 0;
  text-align: center;
}
#top_wrapper h2#lnk_05 a { 
  background:url(../images/top/lnk_01.gif) no-repeat 0 0;
  color: #333;
  padding-bottom: 5px;
}
#top_wrapper h2#lnk_05 .number {
  width: 50px;
  color: #333;
  font-size: 20px;
  border-bottom: solid 1px #333;
  padding: 0 0 25px 0;
  margin: 0 0 25px 0;
  display: block;
}
#top_wrapper h2#lnk_05 .title {
  margin-left: -10px;
  padding-bottom: 5px;
  font-size: 16px;
}
#top_wrapper h2#lnk_05 a .title:hover {
  border-bottom: 1px dashed #000;
}
#top_wrapper h2#lnk_06 {
  background:url(../images/top/lnk_04_on.gif) no-repeat 0 0;
  width: 110px;
  text-align: center;
}
#top_wrapper h2#lnk_06 a {
  background:url(../images/top/lnk_04.gif) no-repeat 0 0;
  color: #333;
  font-size: 16px;
  padding-bottom: 5px;
}
#top_wrapper h2#lnk_06 .number {
  color: #333;
  font-size: 20px;
  border-bottom: solid 1px #333;
  padding: 0 0 25px 0;
  margin: 0 0 25px 0;
  display: block;
}
#top_wrapper h2#lnk_06 .title:hover {
  border-bottom: 1px dashed #000;
}
#top_wrapper h2#lnk_06 .title {
  display: block;
  padding-bottom: 5px;
}
#top_wrapper h2#lnk_sns {
  width: 110px;
  text-align: center;
}
#top_wrapper h2#lnk_sns a {
  color: #333;
  font-size: 16px;
  padding-bottom: 5px;
}
#top_wrapper h2#lnk_sns a:hover {
  border-bottom: 1px dashed #000;
}
#top_wrapper h2#lnk_sns a .title01:hover,
a .title02:hover {
  border-bottom: 1px dashed #000;
}
#top_wrapper h2#lnk_sns .title01 {
  font-size: 16px;
  padding: 0 0 10px 0;
  display: block;
}
.title02 {
  display: block;
  border-top: solid 1px #333;
  padding: 25px 0 10px 0;
  margin: 10px 0 0px 0;
}

#content {
  padding: 0 10px 0 10px;
  margin: 0 auto;
}
#snav_left {
  display: none;
}

#top_wrapper #stitch_01  { top:40px;   right:5%;  width: 260px; height: 260px; }
#top_wrapper #stitch_02  { top:380px;  right:0%;  width: 210px; height: 210px; }
#top_wrapper #stitch_03  { top:200px;  left:0;     width: 480px; height: 480px; }
#top_wrapper #stitch_04  { top:600px;  right0%;  width: 330px; height: 330px; }
#top_wrapper #stitch_05  { top:860px;  left:-30%;   width: 250px; height: 250px;}
#top_wrapper #stitch_06  { top:930px;  right:26%;  width: 2px;   height: 440px; }
#top_wrapper #stitch_07  { top:1980px;  left:0%;   width: 190px; height: 190px; }
#top_wrapper #stitch_08  { top:80px;   left:25px; width: 570px; height: 570px;}
#top_wrapper #stitch_09  { top:1450px;   left:50%; width: 570px; height: 570px;}


/*---------------------------------------------------------------------
concept layout
---------------------------------------------------------------------*/
#concept_wrapper .lnk    {z-index: 4;}
#concept_wrapper .stitch {z-index: 3;}
#concept_wrapper .photo  {z-index: 2;}

#concept_wrapper              { width: 100%; margin: 0 auto; height: 2350px; position: relative; }
#concept_wrapper #photo_01    { top: 0px; left:0px; max-width: 180px; }
#concept_wrapper #photo_02    { top: 670px; right:0px; max-width: 180px; }
#concept_wrapper #photo_03    { top: 980px; left:0px; max-width: 40%; }
#concept_wrapper #photo_04    { top: 1320px; left:0px; max-width: 60%; }
#concept_wrapper #photo_05    { top: 1000px; right:0px; max-width: 50%; }
#concept_wrapper #photo_06    { top: 1720px; left:0px; max-width: 50%; }
#concept_wrapper #photo_07    { top: 1520px; right:0px; max-width: 60%; }
#concept_wrapper #photo_08    { top: 2050px; left:0px; max-width: 100%; }

#concept_wrapper #description img { max-width:100px; }
#concept_wrapper #text_box    { top: 315px; left: 0px;  width: 100%;}
#concept_wrapper #text_box p  { font-size:100%; line-height: 230%; text-align: center; }

/*---------------------------------------------------------------------
Menu layout
---------------------------------------------------------------------*/
#menu_wrapper { width: 100%; height: 1240px; margin: 0 auto; position: relative; }
#menu_wrapper h3 { font-size:108%; margin:0 0 30px; }
#menu_wrapper h3 span { font-size:7px; }
#menu_wrapper table {
  width: 100%;
  margin:0 0 60px;
}
#menu_wrapper table th {
  text-align: left;
  width: 50%;
  font-weight: bold;
  font-size: 100%;
  line-height: 230%;
}

#menu_wrapper table td {
  text-align: right;
  width: 50%;
  font-weight: bold;
  font-size:100%;
  line-height: 230%;
}

/*---------------------------------------------------------------------
Calendar layout
---------------------------------------------------------------------*/
#calendar_wrapper { width:100%;/* height: 660px;*/ margin: 0 auto;}
#calendar_wrapper table {
  border-collapse: collapse;
}
#calendar_wrapper table th {
  padding: 10px 0;
}
#calendar_wrapper table td {
  padding: 10px 0;
}

/*---------------------------------------------------------------------
ShopInformation layout
---------------------------------------------------------------------*/
#contactbtn {
  padding: 30px 0 0 0;
}
#contactbtn p {
  font-size: 15px;
}
#contactbtn p a {
  font-size: 20px;
}
#contactbtn a:hover {
  color: #B7E9F6;
}
#shopinfo_wrapper { margin: 30px auto 0; width: 100%; height: 1030px; position: static; }
#shopinfo_wrapper #map {
  position: static;
}
#shopinfo_wrapper #map iframe {
  width: 100%;
  height: 300px;
  margin: 20px 0 0 0;
}
#shopinfo_wrapper #shop-info {
  width: 100%;
  position: static;
}
#shopinfo_wrapper #shop-info p {
  font-size:108%;
  line-height: 180%;
}
#shop-img {
  position: static;
  margin: 30px 0 0 0;
}

#shop-img ul {
  list-style: none;
}

#shop-img ul:after {
  content: "";
  display: block;
  clear: both;
}
#shop-img ul li {
  float: left;
  width: 33.3333%;
}
#shop-img ul li img {
  width: 100%; 
}

/*---------------------------------------------------------------------
Style layout
---------------------------------------------------------------------*/
#style_wrapper .lnk    {z-index: 4;}
#style_wrapper .stitch {z-index: 3;}
#style_wrapper .photo  {z-index: 2;}

#style_wrapper              { width: 100%; margin: 0 auto; height: 440px; position: relative; }
#style_wrapper #photo_01    { top: 0px; left:0px; width: 60px; }
#style_wrapper #photo_02    { top: 0px; left:68px; width: 60px;}
#style_wrapper #photo_03    { top: 120px; left:0px; width: 145px;}
#style_wrapper #photo_04    { top: 120px;  left:155px; width: 145px;}
#style_wrapper #photo_05    { top: 245px; left:0px; width: 145px;}
#style_wrapper #photo_06    { top: 245px; left:155px; width: 145px;}
#style_wrapper #text_box    { top: 0px; left: 72px;  width: 100%;}
#style_wrapper #text_box p  { font-size:70%; line-height: 220%; text-align: center; }

@media(min-width: 321px) {
  #style_wrapper              { height: 500px;}
  #style_wrapper #photo_01    { top: 0px; left:0px; width: 80px; }
  #style_wrapper #photo_02    { top: 0px; left:88px; width: 80px;}
  #style_wrapper #photo_03    { top: 140px; left:0px; width: 170px;}
  #style_wrapper #photo_04    { top: 140px;  left:183px; width: 170px;}
  #style_wrapper #photo_05    { top: 275px; left:0px; width: 170px;}
  #style_wrapper #photo_06    { top: 275px; left:183px; width: 170px;}
  #style_wrapper #text_box    { top: 0px; left: 93px;  width: 100%;}
  #style_wrapper #text_box p  { font-size:80%; line-height: 220%; text-align: center; }
}


/*********************************************************
PageTopボタン
*********************************************************/
#page-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 10000;
}
page-top i {
  font-size: 167%;
}
#page-top a {
  background: #333;
  text-decoration: none;
  color: #fff;
  width: 50px;
  padding: 3px 0;
  text-align: center;
  display: block;
  border-radius: 5px;
  opacity: 0.6;
  font-size: 14px;
}
#page-top a:hover {
  text-decoration: none;
  opacity: 1;
}