@charset "utf-8";

/* ======================================================

	INCSS 1.0
	Copyright (c) 2015 Natsuko Ogawa & INBRANDING Inc.
	Released under the MIT license
	http://opensource.org/licenses/mit-license.php
	
	last updated:20151010
	
  ======================================================*/

/* @group 1:base */

/* ======================================================*/

/* @group 1-00:normalize */

/* 00：ノーマライズ
　　
　　normalize.cssを使用しています。

 ======================================================

	! normalize.css v3.0.1 | MIT License | git.io/normalize

   ======================================================
 */

html {
  font: "メイリオ",“Meiryo”,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HiraKakuPro-W3","Yu Gothic","MS PGothic",Osaka,sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  margin: 0;
  font-size: 14px;
  font-size: 1.4rem;
}

h1,h2,h3,h4,h5,h6,p,ul,ol,dl,table {
  margin-top: 0;
  margin-bottom: 0;
  font-weight: normal;
}

/* HTML5 display definitions*/

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden],
template {
  display: none;
}

/* Links */

a {
  background: transparent;
}

a:active,
a:hover {
  outline: 0;
}

/* Text-level  */

html {
  font-size: 62.5%;
}

p,li,dt,dd,th,td,pre {
  -ms-line-break: strict;
  line-break: strict;
  -ms-word-break: break-strict;
  word-break: break-strict;
}

abbr[title] {
  border-bottom: 1px dotted;
}

strong {
  font-weight: bold;
}

dfn {
  font-style: italic;
}

mark {
  background: #ff0;
  color: #000;
}

small {
  font-size: 10px;
  font-size: 1rem;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Embedded content */

img {
  border: 0;
  max-width: 100%;
  /*fruid-image */
  vertical-align: middle;
  width: auto\9;
  /*IE8 and below */
  height: auto\9;
  /*IE8 and below */
  -ms-interpolation-mode: bicubic;
}

svg:not(:root) {
  overflow: hidden;
}

figure {
  margin: 1em 40px;
}

hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}

