@charset "utf-8";



/*****************************/
/********** Default **********/
/*****************************/

* {
  font-family: Arial, 'Yu Gothic', YuGothic, Meiryo, 'Hiragino Kaku Gothic ProN', sans-serif;
  font-weight: 500;
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

::-moz-selection { background: #BBBBBB; color: #FFFFFF; text-shadow: none;}
::selection { background: #BBBBBB; color: #FFFFFF; text-shadow: none;}

::-webkit-input-placeholder {color: #FFFFFF;}
::-moz-placeholder  {color: #FFFFFF;}
:-moz-placeholder {color: #FFFFFF;}
:-ms-input-placeholder  {color: #FFFFFF;} 

p {
  margin: 20px 0;
}
html, body {
  height: 100%;
}
body {
  margin: 0 auto;
  padding: 0;
  font-size: 1.6rem;
  line-height: 160%;
  color: #000000;
  background-color: #FFFFFF;
}
ul, ol, li {
  margin: 0;
  padding: 0;
  list-style: none;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: bold;
  font-style: normal;
  clear: both;
}
a {
  color: #0F2625;
  background: none;
  text-decoration: underline;
}
a:hover {
  color: #2BAA9C;
  text-decoration: none;
}
a img {
  border: none;
}
address {
  font-style: normal;
}
img {
  vertical-align: middle;
}
strong, em {
  font-style: normal;
  font-weight: bold;
}
sup {
  vertical-align: baseline;
  position: relative;
  top: -1ex;
  font-size: 1.0rem;
}
sub {
  vertical-align: baseline;
  position: relative;
  bottom: -1ex;
  font-size: 1.0rem;
}
hr {
  border: none;
  height: 1px;
  background-color: #BDDFB3;
  margin: 30px 0;
  clear: both;
}
figure {
  margin: 0 auto;
}
figcaption {
  margin: 10px auto;
}
.center {
  text-align: center;
}
.left {
  text-align: left;
}
.right {
  text-align: right;
}
.alignleft {
  display: inline;
  float: left;
  margin: 0 20px 20px 0;
}
.alignright {
  display: inline;
  float: right;
  margin: 0 0 20px 20px;
}
.aligncenter {
  display: block;
  margin: 20px auto;
  text-align: center;
}
.email:after {
  content: "@";
}



/***************************************/
/********** Base Font Setting **********/
/***************************************/

html {
  font-size: 62.5%;
}



/****************************************/
/********** Base Setting (1024) **********/
/****************************************/

body {
  min-width: 1000px;
}



/****************************/
/********** Header **********/
/****************************/

.home #header {
  width: 100%;
}
.home #header header {
  margin: 0 auto;
  padding: 0;
  width: 1000px;
  text-align: left;
}
.page #header {
  background-image: url("../images/main-image01.jpg");
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center bottom;
  height: 90px;
  width: 100%;
  border-bottom: 10px solid #EDF0E3;
}
.page #header header {
  display: none;
}



/****************************/
/********** Footer **********/
/****************************/

#footer {
  background-image: url("../images/bg-footer.png");
  background-repeat: repeat-x;
  background-position: center bottom;
  background-size: auto 100%;
  width: 100%;
}
#footer footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-align: left;
  margin: 0 auto;
  padding: 0 10px;
  width: 1000px;
}
#footer footer #credit {
  margin: 0;
  padding: 0;
  text-align: left;
  width: 60%;
  font-size: 1.8rem;
}
#footer footer #credit h2 {
  margin: 10px 0;
  padding: 0;
}
#footer footer #credit h3 {
  margin: 10px 0;
  padding: 0;
}
#footer footer #credit p {
  margin: 10px 0;
  padding: 0;
  font-size: 1.8rem;
  line-height: 180%;
}
#footer footer nav {
  margin: 0 0 0 20px;
  padding: 0;
  width: 40%;
  display: flex;
}
#footer footer nav ul {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  width: 100%;
}
#footer footer nav ul li {
  margin: 5px 0;
  padding: 0;
  text-align: left;
  font-size: 1.6rem;
  width: 100%;
}
#footer footer nav ul li a {
  text-decoration: none;
  background-image: url("../images/icon04.png");
  background-repeat: no-repeat;
  background-position: left center;
  padding: 0 0 0 24px;
  color: #000000;
}
#footer footer nav ul li a:hover,
#footer footer nav ul li.current a:hover {
  text-decoration: none;
  background-image: url("../images/icon08.png");
  background-repeat: no-repeat;
  background-position: left center;
}
#footer footer nav ul li.current a {
  text-decoration: none;
  background-image: url("../images/icon03.png");
  background-repeat: no-repeat;
  background-position: left center;
}
#footer #pagetop {
  position: fixed;
  bottom: 40px;
  right: 40px;
}
#footer #copyright {
  font-size: 1.8rem;
  text-align: center;
  margin: 0 auto;
  padding: 10px 0;
  background-color: #EDF0E3;
}



