/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

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

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

a {
  text-decoration: none;
}

@font-face {
  font-family: "icomoon";
  src: url("../fonts/icomoon.ttf?wbeatq") format("truetype"), url("../fonts/icomoon.woff?wbeatq") format("woff"), url("../fonts/icomoon.svg?wbeatq#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
}
[class^=fa-], [class*=" fa-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.fa-times-circle:before {
  content: "\f057";
}

.fa-chevron-circle-down:before {
  content: "\f13a";
}

html {
  font-size: 62.5%;
}

body {
  font-size: 1.6rem;
  line-height: 1.6;
  background: #fff;
}

.wrapper {
  max-width: 96rem;
  margin: auto;
}

body.leftSidebar .wrapper,
body.rightSidebar .wrapper {
  max-width: 96rem;
  display: -webkit-flex;
  display: flex;
  justify-content: space-between;
  margin: auto;
}
body.leftSidebar .wrapper main,
body.rightSidebar .wrapper main {
  width: 71rem;
}
body.leftSidebar .wrapper aside,
body.rightSidebar .wrapper aside {
  width: 22.5rem;
}

body.leftSidebar .wrapper main {
  order: 2;
}
body.leftSidebar .wrapper aside {
  order: 1;
}

@media screen and (max-width: 959px) {
  .wrapper {
    max-width: 100%;
    padding: 0 2%;
    flex-wrap: wrap;
  }
  body.leftSidebar .wrapper,
  body.rightSidebar .wrapper {
    max-width: 100%;
  }
  body.leftSidebar .wrapper main,
  body.rightSidebar .wrapper main {
    width: 100%;
  }
  body.leftSidebar .wrapper aside,
  body.rightSidebar .wrapper aside {
    width: 100%;
  }
  body.leftSidebar .wrapper main {
    order: 1;
  }
  body.leftSidebar .wrapper aside {
    order: 2;
  }
}
header {
  background: #fff;
  color: #fff;
}
header h1 {
  background: #e75400;
  color: #fff;
  font-size: 1.4rem;
  padding: 0.4rem 0;
}
header h1 span {
  display: block;
  max-width: 96rem;
  margin: auto;
}
header .logoTelArea {
  width: 96rem;
  align-items: center;
  margin: auto;
  padding: 2.4rem 0;
}

@media screen and (max-width: 480px) {
  header .logoTelArea.basicFlex {
    display: block;
    width: 100%;
    width: 50%;
    text-align: center;
  }
  header .logoTelArea.basicFlex .logoBlock {
    margin-bottom: 1.2rem;
  }
}
nav#mainNav {
  background: #e75400;
  margin-bottom: 3.2rem;
}
nav#mainNav .inner {
  max-width: 96rem;
  margin: auto;
}
nav#mainNav li {
  text-align: center;
  border-right: 0.1rem solid #fff;
}
nav#mainNav li a {
  display: block;
  color: #fff;
}
nav#mainNav li:first-child {
  border-left: 0.1rem solid #fff;
}
nav#mainNav li:hover {
  background: #e76700;
}
nav#mainNav li:hover a {
  color: #fff;
}
nav#mainNav span {
  display: block;
  font-size: 1.2rem;
  margin-top: 0.5rem;
}
nav#mainNav ul {
  display: table;
  table-layout: fixed;
  width: 100%;
}
nav#mainNav li {
  display: table-cell;
  vertical-align: middle;
}
nav#mainNav li a {
  padding: 1rem 0;
}
nav#mainNav .spMenuBlock {
  display: none;
}