pre {
  overflow: auto;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms */

button,
input,
optgroup,
select,
textarea {
  color: inherit;
  font: inherit;
  margin: 0;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html input[type="button"], 
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

input[type="search"] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}

ut[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

/* Tables */

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

ul,ol {
  list-style: none;
  padding-left: 0;
}

/* @end */

/* @group 1-01:font-face */

body {
  font-family:  "メイリオ",“Meiryo”,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HiraKakuPro-W3","Yu Gothic","MS PGothic",Osaka,sans-serif;
  color: #444444;
}

/* @end */

/* @group 1-02:clearfix */

.sheet:after,
.bar:after,
.header__nav:after,
.footer__nav ul:after,
.breadcrumbs__nav ol:after,
.nav--eql:after,
.pageturn:after,
.pagenation:after,
.form div:after,
.gridbox:after,
.listbox:after,
.form div:after,
.position-right:after,
.text-right:after,
.position-left:after,
header:after,
.header-layout:after,
.contents:after,
.container:after,
footer:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  line-height: 0;
  font-size: 0.1em;
  overflow: hidden;
}

/* @end */

/* @group 1-03:Typography */

/* @group heading */

h1 {
  font-size: 36px;
  font-size: 1.6rem;
  font-weight: bold;
margin: 20px auto 20px;
  margin-bottom: 36px;
}

h2 {
  clear: both;
  font-size: 24px;
  font-size: 2.4rem;
  margin: 45px 0 25px;
  padding: 4px 0;
}

h3 {
  font-size: 18px;
  font-size: 1.8rem;
  margin-bottom: 10px;
}

h4 {
  font-size: 16px;
  font-size: 1.6rem;
  margin-bottom: 6px;
  text-align: left;
  font-weight: bold;
}

h5 {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 4px;
  font-weight: bold;
  text-align: left;
}

h6 {
  font-size: 12px;
  font-size: 1.2rem;
  margin-bottom: 2px;
  font-weight: bold;
  text-align: left;
}

/* @end */

/* @group background-color */

.bg-red {
  background-color: #f36568;
  color: #fff;
}

.bg-orange {
  background-color: #f8ad56;
  color: #fff;
}

.bg-yellow {
  background-color: #f4cd1d;
  color: #fff;
}

.bg-green {
  background-color: #45ce67;
  color: #fff;
  box-shadow: 0 1px 0 0 #39bc5a;
}

.bg-skyblue {
  background-color: #64c9dc;
  color: #fff;
}

.bg-blue {
  background-color: #537ee0;
  color: #fff;
}

.bg-violet {
  background-color: #a273e2;
  color: #fff;
}

/* @end */

/* @group text-color */

.text-red {
  color: #c23438;
}

.text-orange {
  color: #cb7435;
}

.text-yellow {
  color: #dba748;
}

.text-green {
  color: #299e47;
}

.text-skyblue {
  color: #4a95bb;
}

.text-blue {
  color: #364e9d;
}

.text-violet {
  color: #7036b2;
}

/* @end */

/* @end */

/* @group 1-04:config */

p {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.6;
  margin-bottom: 18px;
  margin-bottom: 1.8rem;
}

.small {
  font-size: 93%;
}

.small-x{
  font-size: 85%;
}

.small-xx{
  font-size: 64%;
}

.large{
  font-size: 124%;
}

.large-x{
  font-size: 136%;
}

.large-xx{
  font-size: 154%;
}

a {
  color: #4467bc;
  text-decoration: none;
}

hr {
  margin: 20px 0 20px;
  padding: 0;
  border: 0;
  border-top: 1px solid #ccc;
}

/* @end */

/* @end */

/* @group 2:layout */

/* ======================================================*/

/* @group 2-01:base-layout */

body,
header,
.contents,
footer {
  text-align: center;
  width: 100%;
  margin: 0 auto;
}

.contents{
  padding-bottom: 40px;
}
.container {
  padding: 0 20px;
}

.main,
.side {
  position: relative;
}

p {
  text-align: left;
}

/* @group status */

.position-left,
.position-right,
.position-center,
img.position-left,
img.position-right {
  width: 100%;
  display: block;
}

.screen {
  display: none; /* モバイルサイズでは見えない状態 */
}

/* @end */

/* @end */

/* @group 2-02:grid */

.gridbox {
  clear: both;
}

/* @group gridbox(div) */

.gridbox > div {
  display: block;
  position: relative;
}

.main .gridbox div+div {
  margin-bottom: 20px;
}

.main .gridbox:last-child{
  margin-bottom: 0;
}

.gridbox div p:last-child {
  margin-bottom: 0;
}

/* @end */

/* @group lo-list(li) */

.listbox li {
  margin-bottom: 20px;
  font-size: 14px;
  font-size: 1.4rem;
}

.listbox li>a {
  display: block;
}

/* @end */

/* @group nomargin */

.gridbox.gridbox--nomargin {
  margin-bottom: 0;
}

.gridbox.gridbox--nomargin>div {
  margin: 0;
}

/* @end */

/* @end */

/* @end */

/* @group 3:base-components */

/* ======================================================*/

/* @group 3-01:header */

/* @group bar */

.bar {
  width: 100%;
  background-color: #555;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  z-index: 1000;
  text-align: center;
}

.bar__h1 img {
  margin: 0;
  height: auto;
  max-height: 30px;
}


/* @end */

.header__logo {
  text-align: center;
  width: 50%;
  margin: 20px auto;
  font-size: 20px;
  font-size: 2rem;
}

/* @end */

/* @group 3-02:footer */

.footer__logo {
  padding: 10px 0;
  display: block;
  margin-bottom: 0;
  text-align: center;
}

.footer__logo img{
  height: 40px;
}

.footer__data {
  margin-bottom: 20px;
  width: auto;

}

.footer__data address {
  font-style: normal;
  font-weight: bold;
  font-size: 18px;
  font-size: 1.8rem;
  display: inline-block;
}

.footer__data address a {
  color: #444;
  display: block;
  padding: 6px;
}

.copyright {
  font-size: 10px;
  font-size: 1rem;
  clear: both;
  display: block;
  width: 100%;
  margin-bottom: 4;
  text-align: center;
}

/* @end */

/* @group 3-03:side */

/* @group logo */

.sidebar__logo {
  margin: 0;
  text-align: center;
}

.sidebar__logo h1 {
  margin: 0;
  padding: 20px;
}

.sidebar__logo a {
  display: block;
}

.sidebar__logo img {
  height: 100px;
}

/* @end */

/* @end */

/* @group 3-04:navigation */

/* @group header__nav/footer__nav */

.header__nav li,
.footer__nav li {
  text-align: left;
  float: left;
}

.header__nav span {
  display: block;
  color: #777;
  font-size: 10px;
  font-size: 1rem;
}

.header__nav a,
.footer__nav a {
  display: block;
  padding: 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* @end */

/* @group bar__nav */

.bar__nav {
  padding: 3px 20px 0;
  margin: auto;
}

.bar__nav li {
  float: left;
  margin: 0;
  font-size: 14px;
  margin-left: 10px;
}

.bar__nav a {
  padding: 6px 10px 4px;
  display: block;
  color: #fff;
  border-bottom: 2px solid rgba(00,00,00,0);
}

.bar__nav a:hover {
  border-bottom: 2px solid;
}

a.sitebtn {
  padding: 4px 12px 2px;
  background-color: rgba(255,255,255,0.5);
  -webkit-border-radius: 3px;
  border-radius: 3px;
  color: #555;
}

a.sitebtn:hover {
  border-bottom: 2px solid rgba(00,00,00,0);
  background-color: rgba(255,255,255,0.7);
}

/* @end */

/* @group sidemenu */

.sidebar__nav{
  border-top: 1px solid #ddd;
}
.sidebar__nav li {
  border-bottom: 1px solid #ddd;
  text-align: left;
}

.sidebar__nav li span {
  margin: 0 6px;
  font-size: 10px;
  font-size: 1rem;
  color: #777;
}

.sidebar__nav li a {
  display: block;
  position: relative;
  padding: 16px;
}

.sidebar__nav li a:hover {
  background-color: #f5f5f5;
}

.sidebar__nav li ul {
  border-top: none;
  border-bottom: none;
  margin-top: -4px;
  margin-bottom: 0;
}

.sidebar__nav li ul li {
  text-indent: 1em;
  border-bottom: none;
}

.sidebar__nav li ul li a {
  font-size: 12px;
  font-size: 1.2rem;
  display: block;
  position: relative;
  padding: 10px 0;
}

/* @end */

/* @group breadcrumbs */

.breadcrumbs__nav {
  display: none;
}

/* @end */

/* @group pageturn */

.pageturn {
  border: 1px solid #ccc;
  -webkit-border-radius: 4px;
  border-radius: 4px;
  margin-bottom: 20px;
}

.pageturn p {
  margin-bottom: 0;
}

.pageturn a {
  display: block;
  padding: 8px 16px;
}

.pageturn a:hover {
  background-color: #eee;
}

.pageturn p:first-child a {
  width: 49.999%;
  float: left;
  text-align: left;
  -webkit-border-radius: 4px 0 0 4px;
  border-radius: 4px 0 0 4px;
}

.pageturn p:last-child a {
  width: 49.999%;
  float: right;
  text-align: right;
  -webkit-border-radius: 0 4px 4px 0;
  border-radius: 0 4px 4px 0;
}

/* @end */


/* @group pagenation */

.pagination {
  margin: 30px auto;
  text-align: center;
  border-top: 1px solid #90a7d1;
}

.pagination .position-left{
  width: 100px;  
  float: left;
}

.pagination div.position-right{
  width: 100px;   
  float: right;
}


.pagination a{
  padding: 8px 20px 6px;
  display: block;
  font-size: 20px;
  color: #90a7d1;
}

.pagination a:hover{
  background-color:#eee;
}

.pagination .first,
.pagination .next{
  float: left;
}

.pagination .prev,
.pagination .last{
  float: right;
}

/* @end */

/* @end */

/*

 @end */

/* @group in-components */

/* ======================================================*/

/* @group btn */

.btn {
  padding: 8px 20px 6px;
  -webkit-box-shadow: 0 1px 0 0 #ddd;
  box-shadow: 0 1px 0 0 #ddd;
  background-color: #eee;
  -webkit-border-radius: 3px;
  border-radius: 3px;
  border: none;
  color: #555;
  font-size: 14px;
  font-size: 1.4rem;
  display: inline-block;
  margin: 0 0 10px 0;
  text-align: center;
  cursor: pointer;
}

.btn:hover,
.btn:focus {
  background-color: #ddd;
  cursor: pointer;
  color: #555;
}

.btn-nopress,
.btn-nopress:hover {
  border: 1px solid #ddd;
  background-color: transparent;
  -webkit-box-shadow: none;
  box-shadow: none;
  color: #bbb;
  cursor: default;
  top: 0;
}

.btn-nopress:hover {
  cursor: default;
}

.btn-big {
  font-size: 124%;
  padding: 14px 10px 12px;
}

.btn-small {
  font-size: 0.6em;
  padding: 6px 16px 4px;
}

.btn-full{
  width: 100%;
}

.btn-ico {
  padding: 6px 20px 4px 16px;
}

.btn-center {
  width: 100%;
  margin: auto;
  padding: 16px;
  font-size: 1.4em;
}

.btn-center.btn-ico {
  padding: 10px 20px 8px;
}

.btn-ico:before {
  position: relative;
  content: "▶";
  font-size: 8px;
  margin-right: 5px;
  top: -1px;
  color: #999;
}

.btn-ico-wht:before {
  color: #fff;
}

/* @group color */

.btn-red {
  background-color: #f36568;
  color: #fff;
  box-shadow: 0 1px 0 0 #d8575a;
}

.btn-red:hover {
  background-color: #d8575a;
  color: #fff;
}

.btn-orange {
  background-color: #f8ad56;
  color: #fff;
  box-shadow: 0 1px 0 0 #e5864f;
}

.btn-orange:hover {
  background-color: #e5864f;
  color: #fff;
}

.btn-yellow {
  background-color: #f4cd1d;
  color: #fff;
  box-shadow: 0 1px 0 0 #e5b052;
}

.btn-yellow:hover {
  background-color: #e5b052;
  color: #fff;
}

.btn-green {
  background-color: #45ce67;
  color: #fff;
  box-shadow: 0 1px 0 0 #32af51;
}

.btn-green:hover {
  background-color: #32af51;
  color: #fff;
}

.btn-skyblue {
  background-color: #64c9dc;
  color: #fff;
  box-shadow: 0 1px 0 0 #53a5cf;
}

.btn-skyblue:hover {
  background-color: #53a5cf;
  color: #fff;
}

.btn-blue {
  background-color: #537ee0;
  color: #fff;
  box-shadow: 0 1px 0 0 #4d69c4;
}

.btn-blue:hover {
  background-color: #4d69c4;
  color: #fff;
}

.btn-violet {
  background-color: #a273e2;
  color: #fff;
  box-shadow: 0 1px 0 0 #8650d0;
}

.btn-violet:hover {
  background-color: #8650d0;
  color: #fff;
}

/* @end */

/* @end */

/* @group gotop */

.gotop {
  position: fixed;
  bottom: 0;
  width: 100%;
  text-align: center;
  z-index: 9999;
}

.gotop p {
  margin-bottom: 0;
}

.gotop a {
  margin: auto;
  padding: 4px;
  background-color: rgba(00,00,00, 0.06);
  display: block;
  color: #fff;
}

.gotop a:hover {
  background-color: rgba(00,00,00,0.1);
  color: #fff;
}

.gotop__icon {
  font-size: 26px;
  font-weight: bold;
  position: relative;
  display: inline-block;
  top: 0px;
  left: -2px;
  -moz-transform: rotate( -90deg );
  /* Firefox */
  -webkit-transform: rotate( -90deg);
  /*Chrome,Safari */
  -o-transform: rotate( -90deg );
  /*Opera */
  -ms-transform: rotate( -90deg );
  /* IE */
  transform: rotate( -90deg );
/* CSS3 */
}

.gotop a:hover .gotop__icon {
  top: -1px;
}

.gotop__txt {
  display: none;
}

/* @end */

/* @group card */

/* @end */

/* @group +Goodies */

/* @group +tag */

.tag {
  background-color: rgba(00,00,00,0.1);
  padding: 1px 14px;
  margin: 0 6px 0 0;
  display: inline-block;
  -webkit-border-radius: 4px;
  border-radius: 4px;
}

.tag.small {
  padding: 1px 8px;
  -webkit-border-radius: 3px;
  border-radius: 3px;
}

.tag.bg-red {
  background-color: #f36568;
}

.tag.bg-orange {
  background-color: #f8ad56;
}

.tag.bg-yellow {
  background-color: #f4cd1d;
}

.tag.bg-green {
  background-color: #45ce67;
}

.tag.bg-skyblue {
  background-color: #64c9dc;
}

.tag.bg-blue {
  background-color: #537ee0;
}

.tag.bg-violet {
  background-color: #a273e2;
}

/* @end */

/* @group +bullet */

.sidebar__blt li a:before {
  position: relative;
  content: "▶";
  font-size: 8px;
  margin-right: 6px;
  top: -2px;
}

.sidebar__blt li ul li a:before {
  content: ">";
  font-weight: bold;
  margin-right: 5px;
}

/*

 @end */

/* @group +linkspeed */

nav li a,
.gotop a,
.btn,
.pageturn a,
.listbox li>a {
  -webkit-transition: background 0.6s ease;
  -moz-transition: background 0.6s ease;
  -ms-transition: background 0.6s ease;
  -o-transition: background 0.6s ease;
  transition: background 0.6s ease;
}

nav li a:hover,
.gotop a:hover,
.btn:hover,
.pageturn a:hover,
.listbox li>a:hover {
  -webkit-transition: background 0.2s ease;
  -moz-transition: background 0.2s ease;
  -ms-transition: background 0.2s ease;
  -o-transition: background 0.2s ease;
  transition: background 0.2s ease;
}

/* @end */

/* @group +list */

.list {
  margin-top: 20px;
  margin-bottom: 40px;
}

.list li {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 14px;
}

/* @end */

/* @group googlemap */

.google-maps {
  position: relative;
  padding-bottom: 75%;
  height: 0;
  overflow: hidden;
}

.google-maps iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

/* @end */


/* @end */


/* @end */

/* @group in-question */

/* ======================================================*/

.QA {
  margin-bottom: 40px;
}

.que {
  font-weight: bold;
  border-bottom: 1px dotted #aaa;
}

.ans {
  clear: both;
}

.QA p {
  padding-left: 1.8em;
}

.que span,
.ans span {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  display: inline-block;
  margin-left: -1.6em;
  width: 1.6em;
}

/* @group QA-border */

.QA-border {
  border: 1px solid #ccc;
  background-color: #fff;
  -webkit-border-radius: 4px;
  border-radius: 4px;
}

.QA-border p {
  padding: 20px 20px 20px 40px;
  margin: 0;
}

.QA-border .que {
  background-color: #eee;
  border: none;
  -webkit-border-radius: 4px 4px 0 0;
  border-radius: 4px 4px 0 0;
}

/* @end */

/* @group QA-list */

.QA-list li {
  font-size: 16px;
  font-size: 1.6rem;
  display: block;
  padding: 16px 10px 16px 46px;
  border-bottom: 1px dotted #999;
}

.QA-list li:last-child {
  margin-bottom: 0;
}

.QA-list li:hover {
  background-color: #eee;
  cursor: pointer;
}

.QA-list li a {
  color: #333;
  display: block;
}

.QA-list li span {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  display: inline-block;
  margin-left: -2.4em;
  width: 2.4em;
}

/* @end */

/* @end */

/* @group in-tables */

/* ======================================================*/

.tablebox {
  width: 100%;
  overflow: auto;
  margin:20px 0 40px;
}

.tablebox table {
  border-collapse: collapse;
  font-size: 14px;
  font-size: 1.4rem;
  width: 100%;
}

.tablebox th,
.tablebox td {
  min-width: 5em;
  width: auto;
  padding: 10px;
}

.tablebox::-webkit-scrollbar {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
}

.tablebox::-webkit-scrollbar-thumb {
  border-radius: 12px;
  border: 3px solid #fff;
  background-color: rgba(0, 0, 0, 0.1);
}

/* @group tabletype */

.table {
  border: 1px solid #ddd;
}

.table th,
.table td {
  border-right: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  padding: 12px 10px 10px;
  vertical-align: middle;
}

.table th{
  background-color: #f1f1f1;
}

.table--borderbtm{
  border: none;
  border-top: 1px solid #ddd;
}

.table--borderbtm th,
.table--borderbtm td{
  background-color: transparent;
  border-right: none;
}

.table--stripe tr:nth-child(even) {
  background-color: #f1f1f1;
}

.table--stripe tr:nth-child(odd) th {
  background-color: transparent;
}

th.th--label {
  background-color: #999;
  color: #fff;
}

.table--change{
  border-right: none;
}
.table--change th,
.table--change td{
  display: block;
  word-break: break-all;
  overflow: auto;
  width: 100%;
}

.table--change th{
  border-top: 2px solid #ccc;
}

/* @end */

/* @group bill */

.bill-header {
  margin-bottom: 60px;
}

.bill-header h1 {
  font-size: 24px;
  padding: 10px 0 0;
  border-top: 1px solid #ddd;
  color: #333;
  font-weight: bold;
}

.bill-header h2 {
  background-image: none;
  font-weight: normal;
  font-size: 14px;
  padding: 0 0 6px;
  border: none;
  margin-bottom: 20px;
  border-bottom: 1px solid #ddd;
}

.bill-person p {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 20px;
}

.bill-person span {
  float: right;
  font-weight: normal;
}

.bill-data th,
.bill-data td {
  font-size: 12px;
  padding: 6px 8px;
  display: block;
}

.bill-date {
  text-align: right;
  font-size: 12px;
}

.bill-from {
  text-align: left;
}

.bill-from.position-right {
  text-align: left;
}

.bill-company {
  font-size: 14px;
  font-weight: bold;
  margin: 0;
}

.bill-companydata {
  font-size: 12px;
  line-height: 1.4;
}

/* @group table-bill */

.table-bill {
  margin-bottom: 50px;
  border: none;
}

.bill-total {
  background-color: #eee;
}

.table-bill caption {
  font-size: 16px;
  text-align: left;
  padding: 4px 10px;
  font-weight: bold;
  letter-spacing: 0.2em;
  background-color: #eee;
  border-bottom: 1px solid #ddd;
}

.table-bill th,
.table-bill td {
  display: block;
  width: 100%;
  padding: 6px 10px;
}

.table-bill .bill-total th,
.table-bill .bill-total td {
  padding: 16px 10px;
}

.table-bill th {
  text-align: left;
}

.table-bill td {
  text-align: right;
}

.table-bill tfoot {
  border-top: 4px solid #aaa;
  font-size: 130%;
}

/* @end */

/* @end */

/* @end */

/* @group in-forms */

/* ======================================================*/

.form {
  font-size: 16px;
  font-size: 1.6rem;
  text-align: left;
}

.form div {
  clear: both;
  margin-bottom: 30px;
}

.form label {
  display: block;
  width: 100%;
}

.form--simple label:before,
.form--column label:before {
  content: "▼";
  font-size: 8px;
  margin-right: 4px;
  position: relative;
  top: -4px;
  color: #ccc;
}

/* @group option */

.req {
  background-color: rgba(00, 00, 00, 0.08);
  padding: 10px;
  margin-bottom: 30px;
    border-radius: 3px;
}

.required,
.option {
  color: #fff;
  font-size: 10px;
  margin: 0 6px 3px 6px;
  display: inline-block;
  background-color: #ccc;
  padding: 3px 7px 2px;
  -webkit-border-radius: 3px;
  border-radius: 3px;
  position: relative;
  top: -4px;
}

.req .required,
.req .option{
  top: 0;
}

.required {
  background-color: #c74e58;
}

.option {
  background-color: #aaa;
}

/* @end */

/* @end */



/* ======================================================

	for screen (400px-768px)

   ====================================================== */

@media print, screen and (min-width: 420px) {

/* @group 2-01:base-layout */



/* @group status */

.position-center {
  text-align: center !important;
  margin: auto;
}

.position-right {
  float: right;
  width: auto;
}

.position-left {
  float: left;
  width: auto;
}

.text-center{
  text-align: center;
}
.text-right{
  text-align: right;
  float: right;
  margin-left: 10px;
}

.text-left{
  text-align: left;
}

img.position-right {
  width: 50%;
  margin-left: 30px;
  margin-bottom: 1.6em;
}

img.position-left {
  width: 50%;
  margin-right: 30px;
  margin-bottom: 1.6em;
}

.position-clear {
  clear: both;
}



/* @end */

/* @end */

/* @group 2-03:grid */



/* @group gridbox(div) */

/* 各種レイアウトに使用する、divを並べるためのグリッドシステム */

.gridbox > div {
  margin-left: 3%;
  float: left;
}

.gridbox > div:first-child {
  margin-left: 0;
}


.grid-2-1,
.grid-4-2 {
  width: 48.5%
}

.grid-3-1 {
  width: 31.333%;
}

.grid-3-2 {
  width: 65.666%;
}

.grid-4-1 {
  width: 22.75%;
}

.grid-4-3 {
  width: 74.25%;
}

.grid-5-1 {
  width: 17.6%;
}

.grid-5-2 {
  width: 38.2%;
}

.grid-5-3,
.grid-5-1+.grid-5-3 {
  width: 58.8%;
}

.grid-5-4 {
  width: 79.4%;
}
.grid-3-1:nth-child(2n+1),
.grid-4-1:nth-child(2n+1),
.grid-5-1:nth-child(3n+1),
.grid-5-3+.grid-5-1 {
  margin-left: 3%;
}

/* @end */

/* @group lo-list(li) */

/* リストをボックス化するためのグリッドシステム。等分になる。 */

.list-2 li,
.list-3 li,
.list-4 li,
.list-5 li {
  float: left;
  margin-left: 3%;
}

.list-2 li {
  width: 48.5%;
}

.list-3 li {
  width: 31.333%;
}

.list-4 li {
  width: 22.75%;
}

.list-5 li {
  width: 17.6%;
}

.list-2 li:nth-child(odd),
.list-3 li:nth-child(odd),
.list-4 li:nth-child(odd),
.list-5 li:nth-child(odd) {
  margin-left: 0;
}

.list-3 li:nth-child(odd),
.list-4 li:nth-child(odd), 
.list-5 li:nth-child(odd) {
  margin-left: 3%;
}

.list-3 li:nth-child(3n+1),
.list-4 li:nth-child(4n+1),
.list-5 li:nth-child(5n+1) {
  margin-left: 0;
}

/* @end */

/* @group nomargin */

.gridbox--nomargin .grid-2-1 {
  width: 49.999%;
}

.gridbox--nomargin .grid-3-1 {
  width: 33.333%;
}

.gridbox--nomargin .grid-4-1 {
  width: 24.999%;
}

/* @end */

/* @group centered */

.gridbox > div.grid-center {
  float: none;
  clear: both;
  margin: 0 auto 20px;
}

.grid-center {
  text-align: center;
  margin: auto;
}

.center-90 {
  width: 90%;
}

.center-80 {
  width: 80%;
}

.center-70 {
  width: 70%;
}

.center-60 {
  width: 60%;
}

.center-50 {
  width: 50%;
}

.center-40 {
  width: 40%;
}

.center-30 {
  width: 30%;
}

.center-20 {
  width: 20%;
}

.center-10 {
  width: 10%;
}

/* @end */

/* @end */




/* @group 3-04:navigation */

/* @group navigation grid */


.nav--eql li a {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
}

.nav--2 li {
  width: 49.98%;
}

.nav--3 li {
  width: 33.32%;
}

.nav--4 li,
.nav--5 li,
.nav--6 li,
.nav--7 li,
.nav--8 li {
  width: auto;
  display: inline-block;
}

/* @end */

/* @end */


}




/* ======================================================

	for screen (over:768px)

   ====================================================== */

@media print, screen and (min-width: 768px) {

/* @group 2:layout */

/* ======================================================*/

/* @group 2-01:base-layout */

.container {
  width: 100%;
  max-width: 1100px;  /*任意で別途style.cssへ */
  margin: auto;
}

/* @group pattern */

/* window-fullsize */

.container--full {
  max-width: 100%;
  min-width: 100%;
  padding: 0;
}

/* @end */

/* @group status */

img.position-right {
  width: 30%;
  margin-left: 30px;
  margin-bottom: 1.6em;
}

img.position-left {
  width: 30%;
  margin-right: 30px;
  margin-bottom: 1.6em;
}
.screen {
  display: block;/* PCのみで見える状態 */
}


/* @end */

/* @end */

/* @group 2-02:main & sidebar */

/* @group base */

.main {
  flex: 1;
  box-flex: 1;
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -ms-flex: 1;
  width: 100%;
}

.sidebar {
  text-align: left;
}

.sidebar--left,
.sidebar--right,
.bothsidebar,
.doublesidebar--left,
.doublesidebar--right {
  display: box;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
}

/* @group 1side */

.sidebar--left > .main {
  box-ordinal-group: 2;
  -webkit-box-ordinal-group: 2;
  -moz-box-ordinal-group: 2;
  -ms-flex-order: 2;
  order: 2;
  width: 72%;
}

.sidebar--left > .sidebar {
  box-ordinal-group: 1;
  -webkit-box-ordinal-group: 1;
  -moz-box-ordinal-group: 1;
  -ms-flex-order: 1;
  order: 1;
  width: 24%;
  margin-right: 4%;
}

.sidebar--right > .main {
  box-ordinal-group: 1;
  -webkit-box-ordinal-group: 1;
  -moz-box-ordinal-group: 1;
  -ms-flex-order: 1;
  order: 1;
  width: 72%;
}

.sidebar--right > .sidebar {
  box-ordinal-group: 2;
  -webkit-box-ordinal-group: 2;
  -moz-box-ordinal-group: 2;
  -ms-flex-order: 2;
  order: 2;
  width: 24%;
  margin-left: 4%;
}

/* @end */

/* @group 2side */

.bothsidebar > .main {
  box-ordinal-group: 2;
  -webkit-box-ordinal-group: 2;
  -moz-box-ordinal-group: 2;
  -ms-flex-order: 2;
  order: 2;
  width: 66%;
}

.bothsidebar > .sidebar--primary {
  box-ordinal-group: 1;
  -webkit-box-ordinal-group: 1;
  -moz-box-ordinal-group: 1;
  -ms-flex-order: 1;
  order: 1;
  width: 15%;
  margin-right: 2%;
}

.bothsidebar > .sidebar--secondary {
  box-ordinal-group: 3;
  -webkit-box-ordinal-group: 3;
  -moz-box-ordinal-group: 3;
  -ms-flex-order: 3;
  order: 3;
  width: 15%;
  margin-left: 2%;
}

.doublesidebar--left > .main {
  box-ordinal-group: 3;
  -webkit-box-ordinal-group: 3;
  -moz-box-ordinal-group: 3;
  -ms-flex-order: 3;
  order: 3;
  width: 66%;
}

.doublesidebar--left > .sidebar--primary {
  box-ordinal-group: 1;
  -webkit-box-ordinal-group: 1;
  -moz-box-ordinal-group: 1;
  -ms-flex-order: 1;
  order: 1;
  width: 15%;
  margin-right: 2%;
}

.doublesidebar--left > .sidebar--secondary {
  box-ordinal-group: 2;
  -webkit-box-ordinal-group: 2;
  -moz-box-ordinal-group: 2;
  -ms-flex-order: 2;
  order: 2;
  width: 15%;
  margin-right: 2%;
}

.doublesidebar--right > .main {
  box-ordinal-group: 1;
  -webkit-box-ordinal-group: 1;
  -moz-box-ordinal-group: 1;
  -ms-flex-order: 1;
  order: 1;
  width: 66%;
}

.doublesidebar--right > .sidebar--primary {
  box-ordinal-group: 2;
  -webkit-box-ordinal-group: 2;
  -moz-box-ordinal-group: 2;
  -ms-flex-order: 2;
  order: 2;
  width: 15%;
  margin-left: 2%;
}

.doublesidebar--right > .sidebar--secondary {
  box-ordinal-group: 3;
  -webkit-box-ordinal-group: 3;
  -moz-box-ordinal-group: 3;
  -ms-flex-order: 3;
  order: 3;
  width: 15%;
  margin-left: 2%;
}

/* @end */

/* @group side-fixed */

.sidebar.sidebar--fixed{
  width: 25%; /* 任意で別途style.cssへ */
}

.sidebar--fixed__elements{
  position: fixed;
  width: 25%; /* ↑と同じ数値 */

}

/* @end */

/* @end */

/* @end */

/* @group 2-03:grid */

/* @group gridbox(div) */

/* 各種レイアウトに使用する、divを並べるためのグリッドシステム */

.main .gridbox {
  margin-bottom: 20px;
}

.main .gridbox.gridbox--nomargin,
.main .gridbox div {
  margin-bottom: 0;
}

.gridbox > div {
  margin-left: 3%;
  float: left;
}

.gridbox > div.position-right {
  float: right;
}

.gridbox > div:first-child {
  margin-left: 0;
}

.grid,
.grid-1
.grid-2-2,
.grid-3-3,
.grid-4-4,
.grid-5-5 {
  width: 100%;
  clear: both;
}

.grid-2-1,
.grid-4-2 {
  width: 48.5%
}

.grid-3-1 {
  width: 31.333%;
}

.grid-3-2 {
  width: 65.666%;
}

.grid-4-1 {
  width: 22.75%;
}

.grid-4-3 {
  width: 74.25%;
}

.grid-5-1 {
  width: 17.6%;
}

.grid-5-2 {
  width: 38.2%;
}

.grid-5-3,
.grid-5-1+.grid-5-3 {
  width: 58.8%;
}

.grid-5-4 {
  width: 79.4%;
}

.grid-3-1:nth-child(2n+1),
.grid-4-1:nth-child(2n+1),
.grid-5-1:nth-child(3n+1),
.grid-5-3+.grid-5-1 {
  margin-left: 3%;
}



/* @end */

/* @group lo-list(li) */

/* リストをボックス化するためのグリッドシステム。等分になる。 */

.list-2 li,
.list-3 li,
.list-4 li,
.list-5 li {
  float: left;
  margin-left: 3%;
}

.list-2 li {
  width: 48.5%;
}

.list-3 li {
  width: 31.333%;
}

.list-4 li {
  width: 22.75%;
}

.list-5 li {
  width: 17.6%;
}

.list-2 li:nth-child(odd),
.list-3 li:nth-child(odd),
.list-4 li:nth-child(odd),
.list-5 li:nth-child(odd) {
  margin-left: 0;
}

.list-3 li:nth-child(odd),
.list-4 li:nth-child(odd), 
.list-5 li:nth-child(odd) {
  margin-left: 3%;
}

.list-3 li:nth-child(3n+1),
.list-4 li:nth-child(4n+1),
.list-5 li:nth-child(5n+1) {
  margin-left: 0;
}

/* @end */

/* @group nomargin */

.gridbox--nomargin .grid-2-1 {
  width: 49.999%;
}

.gridbox--nomargin .grid-3-1 {
  width: 33.333%;
}

.gridbox--nomargin .grid-4-1 {
  width: 24.999%;
}

/* @end */

/* @group centered */

.gridbox > div.grid-center {
  float: none;
  clear: both;
  margin: 0 auto 20px;
}

.grid-center {
  text-align: center;
  margin: auto;
}

.center-90 {
  width: 90%;
}

.center-80 {
  width: 80%;
}

.center-70 {
  width: 70%;
}

.center-60 {
  width: 60%;
}

.center-50 {
  width: 50%;
}

.center-40 {
  width: 40%;
}

.center-30 {
  width: 30%;
}

.center-20 {
  width: 20%;
}

.center-10 {
  width: 10%;
}

/* @end */

/* @end */

/* @end */

/* @group 3:base-components */

/* ======================================================*/

/* @group 3-01:header */

/* @group bar */

.bar {
  position: absolute;
  top: 0;
}

.bar__h1 {
  margin: 4px 10px 0;
  padding: 3px 0;
  display: block;
  font-size: 14px;
  font-size: 1.4rem;
}

.bar__h1 img {
  margin: 0;
  height: auto;
  max-height: 20px;
}

.bar+.container{
  margin-top: 40px;
}
/* @end */


.header__logo {
  text-align: left;
  width: auto;
  margin: 10px 0;
}

.header__logo img{
  height: 20px;
}

/* @end */




/* @group 3-02:footer */

.footer__data {
  margin-bottom: 0px;

}

.footer__data p {
  margin-bottom: 10px;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
  text-align: left;
}

.footer__data strong {
  display: inline-block;
  font-size: 14px;
  margin-bottom: 2px;
}

.footer__data address {
  font-style: normal;
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 0;
  padding: 0;
}

.footer__data address a {
  padding: 0px;
}


/* @end */

/* @group 3-03:side */

/* @group logo */

.sidebar__logo h1 {
  margin: 20px 0 20px;
  padding: 20px;
}

.sidebar__logo img {
  height: 120px;
}

/* @end */

/* @end */

/* @group 3-04:navigation */

/* @group header__nav */

.header__nav li,
.footer__nav li {
  width: auto;
  text-align: center;
  border-bottom: none;
}

.header__nav li span {
  margin-left: 0;
  border-left: none;
  border-bottom: none;
}

/* @end */

/* @group breadcrumbs */

.breadcrumbs__nav {
  display: block;
  width: 100%;
  text-align: center;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}

.breadcrumbs__nav ol {
  width: 100%;
  max-width: 1100px; /* 任意でstyle.cssへ */
  margin: auto;
  padding: 0 0px;
}

.breadcrumbs__nav li {
  float: left;
  font-size: 12px;
  font-size: 1.2rem;
  color: #aaa;
}

.breadcrumbs__nav li a {
  color: #444;
  padding: 16px 12px;
  display: inline-block;
}

.breadcrumbs__nav li:after {
  content: ">";
  font-size: 10px;
  position: relative;
  top: -2px;
}

.breadcrumbs__nav li:last-child a {
  color: #aaa;
}

.breadcrumbs__nav li:last-child:after {
  content: " ";
}

/* @end */

/* @group pagenation */

.pagenation {
  text-align: center;
  margin: 20px auto;
  border: none;
}

.pagenation ol {
  display: inline-block;
  *display: inline;
  zoom: 1;
  margin: 0 -5px;
}

.pagenation li {
  *display: inline;
  zoom: 1;
}

.pagenation p {
  display: inline-block;
}

.pagenation p {
  width: 7em;
  margin: 0;
}

.pagenation p a,
.pagenation li a {
  color: #333;
  padding: 10px 20px;
}

.pagenation p a:hover {
  background-color: transparent;
  color: #cc0000;
}

/* @end */

/* @group navigation grid */

.nav--eql {
  width: 100%;
}

.nav--eql li {
  overflow: hidden;
  float: left;
  border-right: 1px solid #ccc;
}

.nav--eql li:first-child {
  border-left: 1px solid #ccc;
}

.nav--eql li a {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
}

.nav--2 li {
  width: 49.98%;
}

.nav--3 li {
  width: 33.32%;
}

.nav--4 li {
  width: 24.99%;
}

.nav--5 li {
  width: 20%;
}

.nav--6 li {
  width: 16.66%;
}

.nav--7 li {
  width: 14.28%;
}

.nav--8 li {
  width: 12.5%;
}

/* @end */

/* @end */

/* @end */

/* @group in-tables */

.table--change{
  display: table;
}
.table--change th,
.table--change td{
  display: table-cell;
  width: auto;
}

.table--change th{
  border-top: none;
}

/* @end */

/* @group in-componetns */

/* ======================================================*/

/* @group in-forms */

.form--column label {
  display: block;
  width: 27%;
  float: left;
  margin-right: 8px;
  margin-top: 6px;
}

.form--column label:before {
  display: none;
}

.form--column input,
.form--column textarea {
  width: 71%;
  float: left;
}

.form--column .form-inline input,
.form--column .form-inline .add-on{
  float: none;
}

.form--column .grid-center input{
  float: none;
  display: block;
  margin: auto;
  width: 50%;
}

/* @end */

/* @group in-tables */

/* @group bill */

.table-bill th,
.table-bill td {
  display: table-cell;
  width: 100%;
  border-right: none;
  padding: 8px 10px;
}

.table-bill th {
  text-align: left;
  border-bottom: 1px solid #ccc;
  width: 50%;/*任意 */
}

.table-bill td {
  text-align: right;
  border-bottom: 1px solid #ccc;
  width: 50%;/*任意 */
}

.bill-data th,
.bill-data td {
  font-size: 12px;
  padding: 8px;
  display: table-cell;
}

/* @end */

/* @end */


/* @end */

}



.y-guide{
margin: 100px auto 20px;    
}


.y-box {
display: flex;
width: 100%;
flex-wrap: wrap;    
}

.y-box div {
width: 348px;
margin: 20px 0 10px;
}


@media print, screen and (max-width: 800px) {

.swiper-container {
    width: 100%!important;
    /* height: 100%; */
    height: auto;
    margin: 20px auto;
}
    
.y-box {
display: flex;
width: 100%;
flex-wrap: wrap; 
justify-content: center;
}    
}
