:root {
  --main-orange: #F8A535;
  --light-orange: #FFF0DC;
  --dark-orange: #E78156;
  --blue: #4A72C3;
  --green: #79BB2E;
  --dark-gray: #404040;
  --gray: #919191;
  --light-gray: #E2E2E2;
  --red: #E00000;
  --font-lg: 22px;
  --font-md: 18px;
  --font-sm: 14px;
}
body {
  display: flex;
  flex-flow: column;
  min-height: 100vh;
  /* ヘッダメニューをposition: stickyで固定するため */
  height: max-content;
  /* 効かないブラウザがある */
  /* scroll-behavior: smooth; */
  color: var(--dark-gray);
}
main {
  flex: 1;
}
p {
  margin: 0;
  padding: 0;
}

/********************* 汎用部品 *********************/

/* 可変幅な文章の改行位置をコントロールする */
span.w {
  display: inline-block;
}
h1.ui.header {
  margin-top: 48px;
  font-size: var(--font-lg);
}
div.section-content-padding {
  padding-left: 15px;
}
div.section-content-padding .ui.grid .row .column {
  padding-left: 0;
}
/* 見出し */
.ui.header.heading2 {
  margin: 60px 0 25px 0;
  padding: 10px 15px;
  background-color: var(--light-orange);
  font-size: var(--font-md);
  font-weight: bold;
}

.ui.header.heading3 {
  margin: 30px 0 20px 0;
  padding: 8px 15px;
  color: var(--dark-gray);
  background-color: var(--light-gray);
  font-size: var(--font-sm);
  font-weight: bold;
}
/* ページ内リンク飛び先の位置調整 */
.anchor {
  padding-top: 20px;
  margin-top: -20px;
}
/* リンク */
a {
  color: var(--dark-gray);
  transition: 100ms;
}
a:hover {
  opacity: 0.7;
  color: var(--dark-gray);
  transition: 100ms;
}
/* グリッド */
.ui.grid > .row {
  padding: 4px;
}
.ui.stackable.grid.list .item {
  padding: 2px 10px !important;
}

/* ボタン */
.ui.button span.backArrow {
  margin-right: 5px;
}
span.backArrow {
  display: flex;
  justify-content: center;
  align-items: center;
}
.ui.button span.forwardArrow {
  margin-left: 5px;
}
span.forwardArrow {
  display: flex;
  justify-content: center;
  align-items: center;
}
span.downArrow {
  display: flex;
  justify-content: center;
  align-items: center;
}
.ui.button:hover {
  transition: 0.2s;
}
.ui.button:hover {
  opacity: 0.8 !important;
  transition: 0.2s;
}
.ui.button.cdc-orange {
  color: white;
  background-color: var(--main-orange);
  border: none;
  transition: 0.2s;
}
.ui.button.outline.cdc-orange {
  color: var(--main-orange);
  background-color: white;
  border: solid 1px var(--main-orange);
  transition: 0.2s;
}
.ui.button.outline.cdc-orange:hover {
  opacity: 0.8;
  transition: 0.2s;
}
.ui.button.cdc-blue {
  color: white;
  background-color: var(--blue);
  border: none;
}
.ui.button.cdc-green {
  color: white;
  background-color: var(--green);
  border: none;
  transition: 0.2s;
}

.ui.button.outline.cdc-gray {
  color: var(--dark-gray);
  background-color: white;
  border: solid 1px var(--dark-gray);
  transition: 0.2s;
}
.ui.button.outline.cdc-gray:hover {
  color: white;
  background-color: var(--dark-gray);
  transition: 0.2s;
}
.ui.button.independent {
  margin: 10px 0 20px;
}
.ui.button.withImg {
  display: flex;
  width: min-content;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  white-space: nowrap;
}
.ui.button.withImg img.left {
  padding-right: 6px;
}
.ui.button.withImg img.right {
  padding-left: 6px;
}

/* ラベル */

/* ラベルの右端に少し隙間があったのでマージン削除 */
.ui.label {
  margin: 0 !important;
}

/********************* ページコンポーネント *********************/



/* ヘッダ */

header.ui.fixed.menu {
  font-size: var(--font-lg);
  background-color: var(--main-orange);
  border: none !important;
  position: sticky !important;
}
header.ui.fixed.menu > .container {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
header.ui.fixed.menu > .container .item {
  padding: 0;
}
header.ui.fixed.menu > .container .main-title {
  color: white;
  font-size: var(--font-lg);
  font-weight: bold;
}
header.ui.fixed.menu > .container .sub-title {
  color: white;
  font-size: var(--font-md);
  font-weight: bold;
}
header.ui.fixed.menu > .container .sub-title.font-sm {
  font-size: 75%;
}
header.ui.fixed.menu > .container .button {
  margin-right: 20px;
  font-size: var(--font-sm);
  background-color: white;
  color: var(--main-orange);
  border-radius: 100vw;
  display: flex;
  align-items: center;
}
header.ui.fixed.menu > .container .button .backArrow path {
  stroke: none;
  fill: var(--dark-orange);
}
header.ui.fixed.menu .item {
  border: none !important;
}
header.ui.fixed.menu .item::before {
  width: 0;
}

/* フッタ */

footer.ui.footer {
  background-color: var(--main-orange);
  padding: auto;
}
footer.ui.footer .container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 80px;
}
footer.ui.footer .divided.list .item {
  font-size: var(--font-sm);
  color: white;
  border-color: white;
}