@media screen and (max-width: 959px) {
  nav#mainNav #spMenuClose {
    display: none;
  }
  nav#mainNav .inner {
    max-width: none;
  }
  nav#mainNav ul {
    display: block;
    display: none;
  }
  nav#mainNav li {
    display: block;
    text-align: left;
    border: none;
    border-bottom: 1px solid #e76700;
    border: 1px solid #e76700;
    border-top: none;
  }
  nav#mainNav li a {
    display: block;
    padding-left: 1rem;
  }
  nav#mainNav li:first-child {
    border-left: none;
    border-bottom: 1px solid #e76700;
    border: 1px solid #e76700;
    border-top: none;
  }
  nav#mainNav span {
    display: none;
  }
  nav#mainNav .spMenuBlock {
    display: block;
    font-size: 1.6rem;
    color: #fff;
    padding: 0.8rem;
  }
  nav#mainNav .spMenuBlock i.fas {
    font-size: 1.6rem;
    color: #fff;
  }
  nav#mainNav #spMenuOpen {
    text-align: center;
  }
  nav#mainNav #spMenuClose {
    text-align: center;
  }
}
#mainImage {
  margin: auto;
  text-align: center;
  margin-bottom: 3.2rem;
}

.first {
  margin-top: 0;
}

main h2 {
  clear: both;
  padding: 0.7rem 1rem;
  font-size: 110%;
  border: 1px solid #dadada;
}

main div.post {
  padding: 1rem;
  border: 1px solid #dadada;
  background: #fff;
  margin-bottom: 3.2rem;
}

aside section {
  padding: 1rem;
  border: 1px solid #dadada;
  background: #fff;
  margin-bottom: 3.2rem;
}
aside h2 {
  clear: both;
  margin-bottom: 1rem;
  padding: 0.5rem 0 1rem;
  font-size: 100%;
  font-weight: normal;
  border-bottom: 1px solid #ccc;
}

footer {
  border-top: 1px solid #dadada;
}
footer .inner {
  width: 96rem;
  margin: auto;
  padding: 3.2rem 0;
}

footer small.copyright {
  display: block;
  text-align: center;
  background: #e76700;
  color: #fff;
  padding: 0.5rem;
}

.debugMsg {
  font-weight: bold;
  color: green;
}

p {
  padding-bottom: 1.6rem;
}

img {
  max-width: 100%;
  height: auto;
}

.tac {
  text-align: center;
}

.tar {
  text-align: right;
}

.tal {
  text-align: left;
}

.red {
  color: #FF0000;
}

.bold {
  font-weight: bold;
}

table {
  width: 100%;
  border: 1px solid #dadada;
  border-collapse: collapse;
  border-spacing: 0;
}
table th {
  padding: 8px;
  border: 1px solid #dadada;
  border-width: 0 0 1px 1px;
  font-weight: bold;
  color: #fff;
  background: #e75400;
  vertical-align: middle;
}
table td {
  padding: 8px;
  border: 1px solid #dadada;
  border-width: 0 0 1px 1px;
  vertical-align: middle;
}

.basicFlex {
  display: -webkit-flex;
  display: flex;
  justify-content: space-between;
}
.basicFlex .image {
  width: 30%;
}
.basicFlex .text {
  width: 68%;
}

ul.basicList li:before {
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  display: inline-block;
  background: #e75400;
  border-radius: 50%;
  position: relative;
  margin-right: 0.8rem;
}

ul.basicList li {
  padding-left: 1.6rem;
  text-indent: -1.6rem;
  padding-bottom: 0.8rem;
}

input[type=text], input[type=email], input[type=tel] {
  width: 100%;
  font-size: 1.92rem;
}

textarea {
  width: 100%;
  height: 150px;
}

header h1 {
  padding: 4px;
}

.greetings {
  align-items: center;
}

@media screen and (max-width: 480px) {
  br.spNone {
    display: none;
  }
}

span.dot {
  color: #888;
}

@media screen and (max-width: 480px) {
  .basicFlex {
    flex-wrap: wrap;
  }
  .basicFlex .text, .basicFlex .image {
    width: 100%;
  }
  .basicFlex .image {
    text-align: center;
  }
}

