@CHARSET "UTF-8";

/* header
-------------------------------------------------------------*/
header {
  border-style: solid;
  border-width: 0 0 3px;
  width: 100%;
  height: 50px; /* 2015.8.3 change 45px -> 50px */
  z-index: 1000;
  top: 0;
  position: absolute;
}

header #logo {
  padding: 0 25px 0 10px;
  float: left;
}

header nav {
  line-height: 50px; /* 2015.8.3 change 45px -> 50px */
  float: right;
}

header nav ul {
  line-height: 50px; /* 2015.8.3 change 45px -> 50px */
}

header nav li {
  border: 0 none;
  float: left;
  padding: 0 10px;
  min-width: 48px;
}

header nav li a img {
  vertical-align: middle;
}

.default header { height: 53px; }             /* 2015.8.3 change 37 -> 53 */
.default header #logo img { height: 50px; }   /* 2015.8.3 change 35 -> 50 */
.default header nav ul { line-height: 51px; } /* 2015.8.3 change 36 -> 51 */

/* content
-------------------------------------------------------------*/
#wrapper {
  margin: 0;
  padding: 45px 0 20px;
  width: 100%;
}

#wrapper:after {
  height: 0;
  display: block;
  clear: both;
  content: " ";
}

.default #wrapper {
  padding: 54px 0 20px; /* 2015.8.3 change 37 -> 54 */
}

/* navigation
-------------------------------------------------------------*/
/* pc_navi */
#pc_navi:after {
  height: 0;
  display: block;
  clear: both;
  content: " ";
}

.nav_btn {
  padding: 0 10px;
  border-right: 2px solid #000;
  float: left;
  width: 87px;
}

.nav_btn li {
  width: 30px;
  height: 30px;
  display: inline-block;
  cursor: pointer;
}

.nav_btn li span {
  text-indent: -9999px;
  margin: 9px;
  width: 12px;
  height: 12px;
  display: block;
}

.nav_btn.Op #navChg { display: none; }

#navOp span, #navChg span {
  background-position: center center;
  background-repeat: no-repeat;
}

.navT .nav_btn #navChg span, .navT_tn .nav_btn #navChg span { background-image: url(./img/navchg_h.png); }
.navL .nav_btn #navChg span, .navL_tn .nav_btn #navChg span { background-image: url(./img/navchg_v.png); }
.nav_btn #navOp span { background-image: url(./img/navcls.png); }
.nav_btn.Op #navOp span { background-image: url(./img/navopn.png); }

.nav_tab {
  font-weight: bold;
  float: left;
  overflow: hidden;
}

.nav_tab li { float: left; }

.nav_tab li a {
  padding: 5px 25px;
  display: block;
}

.nav_list {
  font-size: 92%;
  clear: both;
  overflow: visible;
  position: relative;
}

.nav_list.hide {
  width: 0 !important;
  height: 0 !important;
  display: none;
}

.nav_list ul {
  border-style: solid;
  overflow: hidden;
}

.nav_list ul:after {
  height: 0;
  display: block;
  clear: both;
  content: " ";
}

.nav_list li { white-space: nowrap; }

.nav_list li img {
  vertical-align: middle;
  width: 42px;
}

.navT .nav_list li img,
.navT .nav_list li img {
  width: 42px;
}
.navT_tn .nav_list li img,
.navL_tn .nav_list li img {
  width: 36px;
}

.nav_list a { color: inherit; }
.nav_list a:hover img { opacity: 0.7; }

/* ナビゲーション上配置 */
.navT .nav_list ul, .navT_tn .nav_list ul {
  padding: 5px 10px;
  border-width: 0;
}

.navT .nav_list li a, .navT_tn .nav_list li a {
  padding: 0;
  display: block;
}

.navT .nav_list li a { padding-bottom: 15px; }
.navT .nav_list li a:hover span {
  border: 1px solid #ccc;
  background: #fcfcfc;
  white-space: normal;
  overflow:visible;
  text-overflow: clip;
}

.navT .nav_list li, .navT_tn .nav_list li {
  text-align: center;
  padding: 0 0 4px;
  width: 90px;
  float: left;
}

.navT .nav_list li span {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  width: 90px;
  text-overflow: ellipsis;
}
.navT_tn .nav_list li { width: 55px; }

/* ナビゲーション左配置 */
.navL .nav_list, .navL_tn .nav_list {
  height: 100%;
  float: left;
}

.navL .nav_list ul, .navL_tn .nav_list ul {
  padding: 10px 20px 10px 10px;
  border-width: 0;
  float: left;
}

.navL .nav_list li { padding: 0 0 5px; }
.navL .nav_list li span { padding-left: 10px; }
.navL_tn .nav_list li img { margin: 0 5px 0 0; }
.navT_tn .nav_list li a, .navL_tn .nav_list li a { position: relative; }
.navT_tn .nav_list li span, .navL_tn .nav_list li span { display: none; }