/* お知らせ */

#newsWrapper {
  margin: 50px auto 25px auto;
  padding: 0;
}
#newsWrapper > .container {
  display: flex;
  flex-direction: row;
}
#newsWrapper .header {
  margin: 0;
  padding-top: 20px;
  padding-bottom: 20px;
  width: 20%;
  font-size: var(--font-lg);
  background-color: var(--main-orange);
  border: 2px solid var(--main-orange);
  color: white;
}
#newsWrapper .header + .container {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin: 0 !important;
  padding: 10px;
  border: 2px solid var(--main-orange);
  font-size: var(--font-sm);
}
#newsWrapper .header + .container .item:not(:last-child) {
  margin-bottom: 5px;
}

/* ページ内リンク */

#tocWrapper {
  margin: 50px 0 20px 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#tocWrapper .ui.button {
  margin: 5px;
  min-width: 250px;
  width: auto;
}
#tocWrapper .ui.button .downArrow {
  margin-left: 5px;
}
#tocWrapper .ui.button .downArrow path {
  fill: var(--dark-gray)
}
#tocWrapper .ui.button:hover .downArrow path {
  transition: 0.2s;
  fill: white;
}

/* 初回導入設定に必要なツールのダウンロードやマニュアル */
#section-initial-setting .ui.stackable.grid {
  margin-top: 10px;
  margin-bottom: 5px;
}

/* よくあるご質問 */
#section-faq .container.toc {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
#section-faq .toc .ui.button {
  padding: 5px;
  white-space: nowrap;
  min-width: 200px;
  width: min-content;
}
#section-faq .toc .ui.button .downArrow {
  margin-left: 5px;
}
#section-faq .toc .ui.button .downArrow path {
  fill: var(--dark-gray)
}
#section-faq .toc .ui.button:hover .downArrow path {
  transition: 0.2s;
  fill: white;
}
#section-faq .content {
  margin-left: 15px;
  padding: 0;
}
#section-faq .ui.accordion .title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: bold;
}
#section-faq .ui.accordion .title:hover {
  background: var(--light-orange);
  transition: 100ms;
}
#section-faq .ui.divider {
  margin: 5px 0;
}
#section-faq .ui.accordion .title i {
  line-height: 0;
  transition: 300ms;
}
#section-faq .ui.accordion .title i.active {
  transform: rotate(-180deg);
  transition: 300ms;
}

/* トップページの各要素 */

#section-top-description {
  margin-top: 40px;
}

.ui.linkMap.cards {
  margin: 40px 0;
  justify-content: space-between;
}
.ui.linkMap.cards::after {
  content: none;
}
.ui.linkMap.cards .card {
  margin: 20px 0;
  width: 350px;
  min-height: 200px;
  box-shadow: none;
  border-style: solid !important;
  border-width: 1px !important;
  border-radius: 7px;
  background-clip: padding-box;
}
.ui.linkMap.cards .card .label {
  padding: 15px 0;
}
.ui.linkMap.cards .card .content {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  align-items: center;
}
.ui.linkMap.cards .card .content .description {
  margin-bottom: 10px;
}
.ui.linkMap.cards .card .button {
  font-size: var(--font-sm);
  padding: 15px 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.ui.linkMap.cards .card .button .forwardArrow path {
  fill: white;
}
.ui.linkMap.cards .card .label {
  font-size: var(--font-lg);
  color: white;
}
/* お客さま */
.ui.linkMap.cards .card.u .button {
  background-color: var(--dark-orange);
}
.ui.linkMap.cards .card.u, .ui.linkMap.cards .card.u:hover {
  border-color: var(--dark-orange);
}
.ui.linkMap.cards .card.u .label {
  background-color: var(--dark-orange);
}
.ui.linkMap.cards .card.u .button {
  background-color: var(--dark-orange);
}
/* 販売店 */
.ui.linkMap.cards .card.p, .ui.linkMap.cards .card.p:hover {
  border-color: var(--blue);
}
.ui.linkMap.cards .card.p .label {
  background-color: var(--blue);
}
/* 連携メーカー */
.ui.linkMap.cards .card.m, .ui.linkMap.cards .card.m:hover {
  border-color: var(--green);
}
.ui.linkMap.cards .card.m .label {
  background-color: var(--green);
}

/* ログイン画面 */

#main-page-login h2.ui.header {
  margin: 100px 0 40px 0;
}
#main-page-login p.description {
  margin-bottom: 40px;
}
#main-page-login form .container {
  display: flex;
  flex-direction: column;
  align-items: center;
}
#main-page-login #js-form .field {
  width: 600px;
}
#main-page-login #js-form input {
  width: 100%;
  text-align: center;
  font-size: var(--font-lg);
  border: none;
  background-color: var(--light-orange);
}
#main-page-login #js-form input::placeholder {
  text-align: center;
  color: var(--gray);
}
#main-page-login #js-form .lock.icon {
  font-size: 1.8rem;
}
#main-page-login #js-form button {
  margin: 30px auto 50px auto;
  width: 500px;
}
#main-page-login #error-msg {
  color: var(--red);
}