header .logoTelArea.basicFlex {
  padding: 0.4rem 0;
}
header .logoTelArea.basicFlex .logoBlock {
  width: 275px;
}
header .logoTelArea.basicFlex .telBlock {
  display: flex;
  width: 64%;
  align-items: center;
}
header .logoTelArea.basicFlex .telBlock .tel {
  width: 348px;
}
header .logoTelArea.basicFlex .telBlock .goodliving, header .logoTelArea.basicFlex .telBlock .lixilreform {
  width: 21%;
}
header .logoTelArea.basicFlex .kenkou.tb {
  display: none;
}
@media screen and (max-width: 959px) {
  header .logoTelArea.basicFlex .kenkou:first-of-type {
    display: none;
  }
  header .logoTelArea.basicFlex .kenkou.tb {
    display: inline-block;
  }
}

@media screen and (max-width: 480px) {
  div.logoTelArea.basicFlex {
    width: 90%;
  }
  div.logoTelArea.basicFlex .logoBlock {
    width: 275px;
    margin: auto;
    width: 59%;
    display: inline-block;
  }
  div.logoTelArea.basicFlex .kenkou {
    width: 39%;
    margin: 0 auto;
  }
  div.logoTelArea.basicFlex .telBlock {
    width: 70%;
    margin: auto;
  }
}
.innerFlex {
  display: flex;
  justify-content: space-around;
}
.innerFlex .left {
  width: 35%;
}
.innerFlex .left h2 {
  font-size: 18px;
  border-bottom: 1px solid #ccc;
  padding-bottom: 8px;
  margin-bottom: 8px;
}
.innerFlex .right {
  width: 55%;
}
.innerFlex .right ul {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 480px) {
  .innerFlex {
    flex-wrap: wrap;
  }
  .innerFlex .left, .innerFlex .right {
    width: 90%;
    margin: auto;
    margin-bottom: 8px;
  }
}

@keyframes slide {
  from {
    transform: translateY(-200px);
  }
  to {
    transform: translateY(0px);
  }
}
#mainImage {
  height: 400px;
  overflow-y: hidden;
}
#mainImage img {
  animation-name: slide;
  animation-duration: 15s;
  animation-fill-mode: forwards;
  animation-timing-function: linear;
}
@media screen and (max-width: 959px) {
  #mainImage {
    height: auto;
  }
  #mainImage img {
    animation: none;
  }
}

table.infoTable th {
  width: 30%;
}
table.infoTable td {
  width: 70%;
}

table.formTable {
  margin: 20px 0;
}
table.formTable .hissu {
  color: red;
}
table.formTable th {
  width: 30%;
}
table.formTable td {
  width: 70%;
}
@media screen and (max-width: 480px) {
  table.formTable {
    display: block;
    border: none;
    width: 100%;
  }
  table.formTable tbody, table.formTable tr {
    display: block;
    width: 100%;
  }
  table.formTable th {
    display: block;
    border: none;
    width: 100%;
    padding: 4px;
    margin-bottom: 0;
  }
  table.formTable td {
    display: block;
    border: none;
    width: 100%;
    padding: 4px;
    margin-bottom: 8px;
  }
}

.formTable th {
  width: 150px;
}
.formTable .hissu {
  color: #ff0000;
  font-size: 1.28rem;
  padding-left: 0.8rem;
}

p.formMsg {
  text-align: center;
  margin: 1.6rem 0;
}
p.formMsg .tel {
  font-size: 3.2rem;
  font-weight: bold;
}

#formResult {
  margin: auto;
  font-size: 20px;
  margin-top: 36px;
  padding: 16px;
  border-radius: 8px;
  display: none;
}

.formError {
  color: #a94442;
  background-color: #f2dede;
  border-color: #ebccd1;
}

.formSuccess {
  color: #3c763d;
  background-color: #dff0d8;
  border-color: #d6e9c6;
}