/*********************************/
/********** Slide Image **********/
/*********************************/

.slider {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 100;
  width: 100%;
  height: 350px;
  background-position: center;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  text-align: center;
  margin: 0 auto;
}
.slider .extension {
  background-image: url("../images/bg-header.png");
  background-repeat: repeat-x;
  background-position: center -25px;
  background-size: auto 100%;
  height: 100%;
}
.slider .extension p {
  padding: 70px 0 0 250px;
}



/**************************/
/********** Main **********/
/**************************/

main {
  width: 100%;
  margin: 0;
  padding: 0;
}



/****************************************/
/********** Respomsive Swicher **********/
/****************************************/

#trigger {
  display: none;
}
#modal-window {
  display: inline;
}



/*****************************/
/********** Sidebar **********/
/*****************************/

#sidebar {
  margin: 0 30px 0 0;
  padding: 50px 35px;
  background: rgba(255,255,255,0.7);
  position: relative;
  z-index: 300;
}
#sidebar nav {
  clear: both;
  margin: 40px 0 0 0;
  padding: 0;
}
#sidebar nav ul {
  clear: both;
  text-align: center;
  margin: 0;
  padding: 0;
}
#sidebar nav ul li {
  clear: both;
  margin: 0;
  padding: 0;
  text-align: left;
  font-size: 1.6rem;
  border-bottom: 1px dashed #0F2625;
}
#sidebar nav ul li a {
  display: block;
  margin: 0;
  padding: 17px 0 17px 23px;
  color: #000000;
  text-decoration: none;
  width: 100%;
  height: 100%;
  font-weight: bold;
}
#sidebar nav ul li.current {
  background-image: url("../images/icon01.png");
  background-repeat: no-repeat;
  background-position: left 5px;
  margin: 4px 0 0 0;
}
#sidebar nav ul li a:hover {
  background-image: url("../images/icon07.png");
  background-repeat: no-repeat;
  background-position: left 5px;
}

#sidebar nav ul li ul {
  display: none;
}
#sidebar nav ul li.current ul {
  display: block;
}
#sidebar nav ul li ul li {
  margin: 0;
  padding: 0;
  background-color: #BDDFB3;
  border: none;
}
#sidebar nav ul li ul li a {
  display: block;
  margin: 0;
  padding: 10px 20px;
}
#sidebar nav ul li ul li a:before {
  content: "・";
}
#sidebar nav ul li ul li.current,
#sidebar nav ul li ul li a:hover {
  background-color: #BDDFB3;
  background-image: none;
}



/*****************************/
/********** Content **********/
/*****************************/

#content {
  vertical-align: top;
  margin: 80px 0 40px 0;
  padding: 0;
  width: 100%;
  height: 100%;
}
#content article {
  clear: both;
  overflow: hidden;
  margin: 0;
  padding: 0;
  position: relative;
}



/**************************************/
/********** Content (Common) **********/
/**************************************/