.navT_tn .nav_list li a:hover span, .navL_tn .nav_list li a:hover span {
  opacity: 0.9;
  text-align: center;
  padding: 3px;
  width: 100px;
  z-index: 10000;
  left: -5px;
  display: block;
  white-space: normal;
}

.navT_tn .nav_list li a:hover span {
  bottom: 0;
  position: absolute;
  display: none;
}

.navL_tn .nav_list li a:hover span { position: fixed; }

/*nav position chg*/
.navT .content, .navT_tn .content {
  border-width: 0;
  clear: both;
  overflow: hidden;
}

.navL .content, .navL_tn .content {
  border-width: 0;
  float: left;
}

.uix-tab-menu-active {
  background: #ffffff;
}
.uix-tab-menu {
  white-space: nowrap;
  font-weight: bold;
}

.uix-tab-menu li {
  padding: 0;
  position: relative;
  display: inline-block;
}

.uix-tab-menu a:hover, .uix-tab-menu a:focus {
  text-decoration: none;
}

.uix-tab-menu > li > a {
  display: inline-block;
  width: auto;
  height: 30px;
  padding: 0 10px 0 10px;
  line-height: 30px;
}

/* Swipe Navi */
#swipe_navi {
  overflow-y: auto;
  border-bottom: 1px solid #fff;
}

#swipe_navi dt {
  font-weight: bold;
  padding: 10px;
  border-top: 1px solid #fff;
}

#swipe_navi dd {
  padding: 10px 0;
  display: none;
}

#swipe_navi dd.active { display: block; }

.icon_list {
  padding: 5px;
}

.icon_list:after {
  height: 0;
  display: block;
  clear: both;
  content: " ";
}

.icon_list li {
  font-size: 100%;
  text-align: center;
  margin-bottom: 7px;
  width: 83px;
  float: left;
}

.icon_list li span { display: block; }

.icon_list li img {
  vertical-align: middle;
  width: 40px;
}

.content {
  border-color: #000;
  border-style: solid;
}

.content:after {
  height: 0;
  display: block;
  clear: both;
  content: " ";
}


/* footer
-------------------------------------------------------------*/
footer {
  line-height: 18px;
  border-top: 1px solid #000;
  width: 100%;
  height: 30px;
  z-index: 100;
  bottom: 0;
  clear: both;
  position: fixed;
}

.jsp {
  /*overflow-y: auto !important;
  overflow-x: hidden !important;*/
  overflow: auto !important;
  height: 100%;
}


/* Layout
-------------------------------------------------------------*/
/* レイアウトタイプで場合分け */
/* 2カラムタイプ (ツリー + 一覧) */
.layout_type1 #col2 {
  width: 100% !important;
}

/* 2カラムタイプ (ツリー or 一覧 + 詳細)*/
.layout_type2 .content_body div.left {
  display: none;
}
.layout_type2 .content_body div.right #col2 {
  float: left;
  min-width: 300px;
  max-width: 450px;
  width: 300px;
  border-right-width: 1px;
  border-right-style: solid;
}

.layout_type3 .left {
  min-width: 200px;
  max-width: 300px;
  width: 200px;
}

.layout_type3 .right {

}
/* 3カラムタイプ、Previewが右配置の場合 */
.layout_type3.preview1 .content_body > div.right #col2 {
  border-right-width: 1px;
  border-right-style: solid;
  float: left;
  min-width: 250px;
  max-width: 450px;
  width: 300px;
}
.layout_type3.preview1 #col3 {
  position: absolute;
  right: 0;
}

/* 3カラムタイプ、Previewが下配置の場合 */
.layout_type3.preview2 .content_body > div.right #col2 {
  height: 200px;
}

/* 3カラムタイプ、PreviewがOffの場合 */
.layout_type3.preview3 .content_body > div.right #col2 {
  width: 100% !important;
  min-width: none !important;
  max-width: none !important;
}
.layout_type3.preview3 .content_body > div.right #col3 {
  display: none;
}

/* 拡大表示 */
.zoom #col2 {
  display: none;
}
.zoom #col3 {
  left: 0 !important;
  width: 100%;
}


.blc_fixed {

}

.blc_header {
  /*padding: 15px 10px;*/
  padding: 0 10px;
  border-bottom-style: solid;
  border-bottom-width: 1px;
  min-height: 33px;
  line-height: 30px;
  font-size: 12px;
}

.blc_header select {
  padding: 3px 2px;
  border-color: #9fa3ac;
}
.blc_header .button {
  margin-top: -1px;
}

.blc_footer {
  padding: 0 6px;
  border-top-style: solid;
  border-top-width: 1px;
  min-height: 26px;
  line-height: 24px;
  font-size: 12px;
}


html.fluid { overflow: auto !important; }
html.fluid header { position: relative; }
html.fluid .jsp { overflow: visible !important; }
html.fluid #wrapper { padding: 0; }
html.fluid .snap-content { display: table; }
html.fluid .content_body > div.right { overflow: visible !important; margin-left: 200px; }
html.fluid footer { position: relative; }