@media screen and (max-width: 480px) {
  .formTable {
    border: none;
  }
  .formTable th {
    width: 100%;
    display: block;
    border: none;
    padding: 0;
    margin-bottom: 0.8rem;
  }
  .formTable td {
    width: 100%;
    display: block;
    border: none;
    padding: 0;
    margin-bottom: 1.6rem;
  }
  .formTable .hissu {
    color: #ff0000;
    font-size: 1.28rem;
    padding-left: 0.8rem;
  }
  p.formMsg {
    text-align: center;
    margin: 1.6rem 0;
  }
  p.formMsg .tel {
    font-size: 3.2rem;
    font-weight: bold;
  }
}
div.wrapper.form #submitBtn {
  width: 295px;
  height: 56px;
  font-size: 18px;
  border-radius: 4px;
  background: #b44100;
  color: #FFF;
  margin: 32px auto 16px;
}

div.wrapper.form #submitBtn:hover {
  cursor: pointer;
  background: #e75400;
}

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

#footer .right img {
  width: 180px;
  padding: 20px;
  margin: 0 0 0 auto;
  display: block;
}

@media screen and (max-width: 959px) {
  footer#footer .inner {
    width: 100%;
  }
  header .logoTelArea {
    width: 100%;
  }
}
.reformFlex .text {
  width: 58%;
}
.reformFlex .image {
  width: 40%;
}
@media screen and (max-width: 480px) {
  .reformFlex {
    flex-wrap: wrap;
  }
  .reformFlex .text, .reformFlex .image {
    width: 100%;
  }
}

.makers {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.makers .makersBlock {
  width: 18%;
  align-items: center;
}
.makers .makersBlock a {
  display: block;
  text-align: center;
}
.makers .makersBlock.ykkap a {
  padding: 0 38px;
}

.post .businessTitle {
  border: none;
  border-bottom: 3px solid #ddd;
}

.post .businessPost {
  border: none;
}

.insurance h3 {
  background: #e75400;
  padding: 8px;
  color: white;
  font-size: 20px;
}
.insurance h3 span {
  padding: 4px 8px;
  border-left: 4px white solid;
}
.insurance h4 {
  text-align: center;
  font-weight: bold;
  margin: 8px 0;
  font-size: 28px;
}
.insurance .insuranceMsg {
  font-size: 28px;
  text-align: center;
  font-weight: bold;
  color: #e76700;
}
.insurance .insuranceList {
  border: 4px solid #e75400;
  padding: 32px;
  margin: 16px;
}
.insurance .insuranceList .msg {
  font-size: 22px;
  text-align: center;
  font-weight: bold;
  color: #e76700;
}
.insurance .insuranceList ul {
  margin: auto;
  width: 70%;
}
.insurance .insuranceList ul li {
  font-size: 24px;
  padding: 8px;
}
@media screen and (max-width: 480px) {
  .insurance .insuranceList ul {
    width: 100%;
  }
}
.insurance .promiseBox {
  border: 8px solid #e75400;
  padding: 20px;
}
.insurance .promiseBox .title {
  text-align: center;
  font-weight: bold;
  color: #e76700;
  font-size: 28px;
}

.mainColor {
  color: #e75400;
}

.insuranceFlex .insuranceBlock h5 {
  margin: 8px 0;
  padding: 16px 8px;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
.insuranceFlex .insuranceBlock .basicFlex .image {
  width: 40%;
}
.insuranceFlex .insuranceBlock .basicFlex .text {
  width: 58%;
}
@media screen and (max-width: 480px) {
  .insuranceFlex .insuranceBlock .basicFlex .image {
    width: 100%;
  }
  .insuranceFlex .insuranceBlock .basicFlex .text {
    width: 100%;
  }
}

.nonborderTable {
  border: none !important;
  table-layout: auto;
  width: auto;
}
.nonborderTable th, .nonborderTable td {
  padding: 0;
  border: none !important;
  background-color: transparent !important;
  color: black;
  width: max-content;
  white-space: nowrap;
  font-weight: normal;
  text-align: left;
}
.nonborderTable th {
  padding: 0 1em;
}

.post.news .block .title {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 4px;
}/*# sourceMappingURL=style.css.map */