#content h2 {
  clear: both;
  font-size: 3.0rem;
  font-style: normal;
  font-weight: bold;
  color: #000000;
  margin: 30px 0;
  padding: 0;
  border-bottom: 2px solid #2BAA9C;
  line-height: 160%;
}
#content h3 {
  clear: both;
  font-size: 1.8rem;
  font-style: normal;
  font-weight: bold;
  color: #000000;
  margin: 30px 0;
  padding: 5px 15px;
  border-left: 8px solid #0F2625;
  background-color: #EDF0E3;
  line-height: 160%;
}
#content h4 {
  clear: both;
  font-size: 1.6rem;
  font-style: normal;
  font-weight: bold;
  color: #000000;
  margin: 0 0 30px 0;
  padding: 0;
  line-height: 160%;
}
#content .date {
  text-align: right;
  font-size: 1.4rem;
  font-family: Verdana;
}
#content .back {
  clear: both;
  border-top: 1px solid #BDDFB3;
  margin: 30px auto 0 auto;
  padding: 30px 0 0 0;
  text-align: center;
}
#content .back a {
  display: block;
  text-align: center;
  margin: 0 auto;
  padding: 10px 20px;
  border: 2px solid #2F2E2E;
  background-color: #EDF0E3;
  border-radius: 40px;
  font-weight: bold;
  text-decoration: none;
  color: #2F2E2E;
  width: 30%;
}
#content .back a:before {
  content: "<";
  margin: 0 20px 0 0;
}
#content .back a:hover {
  color: #FFFFFF;
  background-color: #2BAA9C;
  border: 2px solid #2BAA9C;
}
#content .more {
  clear: both;
  margin: 30px auto 0 auto;
  padding: 30px 0 0 0;
  text-align: center;
}
#content .more a {
  display: block;
  text-align: center;
  margin: 0 auto;
  padding: 10px 20px;
  border: 2px solid #2F2E2E;
  background-color: #EDF0E3;
  border-radius: 40px;
  font-weight: bold;
  text-decoration: none;
  color: #2F2E2E;
  width: 30%;
}
#content .more a:before {
  content: ">>";
  margin: 0 20px 0 0;
}
#content .more a:hover {
  color: #FFFFFF;
  background-color: #EDF0E3;
  border: 2px solid #2BAA9C;
}
#content .years {
  clear: both;
  overflow: hidden;
  margin: 20px 0;
  padding: 0;
  display: flex;
}
#content .years li {
  margin: 0;
  padding: 0;
  font-size: 1.4rem;
  border-left: 1px solid #BDDFB3;
  border-top: 1px solid #BDDFB3;
  border-bottom: 1px solid #BDDFB3;
  background-color: #EDF0E3;
}
#content .years li:last-child {
  border-right: 1px solid #BDDFB3;
}
#content .years li a {
  display: block;
  padding: 4px 20px;
  width: 100%;
}
#content .years li.current {
  padding: 4px 20px;
  font-weight: bold;
  color: #0F2625;
  background-color: #FFFFFF;
}
#content .category {
  background-color: #0F2625;
  color: #FFFFFF;
  border-radius: 10px;
  margin: 0 10px;
  padding: 2px 10px;
  font-size: 1.2rem;
}



/*********************************/
/********** Breadcrumbs **********/
/*********************************/

#breadcrumbs {
  margin: 0 auto;
  padding: 40px 0 0 0;
}
#breadcrumbs ul {
  margin: 0;
  padding: 0;
}
#breadcrumbs ul li {
  display: inline;
  font-size: 1.4rem;
}
#breadcrumbs ul li:after {
  content: ">";
  font-size: 1.2rem;
  margin: 0 4px;
  padding: 0 0 0 4px;
}
#breadcrumbs ul li:last-child:after {
  content: none;
}



/**********************************/
/********** Page Content **********/
/**********************************/

.page #contents00 {
  display: flex;
  justify-content: space-between;
  margin: -90px auto 40px auto;
  padding: 0;
  width: 1000px;
  text-align: left;
}
.page #contents00 #sidebar h1 {
  margin: 60px 0 0 0;
}



/**************************/
/********** Home **********/
/**************************/

.home #contents00 {
  display: flex;
  justify-content: space-between;
  margin: 0 auto 20px auto;
  padding: 0 5px 0 0;
  width: 1000px;
  text-align: left;
}
.home #contents00 #description {
  margin: 400px 0 40px 0;
  padding: 5px 30px 5px 30px;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 200;
  border: 2px solid #2BAA9C;
  font-size: 1.9rem;
  text-align: left;
  line-height: 200%;
}
.home #contents00 #description h2 {
  text-align: center;
  border-bottom: 2px solid #2BAA9C;
  margin: 0 auto;
  padding: 0 0 5px 0;
}

.home #contents01 {
  margin: 0 auto;
  padding: 60px 0;
  width: 100%;
  background-color: #EDF0E3;
}
.home #contents01 article {
  margin: 0 auto;
  padding: 0 10px;
  width: 1000px;
  display: flex;
  flex-direction: column;
}
.home #contents01 h2 {
  text-align: center;
  margin: 0 auto;
}
.home #contents01 dl {
  clear: both;
  order: 2;
  margin: 20px 0 10px 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #BDDFB3;
  width: 100%;
  display: flex;
}
.home #contents01 dl dt {
  margin: 0;
  padding: 0;
  text-align: left;
  white-space: nowrap;
  width: 12%;
  font-size: 1.4rem;
  font-family: Verdana;
}
.home #contents01 dl dd {
  margin: 0;
  padding: 0;
  text-align: left;
}
.home #contents01 .archives {
  text-align: right;
  font-size: 1.4rem;
  order: 1;
}
.home #contents01 .archives a {
  text-decoration: none;
}
.home #contents01 .archives a:before {
  content: url("../images/icon04.png");
  position: relative;
  top: 2px;
  margin: 0 10px 0 0;
}
.home #contents01 .archives a:hover:before {
  content: url("../images/icon03.png");
  margin: 0 10px 0 0;
  position: relative;
  top: 2px;
}

.home #contents02 {
  margin: 0 auto;
  padding: 60px 0;
  width: 100%;
  background-color: #FFFFFF;
}
.home #contents02 article {
  margin: 0 auto;
  padding: 0;
  width: 1000px;
}
.home #contents02 h2 {
  text-align: center;
  margin: 0 auto;
}
.home #contents02 ul {
  clear: both;
  text-align: center;
  margin: 60px auto;
  padding: 0;
  display: flex;
  justify-content: space-between;
}
.home #contents02 ul li {
  margin: 0 auto;
  padding: 20px 5px;
  text-align: center;
  font-size: 1.8rem;
  border-right: 1px dashed #0F2625;
  display: block;
}
.home #contents02 ul li:last-child {
  border: none;
}



/*******************************/
/********** ketogenic **********/
/*******************************/

.page-id-1 #content article ul {
  list-style-position: inside;
  margin: 20px 40px;
}
.page-id-1 #content article ul li {
  list-style-type: disc;
  margin: 10px 0;
}
.page-id-1 #content article ol {
  list-style-position: inside;
  margin: 20px;
}
.page-id-1 #content article ol li {
  list-style-type: none;
  counter-increment: cnt;
  margin: 10px 0;
}
.page-id-1 #content article ol li:before{
  display: marker;
  content: counter(cnt) ") "
}



/******************************/
/********** About Us **********/
/******************************/

.page-id-2 #content {
}



/*****************************/
/********** Members **********/
/*****************************/

.page-id-3 #content article table {
  clear: both;
  margin: 0 0 30px 0;
  padding: 0;
  width: 100%;
  table-layout: auto;
  border-collapse: collapse;
}
.page-id-3 #content article table tr th {
  margin: 0;
  padding: 4px 10px;
  text-align: center;
  border: 1px solid #0F2625;
  background-color: #EDF0E3;
}
.page-id-3 #content article table tr td {
  margin: 0;
  padding: 4px 10px;
  border: 1px solid #0F2625;
  background-color: #FFFFFF;
}
.page-id-3 #content article table td:nth-child(1) {
  white-space: nowrap;
  width: 25%;
}
.page-id-2 #content article table:last-child {
  margin: 0;
}



/****************************/
/********** Report **********/
/****************************/

.page-id-4 #content article dl {
  clear: both;
  margin: 20px 0 10px 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #BDDFB3;
  width: 100%;
  display: flex;
}
.page-id-4 #content article dl dt {
  margin: 0;
  padding: 0;
  text-align: left;
  white-space: nowrap;
  width: 25%;
  font-size: 1.4rem;
  font-family: Verdana;
}
.page-id-4 #content article dl dd {
  margin: 0;
  padding: 0;
  text-align: left;
}



/*************************************/
/********** Report (Detail) **********/
/*************************************/



/**************************/
/********** Link **********/
/**************************/

.page-id-5 #content article ul {
  clear: both;
  margin: 0;
  padding: 0;
}
.page-id-5 #content article ul li {
  margin: 10px 0;
  padding: 10px 0;
  border-bottom: 1px dashed #0F2625;
}
.page-id-5 #content article ul li a:before {
  content: url("../images/icon04.png");
  margin: 0 10px 0 0;
  position: relative;
  top: 2px;
}
.page-id-5 #content article ul li a:hover:before {
  content: url("../images/icon03.png");
  margin: 0 10px 0 0;
  position: relative;
  top: 2px;
}



/**************************/
/********** News **********/
/**************************/

.page-id-6 #content article dl {
  clear: both;
  margin: 20px 0 10px 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #BDDFB3;
  width: 100%;
  display: flex;
}
.page-id-6 #content article dl dt {
  margin: 0;
  padding: 0;
  text-align: left;
  white-space: nowrap;
  width: 16%;
  font-size: 1.4rem;
  font-family: Verdana;
}
.page-id-6 #content article dl dd {
  margin: 0;
  padding: 0;
  text-align: left;
}



/***********************************/
/********** News (Detail) **********/
/***********************************/