@charset "UTF-8";
/*
 * style.css
*/
/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */
/** 
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Correct the line height in all browsers.
 * 3. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */
/* Document
   ========================================================================== */
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&display=swap");
html {
  font-family: sans-serif; /* 1 */
  line-height: 1.15; /* 2 */
  -ms-text-size-adjust: 100%; /* 3 */
  -webkit-text-size-adjust: 100%; /* 3 */
}

iframe {
  border: none;
}

* {
  margin: 0;
  padding: 0;
  font-style: normal;
  box-sizing: border-box;
}

/* Sections
   ========================================================================== */
li {
  list-style: none;
}

ol, ul, dl, p {
  margin-top: 0;
  margin-bottom: 0;
}

/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 100%;
  margin: 0;
}

/* Grouping content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */
figcaption,
figure,
main { /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 0px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent; /* 1 */
  -webkit-text-decoration-skip: objects; /* 2 */
}

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active,
a:hover {
  outline-width: 0;
}

/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: 700;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button; /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: none;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */
details,
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */
template {
  display: none;
}

/* Hidden
   ========================================================================== */
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none;
}

/*
	File Name   : base.scss
	Description : 各ブロックのレイアウト
*/
/* web font
------------------------------------------------------------------------------- */
/*
font-family: 'Roboto', sans-serif;
font-weight:400,700;
*/
/* Body setting
------------------------------------------------------------------------------- */
body {
  position: relative;
  color: #444444;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  font-size: 13px;
  font-style: 400;
  line-height: 1.7;
  overflow-y: auto;
  background: #fff;
  padding-bottom: env(safe-area-inset-bottom);
}

body.body-bg01 {
  background: #f6f6f6;
  background: linear-gradient(to bottom, #fff, #fff 20%, #f6f6f6 20.1%, #f6f6f6);
  min-height: 100vh;
}

body.body-bg02 {
  background: #f6f6f6;
}

body.menu-open {
  /*
  overflow:hidden;
  */
  overflow: auto;
  height: 100%;
  left: 0;
  bottom: 0;
  top: 0;
  width: 100%;
  position: fixed;
  z-index: 1;
  /**/
  pointer-events: none;
}

/* common style
------------------------------------------------------------------------------- */
a:link, a:visited {
  color: #444444;
  text-decoration: underline;
}

button, select {
  color: inherit;
}

/* Header
------------------------------------------------------------------------------- */
#header-wrap {
  height: 0px;
  overflow: visible;
}

#header {
  background: rgba(255, 255, 255, 0.7);
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2000;
  box-shadow: 0 1px 6px rgb(255, 255, 255);
}

#header-inner {
  height: 69px;
  position: relative;
}

.header--new #header-inner {
  height: 72px;
}

#header__back-btn {
  position: absolute;
  top: 15px;
  left: 15px;
}
#header__back-btn a {
  position: relative;
  display: block;
  width: 40px;
  height: 40px;
}
#header__back-btn a::after {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 10px;
  margin: auto;
  width: 13px;
  height: 13px;
  border-left: 2px solid #00a18f;
  border-bottom: 2px solid #00a18f;
  transform: rotate(45deg);
  content: "";
}

#header__menu-btn {
  display: block;
  position: absolute;
  top: 15px;
  right: 15px;
  width: 40px;
  height: 40px;
  background: url(../images/common/header_menu-btn.svg) 50% 50% no-repeat;
  background-size: 20px 20px;
}

#header__logo {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 69px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
}
#header__logo span {
  display: inline-block;
  width: 99px;
  height: 22px;
  background: url(../images/common/header_logo.png) 50% 50% no-repeat;
  background-size: 100% 100%;
}
#header__logo.row2 {
  text-align: center;
  line-height: 1.4;
}

.header--new #header__logo {
  height: 72px;
}

#header__logo-ajinomoto {
  display: block;
  position: absolute;
  top: 17px;
  right: 15px;
}

#header__info {
  display: none;
  position: absolute;
  top: 15px;
  left: 15px;
  width: 40px;
  height: 40px;
}
#header__info a {
  text-decoration: none !important;
  position: relative;
  display: block;
  width: 40px;
  height: 40px;
  background: url(../images/common/icon_bell.svg) 50% 50% no-repeat;
  background-size: 20px 24px;
}
#header__info a i {
  position: absolute;
  top: 6px;
  right: 2px;
  z-index: 10;
  color: #fff;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-size: 10px;
  display: block;
  text-align: center;
  line-height: 1;
  width: 16px;
  height: 16px;
  padding-top: 3.25px;
  border-radius: 15px;
  background: #fabf01;
}

#gnav-bg {
  display: none;
  position: fixed;
  top: 0px;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99980;
  padding-bottom: 1000px;
  background: rgba(130, 130, 130, 0.25);
}

#gnav-wrap {
  display: flex;
  justify-content: flex-end;
  position: fixed;
  top: 0;
  right: -110%;
  width: 85%;
  height: 100%;
  z-index: 99999;
  transition: right 0.5s ease-in-out;
  box-sizing: content-box;
  /**/
  pointer-events: auto;
}

#gnav-wrap.open {
  right: 0;
}

#gnav {
  position: relative;
  width: 100%;
  min-width: 260px;
  height: 100%;
  padding: 58px 0px 10px 0px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  background: #fff;
  border-radius: 20px 0 0 20px;
  box-shadow: 0 0 20px rgba(100, 100, 100, 0.2);
}

#gnav__close {
  position: absolute;
  top: 15px;
  right: 15px;
  border: none;
  width: 40px;
  height: 40px;
  display: block;
  background: url(../images/common/header_menu-close.svg) 50% 50% no-repeat;
  background-size: 20px 20px;
}

.gnav__list {
  margin-bottom: 0px;
  padding-left: 38px;
  padding-bottom: 10px;
}
.gnav__list > li {
  position: relative;
  margin-bottom: 27px;
}
.gnav__list > li.category {
  position: relative;
}
.gnav__list > li.category span {
  position: relative;
  z-index: 1;
  display: inline-block;
  padding-right: 15px;
  background-color: #fff;
}
.gnav__list > li.category::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: calc(100% - 30px);
  height: 2px;
  margin-top: -1px;
  background-color: #eee;
}
.gnav__list > li > a {
  display: inline-block;
  padding: 7px 20px 7px 35px;
  line-height: 1.2;
  color: #01a08e;
  /*
  font-size: 15px;
  */
  font-size: 14px;
  font-weight: bold;
  text-decoration: none;
}
.gnav__list-icon01 a {
  background: url(../images/common/icon_home_gr.svg) 1px 50% no-repeat;
  background-size: 16px 18px;
}
.gnav__list-icon02 a {
  background: url(../images/common/icon_rabbit.png) 0 50% no-repeat;
  background-size: 18px 28px;
}
.gnav__list-icon03 a {
  background: url(../images/common/icon_movie_gr.svg) 0 50% no-repeat;
  background-size: 20px 15px;
}
.gnav__list-icon04 a {
  background: url(../images/common/icon_megaphone_gr.svg) 0 50% no-repeat;
  background-size: 20px 16px;
}
.gnav__list-icon05 a {
  background: url(../images/common/icon_camera_gr.svg) 0 50% no-repeat;
  background-size: 20px 16px;
}
.gnav__list-icon06 a {
  /*
  background: url(../images/common/icon_child_gr.svg) 0 50% no-repeat;
  background-size: 20px 18px;
  */
  background: url(../images/common/icon_town_gr.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon07 a {
  background: url(../images/common/icon_develop_gr.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon08 a {
  background: url(../images/common/icon_other02_gr.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon09 a {
  background: url(../images/common/icon_foot.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon10 a {
  background: url(../images/common/icon_bell.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon11 a {
  background: url(../images/common/icon_question.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon12 a {
  background: url(../images/common/icon_megahorn.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon13 a {
  background: url(../images/common/icon_global.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon14 a {
  background: url(../images/common/icon_ubie.svg) 0 50% no-repeat;
  background-size: 20px 16px;
}
.gnav__list-icon15 a {
  background: url(../images/common/icon_lc.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list-icon16 a {
  background: url(../images/common/icon_draw.svg) 0 50% no-repeat;
  background-size: 20px 20px;
}
.gnav__list > .gnav__list-icon17 a {
  margin-left: -2px;
  padding-left: 37px;
  background: url(../images/dummy/dummy_thumbnail_02.png) 0 50% no-repeat;
  background-size: 24px 24px;
}

#gnav .username {
  margin: 0 30px 30px;
  padding-bottom: 20px;
  border-bottom: 2px solid #eee;
}
#gnav .username > a {
  display: flex;
  align-items: center;
  text-decoration: none;
}
#gnav .username > a > img {
  width: 40px;
  height: 40px;
  margin-right: 15px;
  object-fit: cover;
  border-radius: 100%;
}
#gnav .username > a > span {
  flex: 1 0 0%;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.4;
  color: #222;
}

#gnav .campaign-bnr {
  margin: 0 35px 35px;
}
#gnav .campaign-bnr > .link {
  margin-top: 5px;
  text-align: center;
}

/* container / main
------------------------------------------------------------------------------- */
#container {
  width: 100%;
}

/* btm-nav
------------------------------------------------------------------------------- */
#btm-nav {
  position: fixed;
  z-index: 980;
  bottom: 0;
  left: 0;
  width: 100%;
}
#btm-nav ul {
  display: flex;
  background-color: #fff;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
}
#btm-nav ul li {
  position: relative;
  width: 100%;
  padding: 0 1px;
}
#btm-nav li + li::before {
  content: "";
  width: 2px;
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: -1px;
  background-color: #eee;
}
#btm-nav ul li a {
  display: block;
  padding: 12px 0 26px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  color: #01a08e;
}
#btm-nav ul li a::before {
  content: "";
  display: block;
  width: 23px;
  height: 26px;
  margin: 0 auto 5px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
#btm-nav ul li.home a::before {
  background-image: url(../images/common/icon_home_gr.svg);
  background-size: 16px auto;
}
#btm-nav ul li.walk a::before {
  background-image: url(../images/common/icon_foot.svg);
  background-size: 18px auto;
}
#btm-nav ul li.sleep a::before {
  background-image: url(../images/common/icon_bed_gr.svg);
  background-size: 23px auto;
}
#btm-nav ul li.meal a::before {
  background-image: url(../images/common/icon_meal_gr.svg);
  background-size: 19px auto;
}
#btm-nav ul li.body a::before {
  background-image: url(../images/common/icon_body_gr.svg);
  background-size: 20px auto;
}
#btm-nav ul li.setting a::before {
  background-image: url(../images/common/icon_develop_gr.svg);
  background-size: 20px auto;
}
#btm-nav ul li a.active {
  color: #fff;
  background-color: #4eb9ad;
}
#btm-nav ul li.home a.active::before {
  background-image: url(../images/common/icon_home_w.svg);
}
#btm-nav ul li.walk a.active::before {
  background-image: url(../images/common/icon_foot_w.svg);
}
#btm-nav ul li.sleep a.active::before {
  background-image: url(../images/common/icon_bed_w.svg);
}
#btm-nav ul li.meal a.active::before {
  background-image: url(../images/common/icon_meal_w.svg);
}
#btm-nav ul li.body a.active::before {
  background-image: url(../images/common/icon_body_w.svg);
}
#btm-nav ul li.setting a.active::before {
  background-image: url(../images/common/icon_develop_w.svg);
}

/*
	File Name   : parts_style.scss
	Description : パーツ用のスタイル
*/
/* style 
----------------------------------------------------------- */
.op_view {
  opacity: 1 !important;
}

.text-col01 {
  color: #d53a3a !important;
}

.fs13 {
  font-size: 13px !important;
}

.fs14 {
  font-size: 14px !important;
}

/* link
----------------------------------------------------------- */
.link-col01 {
  color: #d53a3a !important;
  text-decoration: underline;
}

input[type=button]:active,
input[type=submit]:active,
button:active,
a:active {
  opacity: 0.7 !important;
}

.help-link {
  position: relative;
  padding-left: 25px;
  text-decoration: underline;
  background-color: transparent;
}
.help-link::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: -0.3em;
  width: 20px;
  height: 20px;
  background: url(../images/common/icon_help.png) no-repeat;
  background-size: 100% auto;
}
.help-link::after {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-left: 5px;
  border-right: 2px solid #01a08e;
  border-bottom: 2px solid #01a08e;
  transform: rotate(-45deg);
}

.detail-link {
  position: relative;
  padding-left: 20px;
  text-decoration: underline;
  background-color: transparent;
}
.detail-link::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: -0.1em;
  width: 14px;
  height: 18px;
  background: url(../images/common/icon_loupe_plus.svg) no-repeat;
  background-size: 100% auto;
}
.detail-link::after {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-left: 5px;
  border-right: 2px solid #01a08e;
  border-bottom: 2px solid #01a08e;
  transform: rotate(-45deg);
}

/* btn
----------------------------------------------------------- */
button {
  -webkit-appearance: none;
  appearance: none;
  outline: 0;
  border: none;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
}

.btn-wrap {
  text-align: center;
}
.btn-wrap ul {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 -7px;
}
.btn-wrap ul li {
  width: 150px;
  max-width: calc(50% - 14px);
  margin: 0 7px;
}
.btn-wrap.-alignitems-start ul {
  align-items: flex-start;
}

.inner .btn-wrap {
  margin-left: -15px;
  margin-right: -15px;
}

.btn-type01, .btn-type01--new,
a.btn-type01--new, .btn-type07,
a.btn-type07,
a.btn-type01 {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  width: 250px;
  max-width: 100%;
  text-align: center;
  margin: 0 auto;
  line-height: 1.2;
  font-size: 15px;
  font-weight: 700 !important;
  color: #fff;
  text-decoration: none !important;
  border-radius: 100px;
  padding: 5px;
  border: 2px solid #4eb9ad;
  background: #4eb9ad;
  box-shadow: 0 10px 20px -10px rgba(97, 151, 145, 0.2);
}
.btn-type01:disabled, .btn-type01--new:disabled, .btn-type07:disabled, .btn-type01.-disabled, .-disabled.btn-type01--new, .-disabled.btn-type07,
a.btn-type01:disabled,
a.btn-type01.-disabled {
  background-color: #c6c6c6;
  border-color: #c6c6c6;
  box-shadow: none;
}

.btn-col-w {
  border: 2px solid #4eb9ad !important;
  background: #fff !important;
  color: #4eb9ad !important;
}

.btn-col-cancel {
  border: 2px solid #ddd !important;
  background: #fff !important;
  color: #666 !important;
  box-shadow: 0 10px 20px -10px rgba(173, 173, 173, 0.2) !important;
}

.btn-type01.icon-other::after, .icon-other.btn-type01--new::after, .icon-other.btn-type07::after {
  content: " ";
  position: absolute;
  top: 50%;
  right: 15px;
  z-index: 2;
  width: 11px;
  height: 10px;
  margin-top: -5px;
  background: url(../images/common/icon_other_w.svg) 0 0 no-repeat;
  background-size: 100% 100%;
}

.btn-type01.icon-pen::after, .icon-pen.btn-type01--new::after, .icon-pen.btn-type07::after {
  content: " ";
  position: absolute;
  top: 50%;
  left: 14px;
  z-index: 2;
  width: 19px;
  height: 19px;
  margin-top: -10px;
  background: url(../images/common/icon_pen_w.svg) 0 0 no-repeat;
  background-size: 100% 100%;
}

.btn-type01.icon-point::after, .icon-point.btn-type01--new::after, .icon-point.btn-type07::after {
  content: " ";
  position: absolute;
  top: 50%;
  left: 14px;
  z-index: 2;
  width: 20px;
  height: 20px;
  margin-top: -10px;
  background: url(../images/common/icon_p_w.svg) 0 0 no-repeat;
  background-size: 100% 100%;
}

.btn-type01.icon-wallet::after, .icon-wallet.btn-type01--new::after, .icon-wallet.btn-type07::after {
  content: " ";
  position: absolute;
  top: 50%;
  left: 14px;
  z-index: 2;
  width: 20px;
  height: 20px;
  margin-top: -10px;
  background: url(../images/common/icon_wallet_w.svg) 0 0 no-repeat;
  background-size: 100% 100%;
}

.btn-type02,
a.btn-type02 {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  width: 250px;
  max-width: 100%;
  text-align: center;
  margin: 0 auto;
  line-height: 1.1;
  font-size: 15px;
  font-weight: 700 !important;
  color: #666666;
  text-decoration: none !important;
  border-radius: 20px;
  padding: 0 5px;
  border: 2px solid #dddddd;
  background: #fff;
  box-shadow: 0 10px 20px -10px rgba(97, 151, 145, 0.2);
}

.btn-type03, .btn-type06,
a.btn-type06,
a.btn-type03 {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  width: 250px;
  max-width: 100%;
  text-align: center;
  margin: 0 auto;
  line-height: 1.3;
  font-size: 14px;
  font-weight: 700 !important;
  color: #4eb9ad;
  text-decoration: none !important;
  border-radius: 25px;
  padding: 0 5px;
  border: 2px solid #4eb9ad;
  background: #fff;
  box-shadow: 0 10px 20px -10px rgba(97, 151, 145, 0.2);
}

.btn-type04,
a.btn-type04 {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  width: 250px;
  max-width: 100%;
  text-align: center;
  margin: 0 auto;
  line-height: 1.3;
  font-size: 14px;
  font-weight: 700 !important;
  color: #fff;
  text-decoration: none !important;
  border-radius: 25px;
  padding: 0 5px;
  background: #4eb9ad;
  box-shadow: 0 10px 20px -10px rgba(97, 151, 145, 0.2);
}

.btn-type05,
a.btn-type05 {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  text-align: center;
  margin: 0 auto;
  line-height: 1.3;
  font-size: 14px;
  font-weight: 700 !important;
  padding: 14px 10px;
  color: #4EB9AD;
  background: #EFF9FA;
  border-radius: 10px;
}

.btn-type06,
a.btn-type06 {
  height: 40px;
}

.btn-type07,
a.btn-type07 {
  height: 50px;
}

.btn-type01--new,
a.btn-type01--new {
  width: 100%;
  height: 56px;
  font-size: 16px;
  background-color: #008673;
  border: none;
  border-radius: 24px;
}

/* title / text
----------------------------------------------------------- */
h1 {
  position: relative;
  text-align: center;
  font-size: 20px;
  line-height: 1;
  font-weight: 700;
  color: #222222;
  margin-bottom: 25px;
  /**/
  padding-top: 79px;
}

.icon-setting {
  position: fixed;
  bottom: 0;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  z-index: 1000;
  width: 100%;
  height: 69px;
  background: rgba(255, 255, 255, 0.7);
}
.icon-setting__img {
  width: 30px;
  height: 30px;
  margin-right: 30px;
  background: url(../images/common/icon_develop_mark.svg) 0 0 no-repeat;
  background-size: 30px 30px;
  vertical-align: middle;
}

h1.top-ttl {
  font-size: 16px;
}

.page-text {
  text-align: center;
  margin-bottom: 15px;
}

.form-text {
  border-top: 2px solid #eeeeee;
  padding-top: 15px;
  text-align: center;
  margin-bottom: 20px;
}

.form-text02 {
  text-align: center;
  margin: 15px 0px;
}

.warning-text {
  position: relative;
  padding-left: 37px;
}
.warning-text::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 25px;
  height: 24px;
  background: url(../images/common/icon_warning.svg) no-repeat 0 0;
  background-size: contain;
  transform: translateY(-50%);
}

/* pattern (パターン)
----------------------------------------------------------- */
.inner {
  position: relative;
  padding: 0 30px 25px;
}

.inner--new {
  position: relative;
  padding: 0 20px 32px;
}

.box-w, .box-w--new {
  background: #f6f6f6;
}
.box-w .inner, .box-w--new .inner {
  background: #fff;
  border-radius: 0 0 30px 30px;
  overflow: hidden;
}
.box-w--new .inner {
  padding: 0 20px 24px;
}

.box-g {
  background: #fff;
}
.box-g .inner {
  background: #f6f6f6;
  border-radius: 0 0 30px 30px;
  overflow: hidden;
}

.box-lb, .box-lb--new {
  background: #fff;
}
.box-lb .inner, .box-lb--new .inner {
  padding-left: 20px;
  padding-right: 20px;
  padding-bottom: 15px;
  background: #f6f6f6;
  border-radius: 0 0 30px 30px;
  overflow: hidden;
}
@media screen and (max-width: 374px) {
  .box-lb .inner, .box-lb--new .inner {
    padding-left: 0;
    padding-right: 0;
  }
}
.box-lb--new .inner {
  padding: 0 20px 32px;
}

.form-tbl {
  width: 100%;
  margin-bottom: 15px;
}
.form-tbl th,
.form-tbl td {
  padding: 8px 0;
  text-align: left;
  vertical-align: middle;
  font-size: 13px;
}
.form-tbl th {
  width: 1px;
  white-space: nowrap;
  padding-right: 15px;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.4;
}
.form-tbl td {
  word-break: break-all;
}
.form-tbl td ul {
  display: flex;
  margin: 0 -5px;
}
.form-tbl td ul li {
  width: calc(50% - 10px);
  margin: 0 5px;
}
.form-tbl__inner {
  overflow: hidden;
  position: relative;
}
.form-tbl__inner .select-type01, .form-tbl__inner .select-type02 {
  max-width: calc(100% - 40px);
}
.form-tbl__inner .date-type01 {
  max-width: calc(100% - 40px);
}
.form-tbl__inner .code-type01 {
  max-width: calc(100% - 40px);
}
.form-tbl__inner .form-tbl__eraser {
  -webkit-appearance: none;
  appearance: none;
  background: url(../images/common/icon_eraser.png) 0 0 no-repeat;
  background-size: 30px 30px;
  border: none;
  outline: 0;
  width: 30px;
  height: 30px;
  position: absolute;
  top: 5px;
  right: 0;
}
.form-tbl__inner .form-tbl__question {
  -webkit-appearance: none;
  appearance: none;
  background: url(../images/common/icon_help.png) 0 0 no-repeat;
  background-size: 30px 30px;
  border: none;
  outline: 0;
  width: 30px;
  height: 30px;
  position: absolute;
  top: 5px;
  right: 0;
}
.form-tbl__inner02 {
  overflow: hidden;
  position: relative;
}

.v-top {
  vertical-align: top !important;
}

.v-text-top {
  vertical-align: text-top !important;
}

.form-line-ttl {
  border-top: 2px solid #eeeeee;
  text-align: center;
  padding: 15px 0;
}

.form-dl {
  margin-bottom: 15px;
}
.form-dl dt {
  margin-bottom: 9px;
  font-size: 14px;
  font-weight: 700;
  padding-left: 23px;
  min-height: 18px;
}
.form-dl dt span {
  font-size: 12px;
  font-weight: 400;
  padding-left: 2px;
}
.form-dl dd .form-text03 {
  margin-top: -5px;
  padding: 0 0 10px 23px;
}
.form-dl__icon-user {
  background: url(../images/common/icon_user.svg) 2px 50% no-repeat;
  background-size: 14px 18px;
}
.form-dl__icon-mail {
  background: url(../images/common/icon_mail.svg) 0 50% no-repeat;
  background-size: 16px 12px;
}
.form-dl__icon-key {
  background: url(../images/common/icon_key.svg) 2px 50% no-repeat;
  background-size: 11px 18px;
}
.form-dl__icon-individual {
  background: url(../images/common/icon_individual.svg) 2px 50% no-repeat;
  background-size: 16px 16px;
}
.form-dl__icon-card {
  background: url(../images/common/icon_card.svg) 2px 50% no-repeat;
  background-size: 16px 16px;
}
.form-dl__number-list {
  display: flex;
  align-items: center;
}
.form-dl__number-list li:nth-child(1) {
  width: 100px;
}
.form-dl__number-list li:nth-child(2) {
  text-align: center;
  width: 25px;
  font-weight: 700;
}
.form-dl__number-list li:nth-child(3) {
  width: calc(100% - 125px);
}
.form-dl__desc {
  margin-top: 10px;
  font-size: 12px;
  text-indent: -1em;
  padding-left: 1em;
}

.form-column {
  display: flex;
  justify-content: space-between;
  margin-bottom: 15px;
}
.form-column dt {
  margin-bottom: 9px;
  font-size: 14px;
  font-weight: 700;
  padding-left: 23px;
  min-height: 18px;
}
.form-column dt span {
  font-size: 12px;
  font-weight: 400;
  padding-left: 2px;
}

.form-supplement {
  display: inline-block;
  margin-left: 5px;
  padding: 2px 4px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  background-color: #4eb9ad;
  border-radius: 3px;
}

.form-thumb {
  position: relative;
  width: 100px;
  margin: 25px auto 10px;
}
.form-thumb .thumb {
  width: 100px;
  height: 100px;
  vertical-align: top;
  object-fit: cover;
  border-radius: 100%;
}
.form-thumb .camera {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 30px;
  height: 30px;
  background-color: #4eb9ad;
  object-fit: cover;
  border-radius: 100%;
}
.form-thumb .camera img {
  width: 16px;
}

.form-campaign__required:not(.-required) > th > br,
.form-campaign__required:not(.-required) > th > .form-supplement {
  display: none;
}

.form-campaign__hidden.-hidden {
  display: none;
}

.form-campaign__visible:not(.-visible) {
  display: none;
}

.app-btn-list {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 -20px;
}
.app-btn-list li {
  margin: 0 20px;
  text-align: center;
}
.app-btn-list li span {
  display: block;
  margin-bottom: 5px;
  font-size: 13px;
  font-weight: 700;
}
.app-btn-list li img {
  height: 43px;
  width: auto;
}

/* form 関係
----------------------------------------------------------- */
/* input-type1 */
.input-type01 {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 40px;
  background-color: #f6f6f6;
  border: none;
  border-radius: 20px;
  padding: 0 16px;
  font-size: 13px;
  outline: 0;
}
.input-type01::placeholder {
  color: #666666;
}

/* END input-type01 */
/* select-type01 */
.select-type01, .select-type02 {
  -webkit-appearance: none;
  appearance: none;
  display: inline-block;
  position: relative;
  width: 100%;
  max-width: 100%;
  padding: 0px 30px 0px 16px;
  height: 40px;
  border: none;
  box-shadow: none;
  line-height: 1.2;
  border-radius: 20px;
  background-color: #f6f6f6;
  background-image: url(../images/common/select_arrow.svg);
  background-position: calc(100% - 13px) 50%;
  background-repeat: no-repeat;
  background-size: 12px 7px;
  font-size: 13px;
  outline: 0;
}
.select-type01::-ms-expand, .select-type02::-ms-expand {
  display: none;
}

.select-type02 {
  background-color: #fff;
}

.date-type01 {
  -webkit-appearance: none;
  appearance: none;
  display: inline-block;
  position: relative;
  width: 100%;
  max-width: 100%;
  padding: 0px 30px 0px 16px;
  height: 40px;
  border: none;
  box-shadow: none;
  line-height: 1.2;
  border-radius: 20px;
  background-color: #f6f6f6;
  background-image: url(../images/common/select_arrow.svg);
  background-position: calc(100% - 13px) 50%;
  background-repeat: no-repeat;
  background-size: 12px 7px;
  font-size: 13px;
  outline: 0;
}
.date-type01::placeholder {
  color: #666666;
}

.time-type01 {
  -webkit-appearance: none;
          appearance: none;
  outline: 0;
  display: block;
  position: relative;
  right: 0;
  width: 125px;
  padding: 10px;
  height: 50px;
  margin-left: auto;
  font-size: 25px;
  font-family: "roboto";
  letter-spacing: 2px;
  text-align: center;
  color: #4eb9ad;
  background-color: #fff;
  border: 2px solid #4eb9ad;
  border-radius: 10px;
}
.time-type01::placeholder {
  color: #666666;
}

.time-type01[type=time] {
  position: absolute;
  top: 0;
  right: 0;
  opacity: 0;
  z-index: 1;
}
.time-type01[type=time] :first-child {
  width: 1px;
}

/* END select-type01 */
/* textarea-type1 */
.textarea-type01 {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  background-color: #f6f6f6;
  border: none;
  border-radius: 20px;
  padding: 10px 16px;
  font-size: 13px;
  outline: 0;
}
.textarea-type01::placeholder {
  color: #666666;
}

/* END textarea-type01 */
/* custom-control */
label.custom-control {
  position: relative;
  display: inline-block;
  cursor: pointer;
}

label.custom-control + label.custom-control {
  margin-left: 7px;
}

.custom-control-input {
  position: absolute;
  z-index: -1;
  opacity: 0;
}

.custom-control-indicator {
  position: absolute;
  top: 0px;
  left: 15px;
  z-index: 2;
  display: block;
  width: 17px;
  height: 17px;
  pointer-events: none;
  -webkit-user-select: none;
  user-select: none;
  background-color: #ddd;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 50% 50%;
}

.custom-control-description {
  display: block;
  position: relative;
  z-index: 1;
  font-weight: 700;
}

/* END custom-control */
/* custom-radio */
.custom-control.custom-radio .custom-control-indicator {
  background: url(../images/common/radio_off.svg) 50% 50% no-repeat;
  background-size: 100% 100%;
  top: 50%;
  margin-top: -8px;
}
.custom-control.custom-radio .custom-control-description {
  padding: 7px 25px 7px 40px;
  border: 2px solid #dddddd;
  background: #fff;
  border-radius: 20px;
}
.custom-control.custom-radio .custom-control-input:checked ~ .custom-control-indicator {
  background: url(../images/common/radio_on.svg) 50% 50% no-repeat;
  background-size: 100% 100%;
}
.custom-control.custom-radio .custom-control-input:checked ~ .custom-control-description {
  background: #4eb9ad;
  border-color: #4eb9ad !important;
  color: #fff;
}

/* END custom-radio */
.custom-checkbox-wrap {
  position: relative;
  text-align: right;
  height: 30px;
  margin-right: -5px;
}

/* custom-checkbox */
.custom-control.custom-checkbox {
  outline: 0;
}
.custom-control.custom-checkbox .custom-control-indicator {
  background: url(../images/common/check_off.png) 0 0 no-repeat;
  background-size: 100% 100%;
  position: static;
  top: inherit;
  margin-top: 0px;
  width: 55px;
  height: 32px;
}
.custom-control.custom-checkbox .custom-control-input:checked ~ .custom-control-indicator {
  background: url(../images/common/check_on.png) 0 0 no-repeat;
  background-size: 100% 100%;
}

/* END custom-checkbox */
/* width:45px; */
/* MODAL 関係
----------------------------------------------------------- */
#modal-bg {
  display: none;
  position: fixed;
  z-index: 3000;
  top: 0;
  left: 0;
  width: 100%;
  height: 150%;
  background: rgba(130, 130, 130, 0.25);
}

.modal-open {
  overflow: hidden;
}

.modal {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 3050;
  overflow: hidden;
  outline: 0;
  overflow-x: hidden;
  overflow: auto;
  /**/
  flex-flow: column;
  align-items: center;
  -webkit-overflow-scrolling: touch;
  padding: 20px 20px;
}

.modal-content {
  position: relative;
  width: 100%;
  margin: auto;
  pointer-events: auto;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 0 20px rgba(100, 100, 100, 0.2);
}

.modal-header {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  padding: 10px 10px 0 10px;
  justify-content: flex-end;
  align-items: center;
}
.modal-header .modal-header__close {
  position: relative;
  z-index: 10;
  order: 1;
  height: 40px;
  width: 100%;
  text-align: right;
}
.modal-header .modal-header__close a {
  display: inline-block;
  width: 40px;
  height: 40px;
  background: url(../images/common/icon_close.svg) 50% 50% no-repeat;
  background-size: 20px 20px;
}

.modal-body {
  position: relative;
  padding: 0;
  text-align: center;
  font-size: 13px;
}

.modal-body__inner {
  padding: 0 20px 30px;
}

.modal-btn-wrap {
  margin-top: 20px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal-btn-wrap li {
  width: 130px;
  margin: 0 5px;
}

#modal-bg2 {
  display: none;
  position: fixed;
  z-index: 3000;
  top: 0;
  left: 0;
  width: 100%;
  height: 150%;
  background: rgba(0, 61, 52, 0.9);
}

.modal2 {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 3050;
  overflow: hidden;
  outline: 0;
  overflow-x: hidden;
  overflow: auto;
  /**/
  flex-flow: column;
  align-items: center;
  -webkit-overflow-scrolling: touch;
  padding: 20px;
}
.modal2 .modal-content {
  border-radius: 24px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}
.modal2 .modal-header__close {
  position: absolute;
  top: -20px;
  right: -12px;
  width: 40px;
  height: 40px;
  background-color: #FABF00;
  border-radius: 50%;
}
.modal2 .modal-header__close a {
  background-size: 18px 18px;
}
.modal2 .modal-header {
  padding: 0;
}
.modal2 .modal-body__inner {
  padding: 32px 24px;
}

/* slide-modal */
.slide-modal {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2900;
  outline: 0;
  overflow: hidden;
  transform: translateY(100%);
  transition: transform 0.5s cubic-bezier(0.65, 0, 0.35, 1);
  /**/
  flex-flow: column;
  align-items: center;
  -webkit-overflow-scrolling: touch;
}
.slide-modal-open {
  transform: translateY(0);
}

.slide-modal-content {
  position: relative;
  width: 100%;
  height: 100%;
  pointer-events: auto;
  background: #fff;
}

.slide-modal-header {
  background: rgba(255, 255, 255, 0.7);
  z-index: 2950;
  width: 100%;
  height: 69px;
  position: fixed;
  top: 0;
  left: 0;
  box-shadow: 0 1px 6px #fff;
}
.slide-modal-header__title {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 69px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}
.slide-modal-header__close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 10;
  width: 69px;
  height: 69px;
}
.slide-modal-header__close a {
  display: inline-block;
  width: 69px;
  height: 69px;
  background: url(../images/common/icon_close_gr.svg) 50% 50% no-repeat;
  background-size: 20px 20px;
}

.slide-modal-body {
  position: relative;
  padding-top: 69px;
  height: 100%;
  overflow-y: scroll;
  text-align: center;
  font-size: 13px;
}

.slide-modal-body__inner {
  padding: 30px;
}

/* accordion
----------------------------------------------------------- */
.accordion-box {
  background-color: #fff;
  border: 2px solid #ddd;
  border-radius: 8px;
  box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.05);
}
.accordion-box__head {
  position: relative;
  width: 100%;
  padding: 19px 45px;
  font-size: 15px;
  font-weight: 700;
  text-align: center;
  background-color: transparent;
}
.accordion-box__head::before, .accordion-box__head::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 25px;
  width: 2px;
  height: 18px;
  background-color: #01a08e;
  transform: translateY(-50%);
}
.accordion-box__head::after {
  transform: translateY(-50%) rotate(90deg);
}
.accordion-box__body {
  display: none;
  padding: 25px;
}
.accordion-box.-active .accordion-box__head::before {
  top: auto;
  bottom: 0;
  left: 17px;
  right: 17px;
  width: auto;
  height: 2px;
  background-color: #eee;
  transform: none;
}

#howto-slide-modal .modal-body__inner {
  padding: 0 0 90px;
}
#howto-slide-modal .separate-line01 {
  margin: 20px 30px;
}
#howto-slide-modal h2 {
  font-size: 22px;
  font-weight: 700;
}
#howto-slide-modal dl {
  display: inline-flex;
  justify-content: center;
  margin: 10px 10px 20px;
  text-align: left;
}
#howto-slide-modal dl dt {
  margin-top: 2px;
  margin-right: 8px;
  font-size: 16px;
  font-weight: 700;
  color: #4eb9ad;
  font-family: roboto;
  white-space: nowrap;
}
#howto-slide-modal dl dd {
  font-size: 18px;
  font-weight: 700;
}
#howto-slide-modal dl + p {
  margin: -10px 10px 20px;
}
#howto-slide-modal .slides {
  position: relative;
  z-index: 3;
  opacity: 0;
  padding-bottom: 25px;
}
#howto-slide-modal .slide-close {
  display: none;
  position: absolute;
  bottom: 30px;
  left: 0;
  width: 100%;
  z-index: 10;
}
#howto-slide-modal .slide-close .btn-type01, #howto-slide-modal .slide-close .btn-type07, #howto-slide-modal .slide-close .btn-type01--new {
  width: 200px;
}

/* vue v-cloak
----------------------------------------------------------- */
[v-cloak] {
  display: none !important;
}

/* *********
----------------------------------------------------------- */
/*
	File Name   : page.scss
	Description : 各コンテンツページ用

	00.共通
    01.起動画面
    02.アプリの使い方
    03.利用規約
    04.プロフィール登録
    06.設定
    07.お知らせ
    08.動画
    09.ウォーキングチーム
    10.ライフサポートトップ
    11.キャンペーン説明

	**.TITLE

*/
/*------------------------------------------------------*/
/* 00.共通
----------------------------------------------------------- */
/* 01.起動画面
----------------------------------------------------------- */
#app-intro {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
#app-intro span {
  opacity: 0;
}

/* 02.アプリの使い方
----------------------------------------------------------- */
@keyframes cloud-anime {
  from {
    background-position: 0 0;
  }
  to {
    background-position: 100% 0;
  }
}
#howto-close-btn {
  position: fixed;
  top: 15px;
  right: 15px;
  z-index: 3000;
}
#howto-close-btn a {
  display: block;
  width: 40px;
  height: 40px;
  background: url(../images/common/icon_close.svg) 50% 50% no-repeat;
  background-size: 20px 20px;
}

#howto-start {
  display: none;
  /**/
  position: absolute;
  bottom: 30px;
  left: 0;
  width: 100%;
  z-index: 10;
}
#howto-start a.btn-type01, #howto-start a.btn-type07, #howto-start a.btn-type01--new {
  width: 200px;
}

#howto-next {
  position: absolute;
  bottom: -60px;
  left: 50%;
  margin: 0 0 0 -100px;
  z-index: 1;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  width: 200px;
  max-width: 100%;
  text-align: center;
  line-height: 1.1;
  font-size: 15px;
  font-weight: 700 !important;
  color: #4eb9ad;
  text-decoration: none !important;
  border-radius: 20px;
  padding: 0 5px;
  border: 2px solid #4eb9ad;
  background: #fff;
  box-shadow: 0 10px 20px -10px rgba(97, 151, 145, 0.2);
  transition: 0.5s ease;
}

#howto .slick-prev {
  display: none !important;
}

#howto-next.slick-disabled {
  pointer-events: none;
  opacity: 0;
}

#howto-bg {
  position: fixed;
  top: 290px;
  left: 0px;
  background: url(../images/common/slide_bg02.png) center top repeat-x;
  background-size: auto 188px;
  width: 100%;
  height: 188px;
  z-index: 0;
  animation: cloud-anime 30s linear infinite;
}

#howto {
  position: relative;
  z-index: 2;
  padding-bottom: 90px;
}
#howto h1 {
  padding-top: 40px;
}
#howto .slides {
  position: relative;
  z-index: 3;
  opacity: 0;
  padding-bottom: 25px;
}
#howto .slides .slide-item {
  text-align: center;
}
#howto .slides .slide-item dl {
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#howto .slides .slide-item dl dt {
  font-family: "Roboto", sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #4eb9ad;
}
#howto .slides .slide-item dl dd {
  font-size: 18px;
  font-weight: 700;
  color: #444444;
  padding-left: 8px;
}
#howto .slides .slide-item p {
  font-size: 14px;
  margin-bottom: 10px;
}
#howto .slides .slide-item figure {
  line-height: 0;
}
#howto .slides .slide-item img {
  width: 100%;
}

/* 03.利用規約
----------------------------------------------------------- */
#agreement-text {
  border: 2px solid #dddddd;
  border-radius: 8px;
  padding: 15px 17px;
  height: 350px;
  text-align: left;
  overflow: auto;
  margin-bottom: 23px;
}
#agreement-text a {
  word-break: break-all;
}

#inviflow-modal .modal-body__inner {
  padding: 0 0 90px;
}
#inviflow-modal .warning-text {
  margin: 0 30px;
  font-size: 12px;
  text-align: left;
}
#inviflow-modal .separate-line01 {
  margin: 20px 30px;
}
#inviflow-modal h2 {
  font-size: 22px;
  font-weight: 700;
}
#inviflow-modal dl {
  display: inline-flex;
  justify-content: center;
  margin: 10px 10px 20px;
  text-align: left;
}
#inviflow-modal dl dt {
  margin-top: 2px;
  margin-right: 8px;
  font-size: 16px;
  font-weight: 700;
  color: #4eb9ad;
  font-family: roboto;
  white-space: nowrap;
}
#inviflow-modal dl dd {
  font-size: 18px;
  font-weight: 700;
}
#inviflow-modal dl + p {
  margin: -10px 10px 20px;
}
#inviflow-modal .slides {
  position: relative;
  z-index: 3;
  opacity: 0;
  padding-bottom: 25px;
}
#inviflow-modal #inviflow-close {
  display: none;
  position: absolute;
  bottom: 30px;
  left: 0;
  width: 100%;
  z-index: 10;
}
#inviflow-modal #inviflow-close .btn-type01, #inviflow-modal #inviflow-close .btn-type07, #inviflow-modal #inviflow-close .btn-type01--new {
  width: 200px;
}

/* 04.プロフィール登録
----------------------------------------------------------- */
.form-line-box {
  border: 2px solid #eeeeee;
  border-radius: 8px;
  padding: 15px 17px 10px;
  margin: 0 -15px 30px;
}

.form-line-box__text {
  text-align: center;
  margin-bottom: 8px;
}

#date-input-date {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  max-width: inherit;
}

#date-input-text {
  pointer-events: none;
}

/* 06.設定
----------------------------------------------------------- */
.setting-list {
  display: flex;
  flex-wrap: wrap;
  margin: -30px -10px 0;
}
.setting-list li {
  width: 33.33%;
  text-align: center;
  line-height: 1.5;
  padding-top: 30px;
}
.setting-list li figure {
  width: 70px;
  line-height: 0;
}
.setting-list li a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #01a08e;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
}

.profile-header {
  position: relative;
  margin: 118px -30px 0;
  padding: 80px 0 25px;
  text-align: center;
  background-color: #66c4b9;
}
.profile-header > .develop {
  position: absolute;
  top: 25px;
  right: 30px;
  width: 20px;
  height: 20px;
}
.profile-header > .thumbnail {
  position: absolute;
  top: -38px;
  left: 50%;
  transform: translateX(-50%);
}
.profile-header > .thumbnail img {
  display: block;
  width: 104px;
  height: 104px;
  margin: auto;
  object-fit: cover;
  border: 2px solid #fff;
  border-radius: 100%;
}
.profile-header > .nickname {
  margin: 0;
  padding: 0;
  font-size: 16px;
  color: #fff;
}
.profile-header > .overview {
  display: inline-flex;
  margin-top: 12px;
  padding: 6px 0;
  background-color: #fff;
  border-radius: 100px;
}
.profile-header > .overview > .pref {
  min-width: 76px;
  height: 16px;
  line-height: 16px;
  border-right: 1px solid #aaa;
}
.profile-header > .overview > .pref::before {
  content: "";
  display: inline-block;
  width: 9px;
  height: 12px;
  margin-right: 7px;
  background: url(../images/common/icon_marker.svg) 50% 50% no-repeat;
  background-size: auto 100%;
  vertical-align: -1px;
}
.profile-header > .overview > .gender {
  width: 43px;
  height: 16px;
  text-align: center;
}
.profile-header > .overview > .gender > img {
  width: auto;
  height: 16px;
  margin-right: 5px;
}

.profile-body table {
  margin: 10px 0;
  border-collapse: collapse;
}
.profile-body table tr th {
  position: relative;
  width: 7em;
  padding: 20px 0 20px 30px;
  font-size: 14px;
  font-weight: bold;
  text-align: left;
}
.profile-body table tr th::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  width: 19px;
  height: 19px;
  margin-right: 10px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateY(-50%);
}
.profile-body table tr td {
  padding: 20px 0 20px 20px;
}
.profile-body table tr:not(:first-child) th,
.profile-body table tr:not(:first-child) td {
  border-top: 2px solid #eeeeee;
}
.profile-body table tr.comment th {
  width: 100%;
  padding-bottom: 15px;
}
.profile-body table tr.comment td {
  padding: 12px 20px;
  background-color: #eff9fa;
  border-top: none;
  border-radius: 8px;
}
.profile-body table tr.name th::before,
.profile-body table tr.kana th::before,
.profile-body table tr.kanji th::before {
  background-image: url(../images/common/icon_user.svg);
  background-size: auto 16px;
}
.profile-body table tr.birthday th::before {
  background-image: url(../images/common/icon_cake.svg);
  background-size: auto 18px;
}
.profile-body table tr.pref th::before,
.profile-body table tr.address th::before {
  background-image: url(../images/common/icon_japan.svg);
}
.profile-body table tr.job th::before {
  background-image: url(../images/common/icon_job.svg);
}
.profile-body table tr.campaigncode th::before {
  background-image: url(../images/common/icon_campaigncode.svg);
}
.profile-body table tr.tel th::before {
  background-image: url(../images/common/icon_tel.svg);
}
.profile-body table tr.contactcode th::before {
  background-image: url(../images/common/icon_contactcode.svg);
}
.profile-body table tr.tel th::before {
  background-image: url(../images/common/icon_tel.svg);
}
.profile-body table tr.number th::before {
  background-image: url(../images/common/icon_card.svg);
  background-size: 18px auto;
}
.profile-body table tr.comment th::before {
  background-image: url(../images/common/icon_pen2.svg);
}
.profile-body table tr.zipcode th::before {
  background-image: url(../images/common/icon_zip.svg);
}

.campaign-history {
  padding: 20px 0 0;
  text-align: center;
}
.campaign-history > h3 {
  margin-bottom: 15px;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
}
.campaign-history > .history-list {
  padding: 20px 5px;
  font-size: 10px;
  background-color: #fff;
  border-radius: 8px;
}
.campaign-history > .history-list > .inner {
  overflow-y: auto;
  max-height: 200px;
  padding: 0 10px;
  -webkit-overflow-scrolling: touch;
}
.campaign-history > .history-list .item {
  border: 1px solid #dfdfdf;
  padding: 3px;
  border-radius: 8px;
}
.campaign-history > .history-list .item + .item {
  margin-top: 15px;
}
.campaign-history > .history-list .item > .campaign {
  padding: 10px;
  color: #fff;
  background-color: #66c4b9;
  border-radius: 6px 6px 0 0;
}
.campaign-history > .history-list .item > .campaign > .name {
  font-size: 11px;
  font-weight: 700;
}
.campaign-history > .history-list .item > .detail-column {
  display: flex;
  padding: 15px 0;
}
.campaign-history > .history-list .item > .detail-column > .left-col {
  width: 87px;
  padding: 0 5px;
  border-right: 1px solid #dfdfdf;
}
.campaign-history > .history-list .item > .detail-column > .right-col {
  flex: 1 0 0%;
  padding: 0 5px 0 10px;
  text-align: left;
}
.campaign-history > .history-list .item > .detail-column .rank {
  color: #4eb9ad;
}
.campaign-history > .history-list .item > .detail-column .rank > .num {
  font-size: 20px;
  font-weight: 700;
  font-family: Roboto;
  line-height: 1;
}
.campaign-history > .history-list .item > .detail-column .sub {
  width: 125%;
  margin-left: -12.5%;
  transform: scale(0.8);
}
.campaign-history > .history-list .item > .detail-column .group {
  font-weight: 700;
}
.campaign-history > .history-list .item > .detail-column .steps > .num {
  font-size: 13px;
  font-weight: 700;
  font-family: Roboto;
}

/* 07.お知らせ
----------------------------------------------------------- */
.news-list li {
  border-bottom: 2px solid #eeeeee;
}
.news-list li a {
  display: block;
  text-decoration: none !important;
  padding: 15px 0;
}
.news-list li a dl dt {
  position: relative;
  font-weight: 700;
  padding-right: 60px;
  color: #444444;
  margin-bottom: 8px;
  word-break: break-all;
}
.news-list li a dl dt strong {
  font-size: 14px;
}
.news-list li a dl dt i {
  display: block;
  background: #eefafa;
  width: 40px;
  border-radius: 4px;
  text-align: center;
  color: #01a08e;
  font-size: 11px;
  line-height: 1;
  padding: 4px 3px;
  position: absolute;
  top: 1px;
  right: 0;
}
.news-list li a dl dd {
  position: relative;
  color: #444444;
  word-break: break-all;
}
.news-list li a dl dd p {
  font-size: 13px;
}
.news-list li a dl dd em {
  margin-top: 5px;
  font-style: normal;
  font-size: 12px;
  display: block;
}
.news-list li a dl dd i {
  position: absolute;
  bottom: 3px;
  right: 0;
  display: inline-block;
  border-radius: 4px;
  text-align: center;
  min-width: 50px;
  line-height: 1;
  padding: 3px 4px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
}
.news-list li a dl dd i.mark-contact {
  background: #66c4b9;
}
.news-list li a dl dd i.mark-event {
  background: #fabf01;
}
.news-list li a dl dd i.mark-question {
  background: #66d0f4;
}
.news-list li a dl dd i.mark-campaign {
  background: #f395a6;
}

dl.news-detail dt {
  position: relative;
  font-weight: 700;
  color: #444;
  margin-bottom: 20px;
  font-size: 15px;
}
dl.news-detail dd p {
  font-size: 13px;
  margin-bottom: 10px;
}
dl.news-detail dd em {
  text-align: right;
  margin-top: 10px;
  font-style: normal;
  font-size: 12px;
  display: block;
}

/* 08.動画
----------------------------------------------------------- */
.movie-list li {
  margin-bottom: 25px;
}
.movie-list li figure {
  position: relative;
  line-height: 0;
  text-align: center;
}
.movie-list li figure img {
  width: 100%;
}
.movie-list li a {
  position: relative;
  display: block;
}
.movie-list li dl {
  margin: 8px 0 0;
}
.movie-list li dl dt {
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 0px;
}
.movie-list li dl dd {
  font-size: 13px;
  font-family: "Roboto", sans-serif;
}
.movie-list__play-btn {
  display: block;
  width: 40px;
  height: 40px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -20px 0 0 -20px;
  z-index: 10;
  background: url(../images/common/play_btn.png) 0 0 no-repeat;
  background-size: 100% 100%;
}

#movie-box-wrap {
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}

#movie-box {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
}

#movie-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* 09.ウォーキングチーム
----------------------------------------------------------- */
.separate-line01 {
  margin: 25px 0;
  border: 1px solid #eee;
}

.group-list {
  margin-top: 15px;
}
.group-list .box {
  display: block;
  position: relative;
  min-height: 102px;
  padding: 17px 20px;
  text-decoration: none;
  background-color: #eff9fa;
  border: 2px solid #4eb9ad;
  border-radius: 10px;
  box-shadow: 0 10px 20px -10px rgba(173, 173, 173, 0.2);
}
.group-list .box:not(:first-child) {
  margin-top: 20px;
}
.group-list .box .num {
  font-family: Roboto;
}
.group-list .box > .name {
  display: flex;
  position: relative;
  margin-right: 135px;
  font-size: 17px;
  font-weight: 700;
  color: #4eb9ad;
}
.group-list .box > .name > .text {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.group-list .box > .name > .num {
  align-self: center;
  margin-left: 8px;
  font-size: 11px;
}
.group-list .box > .data {
  font-size: 12px;
  line-height: 1.2;
}
.group-list .box > .data > li > .num {
  font-size: 15px;
}
.group-list .box > .thumbnail {
  position: absolute;
  right: 20px;
  top: 20px;
  width: 115px;
}
.group-list .box > .thumbnail > img {
  display: block;
  float: left;
  width: 27px;
  height: 27px;
  margin-right: -5px;
  margin-bottom: 2px;
  object-fit: cover;
  border: 1px solid #4eb9ad;
  border-radius: 100%;
}
.group-list .box > .leader {
  position: absolute;
  left: 7px;
  top: -13px;
  width: 25px;
}
.group-list .box.-disabled {
  border-color: #ddd;
  pointer-events: none;
}
.group-list .box > .disabled-text {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  font-size: 14px;
  text-align: center;
  color: #fff;
  background-color: rgba(0, 0, 0, 0.3);
  border-radius: 8px;
}

.invitation-list {
  margin-top: 25px;
}
.invitation-list ul > li:not(:first-child) {
  margin-top: 20px;
}
.invitation-list ul > li > a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 60px;
  padding: 5px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  border: 1px solid #ddd;
  border-radius: 10px;
  box-shadow: 0 10px 20px -10px rgba(173, 173, 173, 0.2);
}
.invitation-list ul > li > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 20px;
  width: 30px;
  height: 30px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  transform: translateY(-50%);
}
.invitation-list ul > li > a.icon-line::before {
  background-image: url(../images/common/icon_line.png);
  background-size: 30px auto;
}
.invitation-list ul > li > a.icon-mail::before {
  background-image: url(../images/common/icon_mail.svg);
  background-size: 16px auto;
}
.invitation-list ul > li > a.icon-qr::before {
  background-image: url(../images/common/icon_qr.png);
  background-size: 19px auto;
}

#qr-modal .qr-image {
  width: 150px;
  margin: auto;
}

.group-detail-slides {
  margin: 0 -10px;
  padding-top: 79px;
}
.group-detail-slides .slide-item {
  margin: 0 10px;
}
.group-detail-slides h2 {
  text-align: center;
}
.group-detail-slides .group-area {
  margin-top: -4px;
  font-weight: 700;
  text-align: center;
}
.group-detail-slides .member-list {
  margin-top: 25px;
  padding: 20px;
  background-color: #eefafa;
  border-radius: 10px;
}
.group-detail-slides .member-list h3 {
  margin-bottom: 10px;
  font-size: 14px;
  text-align: center;
}
.group-detail-slides .member-list h3 .num {
  margin-left: 8px;
  font-size: 13px;
  font-weight: 400;
}
.group-detail-slides .member-list .list {
  display: grid;
  grid-template-columns: repeat(3, 75px);
  justify-content: space-around;
  justify-items: center;
  grid-row-gap: 16px;
}
.group-detail-slides .member-list .list .item {
  font-size: 12px;
  text-align: center;
}
.group-detail-slides .member-list .list .item img {
  display: block;
  width: 70px;
  height: 70px;
  margin-bottom: 2px;
  object-fit: cover;
  border-radius: 100%;
}
.group-detail-slides .member-list .list .item .image {
  position: relative;
}
.group-detail-slides .member-list .list .item .image .leader {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 25px;
  height: 25px;
}
.group-detail-slides .member-list .list .item .image .leader img {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100%;
  height: auto;
}
.group-detail-slides .member-list .list .item .name {
  width: 75px;
  margin-top: 5px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.group-detail-slides .slick-arrow {
  top: 93px;
  width: 25px;
  height: 25px;
  margin-top: 0;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.group-detail-slides .slick-prev {
  left: 10px;
  background-image: url(../images/common/steps_slick_prev.png);
}
.group-detail-slides .slick-next {
  right: 10px;
  background-image: url(../images/common/steps_slick_next.png);
}
.group-detail-slides .group-data {
  position: relative;
  margin-top: 35px;
}
.group-detail-slides .group-data h3 {
  margin-bottom: 10px;
  font-size: 14px;
  text-align: center;
}
.group-detail-slides .group-data .setting-btn {
  position: absolute;
  top: 0;
  right: 0;
  width: 20px;
  height: 20px;
}
.group-detail-slides .group-data .data-table {
  margin-top: 20px;
}
.group-detail-slides .group-data .data-table tr:not(:first-child) th,
.group-detail-slides .group-data .data-table tr:not(:first-child) td {
  padding-top: 20px;
}
.group-detail-slides .group-data .data-table tr th {
  width: 110px;
  font-size: 14px;
  font-weight: 700;
}
.group-detail-slides.-campaign {
  margin: 0 -30px;
}
.group-detail-slides.-campaign .slide-item {
  margin: 0;
}
.group-detail-slides.-campaign .slick-prev {
  left: 30px;
}
.group-detail-slides.-campaign .slick-next {
  right: 30px;
}

.group-ranking {
  position: relative;
  margin-top: 25px;
  padding: 15px;
  background-color: #fef8e3;
  border-radius: 10px;
}
.group-ranking + .member-list {
  margin-top: 15px;
}
.group-ranking h3 {
  margin-bottom: 8px;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
}
.group-ranking .comment {
  text-align: center;
}
.group-ranking .comment span {
  display: inline-block;
  position: relative;
  z-index: 1;
  padding: 4px 17px;
  font-size: 12px;
  background-color: #fff;
  border-radius: 14px;
}
.group-ranking .comment span::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 5px 0 5px;
  border-color: #fff transparent transparent transparent;
  transform: translateX(-50%);
}
.group-ranking .rank-wrap {
  margin-top: 8px;
  margin-left: 55px;
}
.group-ranking .rank-wrap .rank .num {
  line-height: 1;
  font-size: 25px;
  font-weight: 700;
  font-family: Roboto;
}
.group-ranking .rank-wrap .steps .num {
  font-size: 16px;
  font-weight: 700;
  font-family: Roboto;
}
.group-ranking .leftover {
  margin-top: 15px;
  text-align: center;
}
.group-ranking .image {
  position: absolute;
  left: 5px;
  top: 80px;
  width: 65px;
  height: 65px;
  text-align: center;
}
.group-ranking .image img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  margin: auto;
}

#member-modal .modal-body {
  padding-bottom: 40px;
  background-color: #f6f6f6;
  border-radius: 0 0 8px 8px;
}
#member-modal .main-data {
  padding: 0 30px 20px;
  background-color: #fff;
  border-radius: 0 0 30px 30px;
}
#member-modal .main-data > .thumbnail {
  position: relative;
  width: 100px;
  height: 100px;
  margin: auto;
}
#member-modal .main-data > .thumbnail > .image > img {
  display: block;
  width: 100px;
  height: 100px;
  margin-bottom: 2px;
  object-fit: cover;
  border-radius: 100%;
}
#member-modal .main-data > .thumbnail > .leader {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 30px;
  height: 30px;
}
#member-modal .main-data > .name {
  margin-top: 15px;
  font-weight: 700;
}
#member-modal .main-data > .name > .gender {
  height: 20px;
  margin: 0 3px;
  vertical-align: text-bottom;
}
#member-modal .main-data > .steps {
  margin-top: 5px;
  font-size: 14px;
}
#member-modal .main-data > .steps > .num {
  font-size: 30px;
  font-weight: 700;
  font-family: Roboto;
}
#member-modal .main-data > .steps {
  margin-top: 8px;
  font-size: 14px;
}
#member-modal .main-data > .steps > .num {
  font-size: 30px;
  font-weight: 700;
  font-family: Roboto;
}
#member-modal .main-data > .introduction {
  margin-top: 15px;
}
#member-modal .main-data > .introduction > dt {
  font-size: 14px;
  font-weight: 700;
}
#member-modal .main-data > .introduction > dd {
  margin-top: 8px;
  text-align: left;
}
#member-modal .campaign-history {
  padding-left: 15px;
  padding-right: 15px;
}

.body-modal-posture__text {
  display: flex;
  align-items: center;
  margin-left: 10px;
  margin-right: 10px;
}
.body-modal-posture__text:before {
  content: "";
  flex-shrink: 0;
  margin-right: 0.5em;
  border-bottom: 4px solid;
  width: 35px;
}
.body-modal-posture__text.-green:before {
  color: #4eb9ad;
}
.body-modal-posture__text.-yellow:before {
  color: #e8b71a;
}
.body-modal-posture__text.-red:before {
  color: #fe6868;
}

#rank-wrap {
  margin: 0 -30px;
  padding: 25px 0;
  background: url(../images/common/bg_ranking.png) repeat-y 0 0 #eff9fa;
  background-size: 100% auto;
}
#rank-wrap .rank-tab1 {
  display: flex;
  width: 260px;
  height: 35px;
  margin: 0 auto;
  background-color: #fff;
  box-shadow: 0px 10px 10px 0px rgba(88, 129, 134, 0.15);
  border-radius: 100px;
}
#rank-wrap .rank-tab1.wide {
  margin: 0 30px;
  width: auto;
  font-size: 14px;
}
#rank-wrap .rank-tab1.wide > li {
  width: 50%;
}
#rank-wrap .rank-tab1.wide > li > button {
  width: 100%;
}
#rank-wrap .rank-tab1.wide > li > button::before {
  content: "";
  margin-bottom: 2px;
  width: 18px;
  height: 18px;
}
#rank-wrap .rank-tab1.wide > li > button.rank-individual-btn::before {
  background-image: url(../images/common/icon_individual_g.svg);
}
#rank-wrap .rank-tab1.wide > li > button.rank-individual-btn.-active::before {
  background-image: url(../images/common/icon_individual_w.svg);
}
#rank-wrap .rank-tab1.wide > li > button.rank-age-btn::before {
  background-image: url(../images/common/icon_age_g.svg);
}
#rank-wrap .rank-tab1.wide > li > button.rank-age-btn.-active::before {
  background-image: url(../images/common/icon_age_w.svg);
}
#rank-wrap .rank-tab1 > li {
  display: flex;
}
#rank-wrap .rank-tab1 > li > button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 130px;
  text-decoration: none;
  font-weight: bold;
  color: #aaa;
  background-color: transparent;
}
#rank-wrap .rank-tab1 > li > button.-active {
  color: #fff;
  background-color: #4eb9ad;
  border-radius: 18px;
}
#rank-wrap .rank-tab1 > li > button::before {
  content: "";
  display: block;
  margin-right: 8px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
#rank-wrap .rank-tab2 {
  display: flex;
  height: 45px;
  margin: 25px auto 0;
  border-bottom: 2px solid #4eb9ad;
}
#rank-wrap .rank-tab2 > li {
  display: flex;
  width: 50%;
}
#rank-wrap .rank-tab2 > li > button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  text-decoration: none;
  font-weight: bold;
  color: #aaa;
  background-color: #fff;
  border-radius: 6px 6px 0 0;
  box-shadow: 0px -10px 10px -10px rgba(88, 129, 134, 0.2);
}
#rank-wrap .rank-tab2 > li > button.-active {
  color: #fff;
  background-color: #4eb9ad;
}
#rank-wrap .rank-tab2 > li > button::before {
  content: "";
  display: block;
  margin-right: 8px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
#rank-wrap .rank-tab2 > li > button.rank-all-btn::before {
  width: 20px;
  height: 20px;
  background-image: url(../images/common/icon_japan_g.svg);
}
#rank-wrap .rank-tab2 > li > button.rank-all-btn.-active::before {
  background-image: url(../images/common/icon_japan_w.svg);
}
#rank-wrap .rank-tab2 > li > button.rank-area-btn::before {
  width: 13px;
  height: 18px;
  background-image: url(../images/common/icon_marker_g.svg);
}
#rank-wrap .rank-tab2 > li > button.rank-area-btn.-active::before {
  background-image: url(../images/common/icon_marker_w.svg);
}
#rank-wrap .rank-area-slides {
  position: relative;
}
#rank-wrap .rank-area-slides .slick-arrow {
  top: 0;
  width: 25px;
  height: 25px;
  margin-top: 0;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
#rank-wrap .rank-area-slides .slick-prev {
  left: 10px;
  background-image: url(../images/common/steps_slick_prev.png);
}
#rank-wrap .rank-area-slides .slick-next {
  right: 10px;
  background-image: url(../images/common/steps_slick_next.png);
}
#rank-wrap .rank-podium-wrap {
  margin: 25px 30px 0;
}
#rank-wrap .rank-podium-wrap > .box {
  display: flex;
  background-color: #fff;
  border-radius: 10px;
}
#rank-wrap .rank-podium-wrap > .box + .box {
  margin-top: 15px;
}
#rank-wrap .rank-podium-wrap > .box > .rank {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 88px;
  font-size: 18px;
  color: #fff;
  background: url(../../images/common/img_ranking_laurel.png) no-repeat 50% 50%;
  background-size: 75px auto;
  border-radius: 10px 0 0 10px;
}
#rank-wrap .rank-podium-wrap > .box > .rank > .num {
  display: inline-block;
  position: relative;
  top: -4px;
  font-size: 40px;
  font-weight: 700;
  font-family: Roboto;
  line-height: 1;
  vertical-align: text-bottom;
}
#rank-wrap .rank-podium-wrap > .box > .data {
  flex: 1 0 0%;
  overflow: hidden;
  width: 100%;
  padding: 8px 20px;
  border: 2px solid #eee;
  border-left: none;
  border-radius: 0 10px 10px 0;
}
#rank-wrap .rank-podium-wrap > .box > .data > .name {
  max-width: 100%;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 16px;
}
#rank-wrap .rank-podium-wrap > .box > .data > .steps {
  margin-top: 7px;
  padding-top: 7px;
  font-size: 16px;
  border-top: 2px solid #eee;
}
#rank-wrap .rank-podium-wrap > .box > .data > .steps > .num {
  font-size: 25px;
  font-family: Roboto;
  line-height: 1;
}
#rank-wrap .rank-podium-wrap > .box:nth-child(1) > .rank {
  background-color: #dacd00;
}
#rank-wrap .rank-podium-wrap > .box:nth-child(1) > .data {
  border-color: #dacd00;
}
#rank-wrap .rank-podium-wrap > .box:nth-child(1) > .data > .name {
  padding-left: 25px;
  background: url(/images/common/icon_trophy.png) 0 50% no-repeat;
  background-size: 17px auto;
}
#rank-wrap .rank-podium-wrap > .box:nth-child(2) > .rank {
  background-color: #b3b3b3;
}
#rank-wrap .rank-podium-wrap > .box:nth-child(3) > .rank {
  background-color: #c8962b;
}
#rank-wrap .rank-podium-wrap > .box.-myrank {
  position: relative;
}
#rank-wrap .rank-podium-wrap > .box.-myrank:before {
  content: "";
  display: block;
  border-radius: 50%;
  width: 35px;
  height: 35px;
  background-color: #4eb9ad;
  background-image: url(../images/common/icon_individual_w.svg);
  background-size: 24px;
  background-position: center;
  background-repeat: no-repeat;
  position: absolute;
  right: -10px;
  top: -10px;
}
#rank-wrap .rank-podium-wrap > .box.-myrank > .rank {
  border-top: 2px solid #4eb9ad;
  border-left: 2px solid #4eb9ad;
  border-bottom: 2px solid #4eb9ad;
}
#rank-wrap .rank-podium-wrap > .box.-myrank > .data {
  border-color: #4eb9ad;
  color: #4eb9ad;
}
#rank-wrap .rank-podium-wrap > .box.-myrank > .data > .steps {
  border-top-color: #4eb9ad;
}
#rank-wrap .rank-under-wrap {
  margin: 25px 30px 0;
  padding: 10px 5px;
  background-color: #fff;
  border-radius: 10px;
}
#rank-wrap .rank-under-wrap > ul {
  overflow-y: auto;
  max-height: 215px;
  padding: 0 15px;
  -webkit-overflow-scrolling: touch;
}
#rank-wrap .rank-under-wrap > ul > li {
  display: flex;
  align-items: flex-end;
  padding: 12px 0;
  font-size: 14px;
}
#rank-wrap .rank-under-wrap > ul > li + li {
  border-top: 1px solid #eee;
}
#rank-wrap .rank-under-wrap > ul > li > .rank {
  flex-shrink: 0;
  min-width: 40px;
  margin-right: 7px;
  text-align: right;
}
#rank-wrap .rank-under-wrap > ul > li > .rank > .num {
  font-size: 25px;
  font-weight: 700;
  margin-right: 3px;
  font-family: Roboto;
  line-height: 1;
  letter-spacing: -3px;
  color: #4eb9ad;
}
#rank-wrap .rank-under-wrap > ul > li > .name {
  flex: 1 0 0%;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
#rank-wrap .rank-under-wrap > ul > li > .steps {
  width: 90px;
  margin-left: 5px;
}
#rank-wrap .rank-under-wrap > ul > li > .steps > .num {
  font-size: 17px;
  font-family: Roboto;
  line-height: 1;
}
#rank-wrap .rank-under-wrap > ul > li > .steps > .num::before {
  content: ":";
  font-weight: 400;
  margin-right: 5px;
}
#rank-wrap .rank-under-wrap > ul > li.-myrank {
  color: #fff;
  background-color: #4eb9ad;
}
#rank-wrap .rank-under-wrap > ul > li.-myrank > .rank > .num {
  color: #fff;
}
#rank-wrap .rank-under-wrap2 {
  margin: 25px 30px 0;
}
#rank-wrap .rank-under-wrap2 > ul > li {
  display: flex;
  border-radius: 10px;
  background-color: #fff;
  padding: 12px 0;
  font-size: 14px;
}
#rank-wrap .rank-under-wrap2 > ul > li + li {
  margin-top: 15px;
}
#rank-wrap .rank-under-wrap2 > ul > li > .rank {
  flex-shrink: 0;
  justify-content: center;
  margin: -12px 0 -12px;
  border-radius: 10px 0 0 10px;
  border-top: 2px solid #e2e2e2;
  border-bottom: 2px solid #e2e2e2;
  border-left: 2px solid #e2e2e2;
  padding: 12px 0;
  min-width: 90px;
  height: auto;
  color: #909090;
  text-align: center;
  background-color: #e2e2e2;
}
#rank-wrap .rank-under-wrap2 > ul > li > .rank > .num {
  font-size: 25px;
  font-weight: 700;
  margin-right: 3px;
  font-family: Roboto;
  line-height: 1;
  letter-spacing: -3px;
}
#rank-wrap .rank-under-wrap2 > ul > li > .data {
  flex: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: -12px 0;
  padding: 12px 15px 12px 20px;
  border-radius: 0 10px 10px 0;
  border-top: 2px solid #eee;
  border-right: 2px solid #eee;
  border-bottom: 2px solid #eee;
}
#rank-wrap .rank-under-wrap2 > ul > li > .data > .name {
  flex: 1 0 0%;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 14px;
  overflow: hidden;
}
#rank-wrap .rank-under-wrap2 > ul > li > .data > .steps {
  margin-left: 5px;
}
#rank-wrap .rank-under-wrap2 > ul > li > .data > .steps > .num {
  font-size: 17px;
  font-family: Roboto;
  font-weight: 500;
  line-height: 1;
}
#rank-wrap .rank-under-wrap2 > ul > li.-myrank {
  position: relative;
}
#rank-wrap .rank-under-wrap2 > ul > li.-myrank:before {
  content: "";
  display: block;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  background-color: #4eb9ad;
  background-image: url(../images/common/icon_individual_w.svg);
  background-size: 20px;
  background-position: center;
  background-repeat: no-repeat;
  position: absolute;
  right: -10px;
  top: -10px;
}
#rank-wrap .rank-under-wrap2 > ul > li.-myrank > .rank, #rank-wrap .rank-under-wrap2 > ul > li.-myrank > .data {
  border-top-color: #4eb9ad;
  border-bottom-color: #4eb9ad;
}
#rank-wrap .rank-under-wrap2 > ul > li.-myrank > .rank {
  border-left-color: #4eb9ad;
}
#rank-wrap .rank-under-wrap2 > ul > li.-myrank > .data {
  border-right-color: #4eb9ad;
}
#rank-wrap .rank-under-wrap2 > ul > li.-myrank > .rank {
  color: #fff;
  background-color: #4eb9ad;
}
#rank-wrap .rank-area-tab {
  display: flex;
  justify-content: center;
  margin: 0 0 -5px;
  padding: 0 30px;
  background-color: #fff;
}
#rank-wrap .rank-area-tab li {
  flex: 1;
  display: flex;
  justify-content: center;
  max-width: 105px;
  vertical-align: top;
}
#rank-wrap .rank-area-tab li:not(:first-child):before {
  content: "";
  z-index: 1;
  display: block;
  align-self: center;
  width: 1px;
  height: 25px;
  background-color: #eee;
}
#rank-wrap .rank-area-tab li button {
  display: block;
  position: relative;
  width: 100%;
  padding: 12px 3px 18px;
  font-weight: 700;
  line-height: 1.3;
  color: #aaa;
  background-color: #fff;
}
#rank-wrap .rank-area-tab li button span {
  display: inline-block;
}
#rank-wrap .rank-area-tab li button::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  bottom: 6px;
  width: 3px;
  height: 3px;
  border: 2px solid;
  border-color: transparent #aaa #aaa transparent;
  transform: rotate(45deg) translateX(-50%);
}
#rank-wrap .rank-area-tab li button.-active {
  color: #01a08e;
}
#rank-wrap .rank-area-tab li button.-active::before {
  border-color: transparent #4eb9ad #4eb9ad transparent;
}
#rank-wrap .rank-area-tab li button.-active:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background-color: #4eb9ad;
}
#rank-wrap .rank-area-note {
  margin: 25px 30px -10px;
  padding: 3px;
  text-align: center;
  background-color: #fff;
  border-radius: 15px;
}
#rank-wrap .area-empty {
  padding: 12px 15px;
  font-size: 14px;
  text-align: center;
  background-color: #fff;
}
#rank-wrap .rank-empty {
  margin: 25px 30px 0;
  padding: 35px 15px;
  font-size: 14px;
  text-align: center;
  background-color: #fff;
  border-radius: 10px;
}
#rank-wrap .rank-my-note {
  margin: 25px 30px 0;
  padding: 15px 0;
  text-align: center;
  background-color: #fff;
  border-radius: 15px;
}

/* 10.ライフサポートトップ
----------------------------------------------------------- */
.top-ttl02 {
  text-align: center;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
  color: #222222;
  margin-bottom: 15px;
}

.news-list-type02 {
  padding-bottom: 10px;
  border-bottom: 2px solid #eeeeee;
  margin-bottom: 20px;
}
.news-list-type02 li {
  margin-bottom: 12px;
  line-height: 1.4;
}
.news-list-type02 li dl {
  display: flex;
}
.news-list-type02 li dl dt {
  width: 90px;
  padding-right: 5px;
  padding-top: 1px;
}
.news-list-type02 li dl dt strong {
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  font-size: 13px;
  color: #444444;
}
.news-list-type02 li dl dt i {
  margin-top: 3px;
  display: inline-block;
  border-radius: 4px;
  text-align: center;
  min-width: 50px;
  line-height: 1;
  padding: 3px 4px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
}
.news-list-type02 li dl dt i.mark-event {
  background: #fabf01;
}
.news-list-type02 li dl dt i.mark-contact {
  background: #66c4b9;
}
.news-list-type02 li dl dt i.mark-campaign {
  background: #f395a6;
}
.news-list-type02 li dl dd {
  width: calc(100% - 90px);
  font-size: 13px;
  color: #444444;
}
.news-list-type02 li dl dd a {
  color: #444444;
  text-decoration: underline;
}

.top-loginbtn-wrap {
  text-align: center;
  margin: 20px 0 0;
}

.top-loginbtn {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  width: 100%;
  text-align: center;
  margin: 0 auto;
  line-height: 1.1;
  font-size: 15px;
  font-weight: 700 !important;
  color: #fff !important;
  text-decoration: none !important;
  border-radius: 25px;
  padding: 0 5px;
  border: 2px solid #4eb9ad;
  background: #4eb9ad;
  box-shadow: 0 10px 20px -10px rgba(97, 151, 145, 0.2);
}
.top-loginbtn::after {
  content: " ";
  position: absolute;
  bottom: -2px;
  left: 30px;
  z-index: 2;
  width: 49px;
  height: 69px;
  background: url(../images/top/img_chara.png) 0 100% no-repeat;
  background-size: 100% 100%;
}

.top-content-list {
  margin: 25px -12px 0;
  display: flex;
  flex-wrap: wrap;
}
.top-content-list li {
  width: calc(50% - 24px);
  margin: 0 12px 24px;
  text-align: center;
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(97, 151, 145, 0.2);
}
.top-content-list li a {
  display: block;
  border-radius: 10px;
  overflow: hidden;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
}
.top-content-list li figure {
  line-height: 0;
}
.top-content-list li p {
  min-height: 57px;
  padding: 10px 5px;
  background: #4eb9ad;
  line-height: 1.4;
}
.top-content-list li p span.fs-s {
  display: block;
  font-size: 11px;
  margin-bottom: 2px;
}
.top-content-list li p span.fs-s-lc {
  font-size: 10px;
}
.top-content-list li.main {
  width: 100%;
}
.top-content-list li.main p {
  min-height: auto;
}

.walk-sleep-tab {
  display: flex;
  width: 260px;
  height: 35px;
  margin: 25px auto 15px;
  background-color: #fff;
  box-shadow: 0px 10px 10px 0px rgba(88, 129, 134, 0.15);
  border-radius: 18px;
}
.walk-sleep-tab > li {
  display: flex;
}
.walk-sleep-tab > li > button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 130px;
  text-decoration: none;
  font-weight: bold;
  color: #aaa;
  background-color: transparent;
}
.walk-sleep-tab > li > button.-active {
  color: #fff;
  background-color: #4eb9ad;
  border-radius: 18px;
}
.walk-sleep-tab > li > button::before {
  content: "";
  display: block;
  width: 24px;
  height: 22px;
  margin-right: 10px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
.walk-sleep-tab > li > button.walk-sleep-tab__walk-btn::before {
  background-image: url(../images/common/icon_foot_g.svg);
  background-size: auto 100%;
}
.walk-sleep-tab > li > button.walk-sleep-tab__walk-btn.-active::before {
  background-image: url(../images/common/icon_foot_w.svg);
}
.walk-sleep-tab > li > button.walk-sleep-tab__sleep-btn::before {
  background-image: url(../images/common/icon_bed_g.svg);
  background-size: 100% auto;
}
.walk-sleep-tab > li > button.walk-sleep-tab__sleep-btn.-active::before {
  background-image: url(../images/common/icon_bed_w.svg);
}

.top-day-slides {
  margin: 0;
  font-family: Roboto;
}
.top-day-slides .slide-item {
  margin: 0;
}
.top-day-slides h2 {
  font-size: 15px;
  font-weight: normal;
  text-align: center;
}
.top-day-slides h2 .day {
  font-size: 19px;
  font-weight: bold;
}
.top-day-slides .slick-arrow {
  top: 3px;
  width: 25px;
  height: 25px;
  margin-top: 0;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.top-day-slides .slick-prev {
  left: 10px;
  background-image: url(../images/common/steps_slick_prev.png);
}
.top-day-slides .slick-next {
  right: 10px;
  background-image: url(../images/common/steps_slick_next.png);
}
.top-day-slides .day-data {
  margin: 20px 10px 15px;
  padding: 20px 20px 15px;
  line-height: 1.5;
  text-align: center;
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0px 10px 10px 0px rgba(88, 129, 134, 0.15);
}
.top-day-slides .day-data h3 {
  font-size: 14px;
  font-weight: bold;
}
.top-day-slides .day-data .comment {
  display: inline-block;
  position: relative;
  z-index: 1;
  padding: 4px 17px;
  font-size: 12px;
  background-color: #fff;
  border: 1px solid #dfdfdf;
  border-radius: 14px;
}
.top-day-slides .day-data .comment::before, .top-day-slides .day-data .comment::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 6px 0 6px;
  border-color: #fff transparent transparent transparent;
  transform: translateX(-50%);
}
.top-day-slides .day-data .comment::before {
  border-top-color: #dfdfdf;
}
.top-day-slides .day-data .comment::after {
  margin-top: -2px;
}
.top-day-slides .day-data .day-steps-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-top: 5px;
}
.top-day-slides .day-data .day-steps-wrap .day-image {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 65px;
  height: 65px;
}
.top-day-slides .day-data .day-steps-wrap .day-image img {
  width: auto;
  height: auto;
  max-width: 65px;
  max-height: 65px;
}
.top-day-slides .day-data .day-steps-wrap .night-image {
  position: absolute;
  left: 0;
  bottom: -10px;
  width: 65px;
  height: 65px;
}
.top-day-slides .day-data .day-steps-wrap .night-image img {
  width: auto;
  height: auto;
  max-width: 65px;
  max-height: 65px;
}
.top-day-slides .day-data .day-steps-wrap .day-steps {
  margin: 0 10px 0 40px;
}
.top-day-slides .day-data .day-steps-wrap .day-steps .steps {
  font-size: 30px;
  font-weight: bold;
}
.top-day-slides .day-data .day-steps-wrap .sleeping-hours {
  margin: 0 10px;
}
.top-day-slides .day-data .day-steps-wrap .sleeping-hours .hour,
.top-day-slides .day-data .day-steps-wrap .sleeping-hours .minutes {
  font-size: 30px;
  font-weight: bold;
}
.top-day-slides .day-data .day-steps-wrap .reload-btn {
  width: 17px;
  height: 17px;
  background-color: transparent;
}
.top-day-slides .day-data .day-steps-wrap .sleep-start {
  position: absolute;
  right: -15px;
  top: -15px;
  width: 92px;
  background-color: transparent;
}
.top-day-slides .day-data .fromto-hours {
  margin-bottom: 8px;
  font-size: 11px;
}
.top-day-slides .day-data .fromto-hours .hour,
.top-day-slides .day-data .fromto-hours .minutes {
  font-size: 13px;
  font-weight: bold;
}
.top-day-slides .day-data .day-target-data {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: Roboto;
}
.top-day-slides .day-data .day-target-data .steps,
.top-day-slides .day-data .day-target-data .hour,
.top-day-slides .day-data .day-target-data .minutes {
  font-size: 16px;
  font-weight: bold;
}
.top-day-slides .day-data .day-target-data .setting-btn {
  width: 20px;
  height: 20px;
}
.top-day-slides .day-data .link-btn {
  margin-top: 15px;
  padding-top: 15px;
  border-top: 2px solid #eee;
}
.top-day-slides .day-data .link-btn .btn-type03, .top-day-slides .day-data .link-btn .btn-type06 {
  width: 200px;
  height: 40px;
  box-shadow: 0px 5px 15px 0px rgba(88, 129, 134, 0.15);
}
.top-day-slides .rest-data {
  margin: 15px 10px 0;
  padding: 15px 20px;
  text-align: center;
  background-color: #fff;
  border-radius: 8px;
}
.top-day-slides .rest-data h3 {
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 12px;
}
.top-day-slides .rest-data h3 .steps,
.top-day-slides .rest-data h3 .hour,
.top-day-slides .rest-data h3 .minutes {
  font-size: 17px;
}
.top-day-slides .rest-data .rest-line-wrap {
  position: relative;
}
.top-day-slides .rest-data .rest-line-wrap .rest-line {
  width: 100%;
  height: 10px;
  background-color: #eee;
  border-radius: 5px;
  overflow: hidden;
}
.top-day-slides .rest-data .rest-line-wrap .rest-line .line {
  content: "";
  display: block;
  width: 0;
  height: 10px;
  background-color: #8dd6df;
}
.top-day-slides .rest-data .rest-line-wrap .now {
  position: absolute;
  left: 0;
  bottom: 11px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 5px 0 5px;
  border-color: #444 transparent transparent transparent;
  transform: translateX(-50%);
}
.top-day-slides .rest-data .rest-line-wrap .image {
  content: "";
  display: block;
  position: absolute;
  left: 92%;
  top: -36px;
  width: 50px;
  height: 50px;
  background: url(../images/top/img_kusudama.png) no-repeat 0 0;
  background-size: auto 100%;
  transform: translateX(-50%);
}
.top-day-slides .rest-data .rest-line-wrap .image2 {
  content: "";
  display: block;
  position: absolute;
  left: 98%;
  top: -22px;
  width: 36px;
  height: 36px;
  background: url(../images/top/img_flag.png) no-repeat 0 0;
  background-size: auto 100%;
  transform: translateX(-50%);
}
.top-day-slides .rest-data .rest-line-wrap.-achieve .image {
  background-position-x: -250px;
}
.top-day-slides .slide-item:last-child .rest-data .rest-line-wrap .rest-line .line {
  transition: width 1s cubic-bezier(0.65, 0, 0.35, 1);
}
.top-day-slides .slide-item:last-child .rest-data .rest-line-wrap .now {
  transition: left 1s cubic-bezier(0.65, 0, 0.35, 1);
}
.top-day-slides .slide-item:last-child .rest-data .rest-line-wrap.-achieve .image {
  animation: kusudama 1.5s steps(5);
}
.top-day-slides.-walk .day-data {
  background: url(../../images/top/bg_day.png) no-repeat 0 0 #fff;
  background-size: 100% auto;
}
.top-day-slides.-sleep .day-data {
  background: url(../../images/top/bg_night.png) no-repeat 0 0 #fff;
  background-size: 100% auto;
}

@keyframes kusudama {
  0% {
    background-position-x: 0;
  }
  100% {
    background-position-x: -250px;
  }
}
#top-entry-modal h2 {
  margin-bottom: 15px;
  font-size: 16px;
  line-height: 1.5;
}
#top-entry-modal .top-entry-modal__inner:not(:first-child) {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 2px solid #eee;
}
#top-entry-modal .top-entry-modal__inner p {
  text-align: left;
}
#top-entry-modal .top-entry-modal__inner .flow-list li {
  position: relative;
  text-align: left;
  padding-left: 1.4em;
  line-height: 1.5;
}
#top-entry-modal .top-entry-modal__inner .flow-list li .num {
  position: absolute;
  left: 0;
  top: 0;
}
#top-entry-modal .top-entry-modal__inner .flow-list li:not(:first-child) {
  margin-top: 5px;
}
#top-entry-modal .btn-type01, #top-entry-modal .btn-type07, #top-entry-modal .btn-type01--new {
  margin-top: 15px;
}

.top-campaign-bnr {
  position: fixed;
  bottom: 0;
  z-index: 1000;
}
.top-campaign-bnr > ul > li > a > img {
  vertical-align: top;
}
.top-campaign-bnr > .close {
  position: absolute;
  top: 5px;
  right: 15px;
  width: 20px;
}

.sleep-think {
  padding: 20px 15px;
  background-color: #e9f4ff;
  border-radius: 10px;
}
.sleep-think__title {
  display: inline-block;
  margin-bottom: 8px;
  padding: 2px 12px;
  font-size: 14px;
  font-weight: bold;
  background-color: #fff;
  border-radius: 15px;
}
.sleep-think__image img {
  width: 65px;
}
.sleep-think__list {
  margin-top: 8px;
  text-align: left;
}
.sleep-think__list > li {
  margin-left: 20px;
  list-style: disc;
}
.sleep-think__list > li + li {
  margin-top: 5px;
}

.otpassword-step__item {
  display: flex;
  align-items: center;
  margin-top: 25px;
}
.otpassword-step__item:not(:first-child) {
  position: relative;
  margin-top: 25px;
}
.otpassword-step__item:not(:first-child)::before {
  content: "";
  position: absolute;
  top: -15px;
  left: 55px;
  height: 5px;
  width: 10px;
  background: #00a18f;
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
          clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.otpassword-step__image {
  width: 120px;
  margin-right: 25px;
}
.otpassword-step__image img {
  vertical-align: top;
}
.otpassword-step__text {
  flex: 1 0 0%;
  line-height: 1.5;
}
.otpassword-step__text h4 {
  margin-bottom: 4px;
  font-size: 16px;
  font-weight: 700;
  font-family: Roboto;
  color: #4eb9ad;
}
.login-top {
  margin-top: 69px;
  padding: 24px 20px;
  font-family: "Noto Sans JP", sans-serif;
  background-color: #F2FAF9;
}

.login-top-btn {
  font-family: "Noto Sans JP", sans-serif;
}
.login-top-btn__heading {
  margin-bottom: 8px;
  padding: 0 60px;
  font-size: 16px;
  line-height: 1.5;
}
.box-w--new .inner .login-top-btn__heading:first-child {
  padding-top: 79px;
}
.login-top-btn__btn a, .login-top-btn__btn input {
  position: relative;
  -webkit-appearance: none;
          appearance: none;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 48px;
  width: 100%;
  text-align: center;
  margin: 0 auto;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 700 !important;
  color: #fff !important;
  text-decoration: none !important;
  border-radius: 25px;
  padding: 0 70px;
  background: #008673;
}
.login-top-btn__btn a::after, .login-top-btn__btn input::after {
  content: " ";
  position: absolute;
  bottom: 0;
  left: 16px;
  z-index: 2;
  width: 52px;
  height: 78px;
  background: url(../images/top/img_chara02.svg) 0 100% no-repeat;
  background-size: 100% 100%;
}

/* 11.歩数
----------------------------------------------------------- */
.walk-day-slides {
  padding-top: 79px;
  font-family: Roboto;
}
.walk-day-slides h2 {
  font-size: 15px;
  font-weight: normal;
  text-align: center;
}
.walk-day-slides h2 .day {
  font-size: 19px;
  font-weight: bold;
}
.walk-day-slides .day-data {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.walk-day-slides .day-data .day-image {
  position: absolute;
  left: 25px;
  width: 47px;
  height: 47px;
}
.walk-day-slides .day-data .day-image img {
  width: auto;
  height: auto;
  max-width: 47px;
  max-height: 47px;
}
.walk-day-slides .day-data .day-steps {
  margin: 0 10px;
}
.walk-day-slides .day-data .day-steps .steps {
  font-size: 35px;
  font-weight: bold;
}
.walk-day-slides .day-data .reload-btn {
  width: 17px;
  height: 17px;
  background-color: transparent;
}
.walk-day-slides .slide-item:last-child .day-data .day-steps {
  margin: 0 10px 0 27px;
}
.walk-day-slides .rest-steps {
  text-align: center;
}
.walk-day-slides .rest-steps .steps {
  font-size: 19px;
  font-weight: bold;
}
.walk-day-slides .slick-arrow {
  top: 82px;
  width: 25px;
  height: 25px;
  margin-top: 0;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.walk-day-slides .slick-prev {
  background-image: url(../images/common/steps_slick_prev.png);
}
.walk-day-slides .slick-next {
  background-image: url(../images/common/steps_slick_next.png);
}

.walk-target-data {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 15px;
  padding-top: 15px;
  border-top: 2px solid #eee;
  font-family: Roboto;
}
.walk-target-data .target-steps .steps {
  font-size: 16px;
  font-weight: bold;
}
.walk-target-data .setting-btn {
  width: 20px;
  height: 20px;
}

.walk-month-slides {
  margin: 25px -10px 0;
  font-family: Roboto;
}
.walk-month-slides .slide-item {
  margin: 0 10px;
}
.walk-month-slides h2 {
  font-size: 15px;
  font-weight: normal;
  text-align: center;
}
.walk-month-slides h2 .day {
  font-size: 19px;
  font-weight: bold;
}
.walk-month-slides .slick-arrow {
  top: 3px;
  width: 25px;
  height: 25px;
  margin-top: 0;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.walk-month-slides .slick-prev {
  left: 10px;
  background-image: url(../images/common/steps_slick_prev.png);
}
.walk-month-slides .slick-next {
  right: 10px;
  background-image: url(../images/common/steps_slick_next.png);
}
.walk-month-slides .month-data-tab {
  display: flex;
  width: 260px;
  height: 35px;
  margin: 20px auto;
  background-color: #fff;
  box-shadow: 0px 10px 10px 0px rgba(88, 129, 134, 0.15);
  border-radius: 18px;
}
.walk-month-slides .month-data-tab > li {
  display: flex;
}
.walk-month-slides .month-data-tab > li > button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 130px;
  text-decoration: none;
  font-weight: bold;
  color: #aaa;
  background-color: transparent;
}
.walk-month-slides .month-data-tab > li > button.-active {
  color: #fff;
  background-color: #4eb9ad;
  border-radius: 18px;
}
.walk-month-slides .month-data-tab > li > button::before {
  content: "";
  display: block;
  width: 15px;
  height: 14px;
  margin-right: 10px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.walk-month-slides .month-data-tab > li > button.month-data-graph-btn::before {
  background-image: url(../images/common/icon_walk_graph_g.png);
}
.walk-month-slides .month-data-tab > li > button.month-data-graph-btn.-active::before {
  background-image: url(../images/common/icon_walk_graph_w.png);
}
.walk-month-slides .month-data-tab > li > button.month-data-list-btn::before {
  background-image: url(../images/common/icon_walk_list_g.png);
}
.walk-month-slides .month-data-tab > li > button.month-data-list-btn.-active::before {
  background-image: url(../images/common/icon_walk_list_w.png);
}
.walk-month-slides .month-data-text {
  margin: 10px 0;
  padding: 15px 20px;
  line-height: 1.5;
  text-align: center;
  background-color: #fff;
  border-radius: 8px;
}
.walk-month-slides .month-data-text .month-steps .steps {
  font-size: 16px;
  font-weight: bold;
}
.walk-month-slides .month-data-text .target-steps {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 2px solid #eee;
}
.walk-month-slides .month-data-text .target-steps .steps {
  font-size: 16px;
  font-weight: bold;
}
.walk-month-slides .month-data-text .target-steps::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
}
.walk-month-slides .month-data-text .target-steps .setting-btn {
  width: 20px;
  height: 20px;
}
.walk-month-slides .month-data-text .average-steps {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 2px solid #eee;
}
.walk-month-slides .month-data-text .average-steps .steps {
  font-size: 16px;
  font-weight: bold;
}
.walk-month-slides .walk-month-data-slides {
  margin: 10px -10px;
}
.walk-month-slides .walk-month-data-slides .slide-item2 {
  margin: 0 10px;
}
.walk-month-slides .walk-month-data-slides .month-data-graph {
  min-height: 215px;
  padding: 20px;
  background-color: #fff;
  border-radius: 8px;
  overflow: hidden;
}
.walk-month-slides .walk-month-data-slides .month-data-list {
  height: 215px;
  overflow-y: auto;
  padding: 20px;
  background-color: #fff;
  border-radius: 8px;
}
.walk-month-slides .walk-month-data-slides .month-data-list table {
  width: 100%;
}
.walk-month-slides .walk-month-data-slides .month-data-list th, .walk-month-slides .walk-month-data-slides .month-data-list td {
  padding: 10px 0;
  font-size: 14px;
  font-weight: normal;
  border-top: 1px #eee solid;
}
.walk-month-slides .walk-month-data-slides .month-data-list td {
  text-align: right;
}
.walk-month-slides .walk-month-data-slides .month-data-list td .steps {
  font-size: 16px;
  font-weight: bold;
}
.walk-month-slides .walk-month-data-slides .month-data-list tr:first-child th, .walk-month-slides .walk-month-data-slides .month-data-list tr:first-child td {
  padding-top: 0;
  border-top: none;
}
.walk-month-slides .walk-month-data-slides .month-data-list tr:last-child th, .walk-month-slides .walk-month-data-slides .month-data-list tr:last-child td {
  padding-bottom: 0;
}

.walk-campaign-bnr {
  position: relative;
  z-index: 1;
  padding-top: 79px;
  margin-bottom: -49px;
}
.walk-campaign-bnr .bnr {
  margin: 0 -30px;
}
.walk-campaign-bnr .link {
  margin-top: 5px;
  font-size: 14px;
  text-align: center;
}

.walk-rank-bnr img {
  vertical-align: top;
}

/* 12.キャンペーン説明
----------------------------------------------------------- */
.campaign-mv {
  margin: 0 -30px 25px;
}

.campaign-wrapper {
  padding: 30px 0;
  border-bottom: solid #eeeeee 1px;
}

.campaign-heading01 {
  font-size: 20px;
  font-weight: 700;
  text-align: left;
  color: #01a08e;
  line-height: 1.55;
  padding-top: 0;
}

.campaign-heading02 {
  font-size: 18px;
  margin-bottom: 25px;
  font-weight: 700;
}

.campaign-text {
  font-size: 13px;
  line-height: 1.75;
}
.campaign-text__container {
  padding: 18px 20px;
  background: #eff9fa;
  border-radius: 10px;
}
.campaign-text__wrapper {
  width: 100%;
  max-width: 160px;
}
.campaign-text.__flex {
  display: flex;
  align-items: baseline;
}

.campaign-flex {
  display: flex;
  justify-content: center;
  align-items: start;
  margin-top: 35px;
}
.campaign-flex__text {
  margin-left: auto;
  width: 100%;
  max-width: 230px;
}

.campaign-accent01 {
  font-size: 19px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 2px !important;
}

.campaign-accent02 {
  font-size: 29px;
  font-weight: 700;
  line-height: 1;
  color: #4eb9ad;
  letter-spacing: 5px !important;
  margin-left: auto;
}

.campaign-btn {
  width: 100%;
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background-color: white;
  border-top: solid #eeeeee 1px;
}

/* 13.睡眠
----------------------------------------------------------- */
#sleep {
  background: #f6f6f6;
}
#sleep .box-lb, #sleep .box-lb--new {
  background: #f6f6f6;
}
#sleep .box-lb .inner, #sleep .box-lb--new .inner {
  background: #fff;
  padding: 0;
}

.sleep-result__slides {
  padding-top: 79px;
  font-family: "roboto";
}
.sleep-result__slides h2 {
  font-size: 15px;
  font-weight: normal;
  text-align: center;
}
.sleep-result__slides h2 .day {
  font-size: 19px;
  font-weight: bold;
}
.sleep-result__box {
  margin: 15px 10px 10px;
  padding: 20px;
  text-align: left;
}
.sleep-result .sleep-result-data {
  display: flex;
  justify-content: space-around;
}
.sleep-result .sleep-result-data__upper {
  font-size: 11px;
  line-height: 1;
  text-align: center;
}
.sleep-result .sleep-result-data__upper .num {
  font-size: 13px;
  font-weight: 700;
}
.sleep-result .sleep-result-data__lower {
  margin-top: 10px;
  font-size: 14px;
  line-height: 1;
  text-align: center;
}
.sleep-result .sleep-result-data__lower .num {
  font-size: 35px;
  font-weight: 700;
}
.sleep-result .sleep-result-graph {
  position: absolute;
  top: 0;
  width: 100%;
}
.sleep-result .sleep-result-graph__wrap {
  position: relative;
  height: 0;
  margin-top: 8px;
  padding-top: 20%;
}
.sleep-result .canvas-note {
  display: flex;
  margin-top: 10px;
}
.sleep-result .canvas-note li {
  display: inline-block;
}
.sleep-result .canvas-note li::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 4px;
  vertical-align: -2px;
}
.sleep-result .canvas-note li:nth-child(1):before {
  background-color: #fbd14c;
}
.sleep-result .canvas-note li:nth-child(2):before {
  background-color: #81e1d6;
}
.sleep-result .canvas-note li:nth-child(3):before {
  background-color: #5c9dde;
}
.sleep-result .canvas-note li:last-child {
  margin-left: auto;
}
.sleep-result .canvas-note li:last-child:before {
  display: none;
}
.sleep-result .canvas-note li + li {
  margin-left: 15px;
}
.sleep-result .sleep-result-setting {
  position: relative;
  margin-top: 15px;
  padding-top: 15px;
  border-top: 2px solid #e9e9e9;
}
.sleep-result .sleep-result-setting table {
  margin: auto;
  line-height: 1.3;
}
.sleep-result .sleep-result-setting table th {
  font-weight: 400;
}
.sleep-result .sleep-result-setting table .num {
  font-size: 16px;
  font-weight: 400;
}
.sleep-result .sleep-result-setting__btn {
  position: absolute;
  right: 0;
  top: 17px;
  width: 20px;
  height: 20px;
}
.sleep-result .slick-arrow {
  top: 82px;
  width: 25px;
  height: 25px;
  margin-top: 0;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.sleep-result .slick-prev {
  left: 30px;
  background-image: url(../images/common/steps_slick_prev.png);
}
.sleep-result .slick-next {
  right: 30px;
  background-image: url(../images/common/steps_slick_next.png);
}

.sleep-record {
  position: relative;
  margin-top: 30px;
  font-family: "roboto";
}
.sleep-record__title {
  position: relative;
  margin-bottom: 15px;
  padding-left: 36px;
  font-size: 16px;
  font-weight: 700;
}
.sleep-record__title::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  width: 24px;
  height: 20px;
  line-height: 1;
  background: url(../images/common/icon_bed_gr.svg) 0 0 no-repeat;
  background-size: 100% auto;
  transform: translateY(-50%);
}
.sleep-record__graph-link {
  position: absolute;
  right: 0;
  top: 1px;
  padding-left: 25px;
}
.sleep-record__graph-link::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  width: 15px;
  height: 15px;
  line-height: 1;
  background: url(../images/common/icon_walk_graph_gr.svg) 0 0 no-repeat;
  background-size: 100% auto;
  transform: translateY(-50%);
}
.sleep-record .sleep-record-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.sleep-record .sleep-record-list__item {
  position: relative;
  width: 48%;
  padding: 1px;
  border: 2px solid #ddd;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0px 3px 8px 0px rgba(0, 0, 0, 0.05);
}
.sleep-record .sleep-record-list__item:nth-child(n+3) {
  margin-top: 15px;
}
.sleep-record .sleep-record-list h3 {
  position: relative;
  margin: 12px 12px 2px;
  padding-left: 16px;
  padding-right: 20px;
  font-size: 14px;
  line-height: 1.2;
  min-height: 2.4em;
}
.sleep-record .sleep-record-list h3::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0.2em;
  width: 11px;
  height: 11px;
  margin-right: 5px;
  background-color: #01a08e;
  border-radius: 50%;
}
.sleep-record .sleep-record-list__btn {
  position: absolute;
  right: 8px;
  top: 10px;
  width: 20px;
  background-color: transparent;
}
.sleep-record .sleep-record-list__data {
  margin-bottom: 10px;
  font-size: 14px;
  line-height: 1;
  text-align: center;
}
.sleep-record .sleep-record-list__data .num {
  font-size: 30px;
  font-weight: 700;
}

.sleep-start-btn {
  position: fixed;
  right: 20px;
  bottom: 10px;
  width: 92px;
  background-color: transparent;
}

#sleep .sleep-start-btn {
  bottom: 75px;
}

#measure {
  padding: 80px 0 20px;
  background: url(../images/common/bg_night.png) 0 0 no-repeat;
  background-size: 100% auto;
}
#measure.wakeup {
  background-image: url(../images/common/bg_day.png);
}
#measure .measure-character {
  text-align: center;
}
#measure .measure-character__fukidashi {
  display: inline-block;
  position: relative;
  z-index: 1;
  padding: 5px 23px;
  font-size: 16px;
  background-color: #fff;
  border: 1px solid #dfdfdf;
  border-radius: 25px;
}
#measure .measure-character__image {
  margin-top: 25px;
}
#measure .measure-character__image > img {
  width: 110px;
}
#measure .measure-time {
  margin-top: 30px;
  text-align: center;
}
#measure .measure-time > dt {
  font-size: 15px;
}
#measure .measure-time > dd {
  margin-top: 15px;
  font-size: 60px;
  font-family: "roboto";
  line-height: 1;
  letter-spacing: 2px;
}
#measure .measure-setting {
  width: 275px;
  margin: 50px auto 0;
}
#measure .measure-setting table {
  width: 100%;
}
#measure .measure-setting table th, #measure .measure-setting table td {
  padding: 23px 0 8px;
  font-size: 15px;
  text-align: left;
  border-bottom: 2px solid #eee;
}
#measure .measure-setting table tr:first-child th,
#measure .measure-setting table tr:first-child td {
  padding-top: 0;
}
#measure .measure-setting table td {
  text-align: right;
}
#measure .measure-setting table .num {
  font-size: 18px;
  font-family: "roboto";
}
#measure .btn-wrap {
  margin-top: 40px;
}
@media screen and (max-width: 374px) {
  #measure {
    padding: 70px 0 20px;
  }
  #measure .measure-time {
    margin-top: 10px;
  }
  #measure .measure-time > dd {
    margin-top: 5px;
  }
  #measure .measure-setting {
    margin-top: 20px;
  }
  #measure .measure-setting table th, #measure .measure-setting table td {
    padding-top: 13px;
  }
  #measure .btn-wrap {
    margin-top: 20px;
  }
}

/* 14.睡眠管理について
----------------------------------------------------------- */
.guide-btn {
  width: 100%;
  padding: 19px;
  font-size: 15px;
  font-weight: 700;
  text-align: center;
  background-color: #fff;
  border: 2px solid #ddd;
  border-radius: 8px;
  box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.05);
}

#alarm-setting-modal .step-list > li + li {
  margin-top: 25px;
}
#alarm-setting-modal dl {
  display: inline-flex;
  justify-content: center;
  margin: 10px 0;
  text-align: left;
}
#alarm-setting-modal dl dt {
  margin-top: 2px;
  margin-right: 8px;
  font-size: 16px;
  font-weight: 700;
  color: #4eb9ad;
  font-family: roboto;
  white-space: nowrap;
}
#alarm-setting-modal dl dd {
  font-size: 18px;
  font-weight: 700;
}
#alarm-setting-modal figure {
  margin-top: 15px;
}
#alarm-setting-modal__close {
  display: none;
  position: absolute;
  bottom: 30px;
  left: 0;
  width: 100%;
  z-index: 10;
}
#alarm-setting-modal__close > a {
  width: 200px;
}

/* 15.睡眠グラフ
----------------------------------------------------------- */
#sleep-graph > .inner {
  padding: 121px 0 0;
  background-color: #f6f6f6;
}
#sleep-graph .period-tab {
  display: flex;
  justify-content: center;
  position: fixed;
  top: 69px;
  left: 0;
  z-index: 2000;
  width: 100%;
  padding: 0 30px;
  background-color: rgba(255, 255, 255, 0.7);
}
#sleep-graph .period-tab li {
  flex: 1;
  display: flex;
  justify-content: center;
  max-width: 105px;
  vertical-align: top;
}
#sleep-graph .period-tab li:not(:first-child):before {
  content: "";
  z-index: 1;
  display: block;
  align-self: center;
  width: 1px;
  height: 25px;
  background-color: #eee;
}
#sleep-graph .period-tab li button {
  display: block;
  position: relative;
  width: 100%;
  padding: 15px 3px 21px;
  font-weight: 700;
  line-height: 1.3;
  color: #aaa;
  background-color: transparent;
}
#sleep-graph .period-tab li button span {
  display: inline-block;
}
#sleep-graph .period-tab li button::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  bottom: 6px;
  width: 3px;
  height: 3px;
  border: 2px solid;
  border-color: transparent #aaa #aaa transparent;
  transform: rotate(45deg) translateX(-50%);
}
#sleep-graph .period-tab li button.-active {
  color: #01a08e;
}
#sleep-graph .period-tab li button.-active::before {
  border-color: transparent #4eb9ad #4eb9ad transparent;
}
#sleep-graph .period-tab li button.-active:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background-color: #4eb9ad;
}
#sleep-graph .period-slides .item {
  padding: 30px 30px 120px;
}
@media screen and (max-width: 374px) {
  #sleep-graph .period-slides .item {
    padding-left: 10px;
    padding-right: 10px;
  }
}
#sleep-graph .graph-box {
  position: relative;
  padding: 23px 20px 20px;
  background-color: #fff;
  border-radius: 9px;
  box-shadow: 0px 0px 10px 0px rgba(88, 129, 134, 0.15);
}
#sleep-graph .graph-box:not(:first-child) {
  margin-top: 20px;
}
#sleep-graph .graph-box h3 {
  position: relative;
  padding-left: 16px;
  padding-right: 20px;
  font-size: 14px;
  min-height: 2.4em;
}
#sleep-graph .graph-box h3::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0.35em;
  width: 11px;
  height: 11px;
  margin-right: 5px;
  background-color: #01a08e;
  border-radius: 50%;
}
#sleep-graph .graph-box__btn {
  position: absolute;
  right: 20px;
  top: 23px;
  width: 20px;
  background-color: transparent;
}

/* 16.京丹後市Let’sチャレンジウォーキング
----------------------------------------------------------- */
#kyotango-challengewalking__thanks {
  padding: 10px 0;
  background-color: #fef8e3;
  box-shadow: 5px 0 7px rgba(88, 129, 134, 0.1);
  text-align: center;
}
#kyotango-challengewalking__thanks a[target=_blank]:after {
  content: "";
  display: inline-block;
  margin-left: 0.5em;
  width: 12px;
  height: 12px;
  vertical-align: -5%;
  background-image: url(../images/common/icon_blanklink.svg);
  background-size: cover;
}

#kyotango-challengewalking__wait {
  margin-top: 35px;
  text-align: center;
}
#kyotango-challengewalking__wait > img {
  width: 92px;
  height: auto;
}
#kyotango-challengewalking__wait > img + p {
  margin-top: 20px;
}

/* 17.体型管理
----------------------------------------------------------- */
#body {
  background: #f6f6f6;
}
#body .box-lb, #body .box-lb--new {
  background: #f6f6f6;
}
#body .box-lb .inner, #body .box-lb--new .inner {
  background: #fff;
  padding: 0;
}

.body-profile {
  padding: 69px 0 10px;
}
.body-profile__head {
  position: relative;
  padding: 10px 30px;
}
.body-profile__head h2 {
  display: inline-block;
  font-size: 16px;
  font-weight: 700;
}
.body-profile__head::before {
  content: "";
  display: block;
  position: absolute;
  top: 10px;
  right: 30px;
  width: 15px;
  height: 15px;
  border-right: 2px solid #4eb9ad;
  border-bottom: 2px solid #4eb9ad;
  transform: rotate(45deg);
}
.body-profile__date {
  display: inline-block;
  margin-left: 10px;
  font-size: 10px;
}
.body-profile__body {
  display: none;
  padding: 10px 30px;
}
.body-profile__data ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.body-profile__data ul li {
  width: calc(50% - 5px);
  font-size: 12px;
}
.body-profile__data ul li span {
  font-size: 15px;
  font-weight: 700;
  font-family: roboto, "ヒラギノ角ゴ Pro W6", sans-serif;
}
.body-profile__data ul li::before {
  content: "";
  display: inline-block;
  width: 21px;
  height: 21px;
  margin-right: 10px;
  vertical-align: middle;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
.body-profile__data ul li.gender::before {
  background-image: url(../images/common/icon_body_gender_gr.svg);
  background-size: auto 100%;
}
.body-profile__data ul li.age::before {
  background-image: url(../images/common/icon_body_age_gr.svg);
  background-size: auto 100%;
}
.body-profile__data ul li.height::before {
  background-image: url(../images/common/icon_body_height_gr.svg);
  background-size: auto 100%;
}
.body-profile__data ul li.weight::before {
  background-image: url(../images/common/icon_body_weight_gr.svg);
  background-size: auto 17px;
}
.body-profile.-active .body-profile__head::before {
  top: 20px;
  transform: rotate(-135deg);
}

.body-result {
  margin-top: 20px;
  padding-bottom: 94px;
}

.body-result-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.body-result-title__subject h2 {
  display: inline-block;
  font-size: 16px;
  font-weight: 700;
}
.body-result-title__date {
  display: inline-block;
  margin-left: 10px;
  font-size: 10px;
}

.body-result-tab {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: 16px;
  background-color: #fff;
  border-radius: 7px;
  box-shadow: 0px 5px 10px 0px rgba(88, 129, 134, 0.15);
}
.body-result-tab li {
  flex: 1;
  display: flex;
  justify-content: center;
  max-width: 105px;
  vertical-align: top;
}
.body-result-tab li:not(:first-child):before {
  content: "";
  z-index: 1;
  display: block;
  align-self: center;
  width: 1px;
  height: 30px;
  background-color: #eee;
}
.body-result-tab li button {
  display: block;
  position: relative;
  width: 100%;
  padding: 14px 3px;
  font-weight: 700;
  line-height: 1.3;
  color: #aaa;
  background-color: transparent;
}
.body-result-tab li button::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  top: calc(100% - 2px);
  border: 5px solid;
  border-color: transparent;
  transform: rotate(45deg) translateX(-50%);
}
.body-result-tab li button.-active {
  color: #fff;
  background-color: #4eb9ad;
  border-radius: 7px;
}
.body-result-tab li button.-active::before {
  border-color: transparent #4eb9ad #4eb9ad transparent;
}

.body-result-slides {
  margin: 18px -30px 0;
}
.body-result-slides__item {
  padding: 0 30px;
}

.body-result-detail {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 15px;
}
.body-result-detail__item {
  width: calc(50% - 8px);
  padding: 10px 13px 8px;
  font-size: 12px;
  text-decoration: none !important;
  background-color: #fff;
  border-radius: 10px;
}
.body-result-detail__item dd {
  position: relative;
  min-height: 46px;
}
.body-result-detail__item dd .image {
  position: absolute;
  left: 0;
  bottom: 4px;
}
.body-result-detail__item dd .compare {
  position: absolute;
  left: 37px;
  top: 0;
  font-size: 11px;
}
.body-result-detail__item dd .compare span {
  font-size: 14px;
  font-weight: 700;
  font-family: roboto, "ヒラギノ角ゴ Pro W6", sans-serif;
  line-height: 1.1;
}
.body-result-detail__item dd .compare.plus {
  color: #d37791;
}
.body-result-detail__item dd .compare.plus::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  margin-right: 3px;
  border-style: solid;
  border-width: 0 6px 10px 6px;
  border-color: transparent transparent #f5c3d1 transparent;
}
.body-result-detail__item dd .compare.minus {
  color: #448dcb;
}
.body-result-detail__item dd .compare.minus::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  margin-right: 3px;
  border-style: solid;
  border-width: 10px 6px 0 6px;
  border-color: #a8d2f0 transparent transparent transparent;
}
.body-result-detail__item dd .now {
  position: absolute;
  left: 37px;
  top: 19px;
  font-size: 12px;
}
.body-result-detail__item dd .now span {
  font-size: 24px;
  font-weight: 700;
  font-family: roboto, "ヒラギノ角ゴ Pro W6", sans-serif;
  line-height: 1.1;
}

.body-result-metabo__item {
  padding: 20px;
  font-size: 12px;
  background-color: #fff;
  border-radius: 10px;
}
.body-result-metabo__item:not(:first-child) {
  margin-top: 15px;
}
.body-result-metabo__item dd {
  display: flex;
  align-items: flex-start;
}
.body-result-metabo__item dd .compare {
  font-size: 11px;
}
.body-result-metabo__item dd .compare span {
  font-size: 14px;
  font-weight: 700;
  font-family: roboto, "ヒラギノ角ゴ Pro W6", sans-serif;
  line-height: 1.1;
}
.body-result-metabo__item dd .compare.plus {
  color: #d37791;
}
.body-result-metabo__item dd .compare.plus::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  margin-right: 3px;
  border-style: solid;
  border-width: 0 5px 8px 5px;
  border-color: transparent transparent #f5c3d1 transparent;
}
.body-result-metabo__item dd .compare.minus {
  color: #448dcb;
}
.body-result-metabo__item dd .compare.minus::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  margin-right: 3px;
  border-style: solid;
  border-width: 8px 5px 0 5px;
  border-color: #a8d2f0 transparent transparent transparent;
}
.body-result-metabo__item dd .now {
  margin-right: 3px;
  font-size: 12px;
}
.body-result-metabo__item dd .now span {
  font-size: 24px;
  font-weight: 700;
  font-family: roboto, "ヒラギノ角ゴ Pro W6", sans-serif;
  line-height: 1.1;
}
.body-result-metabo__table {
  margin-top: 5px;
}
.body-result-metabo__table table {
  width: 100%;
  border-width: 0;
  border-collapse: collapse;
  table-layout: fixed;
}
.body-result-metabo__table table caption {
  margin-bottom: 3px;
  text-align: left;
}
.body-result-metabo__table table tr th,
.body-result-metabo__table table tr td {
  padding: 8px 3px;
  font-size: 10px;
  line-height: 1.5;
  text-align: center;
  background-color: #f6f6f6;
  border: 1px solid #ddd;
}
.body-result-metabo__table table tr .current {
  color: #fff;
  background-color: #54ccc5;
}

.body-result-comparison__item {
  padding: 20px;
  font-size: 12px;
  background-color: #fff;
  border-radius: 10px;
}
.body-result-comparison__supplement {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #666;
}
.body-result-comparison__supplement p {
  display: flex;
  align-items: center;
  line-height: 1.2;
}
.body-result-comparison__supplement p:before {
  content: "";
  display: block;
  width: 35px;
  height: 12px;
  margin-right: 6px;
}
.body-result-comparison__basis:before {
  background-color: rgba(232, 183, 26, 0.3);
  border: 1px solid rgb(232, 183, 26);
}
.body-result-comparison__yours:before {
  background-color: rgba(1, 160, 142, 0.3);
  border: 1px solid rgb(1, 160, 142);
}
.body-result-comparison__yours {
  margin-left: 15px;
}

.body-result-posture__item {
  padding: 20px;
  font-size: 12px;
  background-color: #fff;
  border-radius: 10px;
}
.body-result-posture__wrap {
  display: flex;
  justify-content: space-between;
}
.body-result-posture__front {
  width: 134px;
}
.body-result-posture__side {
  width: 111px;
}
.body-result-posture canvas {
  max-width: 100%;
}
.body-result-posture__caption {
  margin-bottom: 15px;
  padding: 4px 13px;
  display: inline-block;
  font-weight: 700;
  color: #fff;
  background-color: #66c4b9;
  border-radius: 5px;
}
.body-result-posture__text {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
}
.body-result-posture__text > div + div {
  margin-left: 1em;
}
.body-result-posture__text dl {
  display: flex;
}
.body-result-posture__text dl + dl {
  margin-top: 0.4em;
}
.body-result-posture__text dt {
  width: 30px;
  position: relative;
}
.body-result-posture__text dt:after {
  content: "：";
  position: absolute;
  right: 0;
}
.body-analysis {
  padding-top: 69px;
}
.body-analysis__item {
  margin-top: 25px;
  padding: 20px;
  font-size: 12px;
  background-color: #fff;
  border-radius: 10px;
}
.body-analysis canvas {
  max-width: 100%;
}
.body-analysis__side {
  margin-top: 30px;
}
.body-analysis__captionwrap {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
}
.body-analysis__caption {
  padding: 4px 6px;
  display: inline-block;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0;
  background-color: #66c4b9;
  border-radius: 5px;
}
.body-analysis__date {
  margin-left: 10px;
  margin-right: 10px;
  font-size: 9px;
}
.body-analysis__link {
  margin-left: auto;
}
.body-analysis__supplement {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
}
.body-analysis__supplement p:before {
  content: "";
  display: inline-block;
  width: 27px;
  height: 2px;
  margin-right: 10px;
  vertical-align: 4px;
}
.body-analysis__basis:before {
  background-image: linear-gradient(to right, #aaa, #aaa 3px, transparent 3px, transparent);
  background-size: 6px 2px;
  background-repeat: repeat-x;
}
.body-analysis__yours:before {
  background-color: #4eb9ad;
}
.body-analysis__yours {
  margin-left: 20px;
}

.body-start-btn {
  position: fixed;
  right: 20px;
  bottom: 10px;
  width: 92px;
  background-color: transparent;
}

#body .body-start-btn {
  bottom: 75px;
}

#part-graph > .inner {
  padding: 69px 0 0;
  background-color: #f6f6f6;
}
#part-graph .part-heading {
  display: flex;
  justify-content: space-between;
  padding: 5px 30px;
  background-color: #fff;
}
#part-graph .part-heading h2 {
  font-size: 16px;
}
#part-graph .part-heading h2 button {
  background-color: transparent;
}
#part-graph .part-heading h2 img {
  width: 20px;
  vertical-align: middle;
}
#part-graph .part-heading .now {
  font-size: 12px;
}
#part-graph .part-heading .now span {
  padding-left: 5px;
  font-size: 24px;
  font-weight: 700;
  font-family: roboto, "ヒラギノ角ゴ Pro W6", sans-serif;
  line-height: 1.1;
}
#part-graph .period-tab {
  display: flex;
  justify-content: center;
  width: 100%;
  padding: 0 30px;
  background-color: #fff;
}
#part-graph .period-tab li {
  flex: 1;
  display: flex;
  justify-content: center;
  max-width: 105px;
  vertical-align: top;
}
#part-graph .period-tab li:not(:first-child):before {
  content: "";
  z-index: 1;
  display: block;
  align-self: center;
  width: 1px;
  height: 25px;
  background-color: #eee;
}
#part-graph .period-tab li button {
  display: block;
  position: relative;
  width: 100%;
  padding: 15px 3px 21px;
  font-weight: 700;
  line-height: 1.3;
  color: #aaa;
  background-color: transparent;
}
#part-graph .period-tab li button span {
  display: inline-block;
}
#part-graph .period-tab li button::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  bottom: 6px;
  width: 3px;
  height: 3px;
  border: 2px solid;
  border-color: transparent #aaa #aaa transparent;
  transform: rotate(45deg) translateX(-50%);
}
#part-graph .period-tab li button.-active {
  color: #01a08e;
}
#part-graph .period-tab li button.-active::before {
  border-color: transparent #4eb9ad #4eb9ad transparent;
}
#part-graph .period-tab li button.-active:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background-color: #4eb9ad;
}
#part-graph .period-slides .item {
  padding: 30px 30px 120px;
}
@media screen and (max-width: 374px) {
  #part-graph .period-slides .item {
    padding-left: 10px;
    padding-right: 10px;
  }
}
#part-graph .graph-caption {
  margin-bottom: 15px;
  font-size: 10px;
  text-align: center;
}
#part-graph .graph-box {
  position: relative;
  padding: 23px 20px 20px;
  background-color: #fff;
  border-radius: 9px;
  box-shadow: 0px 0px 10px 0px rgba(88, 129, 134, 0.15);
}
#part-graph .graph-box h3 {
  position: relative;
  padding-left: 16px;
  padding-right: 20px;
  font-size: 14px;
  min-height: 2.4em;
}
#part-graph .graph-box h3::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0.35em;
  width: 11px;
  height: 11px;
  margin-right: 5px;
  background-color: #01a08e;
  border-radius: 50%;
}
#part-graph .graph-box__btn {
  position: absolute;
  right: 20px;
  top: 23px;
  width: 20px;
  background-color: transparent;
}

#body-measure-modal .step-list > li + li {
  margin-top: 25px;
}
#body-measure-modal dl {
  display: inline-flex;
  justify-content: center;
  margin: 10px 0;
  text-align: left;
}
#body-measure-modal dl dt {
  margin-top: 2px;
  margin-right: 8px;
  font-size: 16px;
  font-weight: 700;
  color: #4eb9ad;
  font-family: roboto;
  white-space: nowrap;
}
#body-measure-modal dl dd {
  font-size: 18px;
  font-weight: 700;
}
#body-measure-modal figure {
  margin-top: 15px;
}
#body-measure-modal__close {
  display: none;
  position: absolute;
  bottom: 30px;
  left: 0;
  width: 100%;
  z-index: 10;
}
#body-measure-modal__close > a {
  width: 200px;
}

/* **.その他
----------------------------------------------------------- */
.migratoin-text {
  border-top: 2px solid #eeeeee;
  padding-top: 20px;
  margin-bottom: 15px;
}
.migratoin-text p {
  font-size: 12px;
  text-indent: -1em;
  padding-left: 1em;
}

.migratoin-text02 {
  border-top: 2px solid #eeeeee;
  padding-top: 20px;
  margin-bottom: 15px;
}
.migratoin-text02 p {
  font-size: 13px;
  text-align: center;
}

.biometrics-registration-form {
  margin: 0 -30px;
}
.biometrics-registration-form .tab {
  display: flex;
  height: 45px;
  margin: 25px auto 0;
  border-bottom: 2px solid #4eb9ad;
}
.biometrics-registration-form .tab > li {
  display: flex;
  width: 50%;
}
.biometrics-registration-form .tab > li > button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  text-decoration: none;
  font-weight: bold;
  color: #aaa;
  background-color: #fff;
  border-radius: 6px 6px 0 0;
  box-shadow: 0px 0 10px 0 rgba(88, 129, 134, 0.2);
}
.biometrics-registration-form .tab > li > button.-active {
  color: #fff;
  background-color: #4eb9ad;
}
.biometrics-registration-form .tab > li > button::before {
  content: "";
  display: block;
  margin-right: 8px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.biometrics-registration-form .tab > li > button.id-btn::before {
  width: 16px;
  height: 16px;
  background-image: url(../images/common/icon_individual_g.svg);
}
.biometrics-registration-form .tab > li > button.id-btn.-active::before {
  background-image: url(../images/common/icon_individual_w.svg);
}
.biometrics-registration-form .tab > li > button.number-btn::before {
  width: 16px;
  height: 16px;
  background-image: url(../images/common/icon_card_g.svg);
}
.biometrics-registration-form .tab > li > button.number-btn.-active::before {
  background-image: url(../images/common/icon_card_w.svg);
}
.biometrics-registration-form .slides {
  padding: 25px 30px;
}

/* 18.食事管理
----------------------------------------------------------- */
#meal {
  background: #f6f6f6;
}
#meal .box-lb, #meal .box-lb--new {
  background: #f6f6f6;
}
#meal .box-lb .inner, #meal .box-lb--new .inner {
  background: #fff;
  padding: 0 0 35px;
}

.meal-wrap {
  padding: 0 30px;
}

.meal-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 5px 0;
}
.meal-title__heading {
  margin: 0;
  padding: 0;
  font-size: 20px;
  font-weight: 700;
}
.meal-title__link > a {
  display: inline-block;
  padding-left: 25px;
  padding-right: 8px;
  line-height: 20px;
  background: url(../images/common/icon_help.png) no-repeat 0 0;
  background-size: 20px auto;
}

.meal-card-slides {
  margin: 0 -30px;
}
.meal-card-slides .slick-arrow {
  top: 50%;
  width: 30px;
  height: 30px;
  margin-top: 0;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: 100% auto;
  transform: translateY(-50%);
}
.meal-card-slides .slick-prev {
  left: 7px;
  background-image: url(../images/common/steps_slick_prev.png);
}
.meal-card-slides .slick-next {
  right: 7px;
  background-image: url(../images/common/steps_slick_next.png);
}

.meal-card-slides__item {
  margin: 25px 30px 30px;
}

.meal-btn__state {
  display: block;
  padding: 11px 10px 10px 40px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  color: #fff;
  background: url(../../images/common/icon_dish_xmark_w.svg) 10px 50% no-repeat #C1C1C1;
  background-size: 25px auto;
  border-radius: 3px;
  -webkit-appearance: none;
          appearance: none;
}
.meal-btn__state.-simple {
  width: 33px;
  height: 33px;
  padding: 0;
  background-position: 50% 50%;
}
.meal-btn__state.-selected {
  background-color: #4EB9AD;
  background-image: url(../../images/common/icon_dish_w.svg);
}
.meal-btn__favorite {
  display: block;
  padding: 11px 9px 10px 32px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  color: #C6C6C6;
  background: url(../../images/common/icon_heart_g.svg) 10px 50% no-repeat #fff;
  background-size: 16px auto;
  border: 1px solid #C6C6C6;
  border-radius: 3px;
  -webkit-appearance: none;
          appearance: none;
}
.meal-btn__favorite.-simple {
  width: 33px;
  height: 33px;
  padding: 0;
  background-position: 50% 50%;
}
.meal-btn__favorite.-selected {
  color: #fff;
  background-color: #E67288;
  background-image: url(../../images/common/icon_heart_w.svg);
  border: none;
}

.meal-card {
  position: relative;
  overflow: hidden;
  padding: 15px 17px 22px;
  background-color: #fff;
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
}
.meal-card__btns {
  display: flex;
  justify-content: flex-end;
  gap: 5px;
  margin-bottom: 8px;
}
.meal-card__tag {
  display: flex;
  gap: 4px;
  margin: 7px 0 10px;
}
.meal-card__tag > li {
  padding: 4px 13px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  color: #4EB9AD;
  border: 1px solid #4EB9AD;
  border-radius: 100px;
}
.meal-card__images {
  display: flex;
  gap: 7px;
  margin-bottom: 15px;
}
.meal-card__images > li {
  overflow: hidden;
  border-radius: 5px;
}
.meal-card__images > li > img {
  vertical-align: top;
}
.meal-card__menu-list {
  margin-bottom: 15px;
}
.meal-card__menu-list > dl {
  display: flex;
  align-items: center;
  column-gap: 6px;
}
.meal-card__menu-list > dl + dl {
  margin-top: 7px;
}
.meal-card__menu-list > dl > dt {
  padding: 4px 6px;
  font-size: 13px;
  line-height: 1;
}
.meal-card__menu-list > dl > dt {
  padding: 4px 6px;
  font-size: 13px;
  line-height: 1;
  color: #fff;
  border-radius: 3px;
}
.meal-card__menu-list > dl > dd {
  flex: 1 0 0%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.meal-card__menu-type01 {
  background-color: #E397A6;
}
.meal-card__menu-type02 {
  background-color: #89B3D6;
}
.meal-card__menu-type03 {
  background-color: #6ABC96;
}
.meal-card__menu-type04 {
  background-color: #BCD175;
}
.meal-card__nutrient {
  margin-bottom: 20px;
  border: 2px solid #DDD;
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(173, 173, 173, 0.15);
}
.meal-card__nutrient > button {
  position: relative;
  width: 100%;
  padding: 10px 40px;
  font-size: 15px;
  font-weight: 700;
  background-color: transparent;
  -webkit-appearance: none;
          appearance: none;
}
.meal-card__nutrient > button::before, .meal-card__nutrient > button::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 17px;
  height: 2px;
  margin-top: -1px;
  background-color: #4EB9AD;
  border-radius: 2px;
}
.meal-card__nutrient > button::after {
  transform: rotate(90deg);
}
.meal-card__nutrient.-active button::after {
  transform: rotate(180deg);
}
.meal-card__nutrient-body {
  display: none;
  position: relative;
  padding: 14px 20px 18px;
}
.meal-card__nutrient-body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 20px;
  right: 20px;
  height: 2px;
  background-color: #EEE;
}
.meal-card__nutrient-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  row-gap: 6px;
  font-size: 11px;
}
.meal-card__nutrient-list > li {
  width: 56%;
}
.meal-card__nutrient-list > li:nth-child(2n) {
  width: 42%;
}
.meal-card__nutrient-note {
  margin-top: 13px;
  font-size: 12px;
}
.meal-card__time {
  float: left;
  padding-left: 22px;
  background: url(../../images/common/icon_clock_gr.svg) 0 0.35em no-repeat;
  background-size: 16px auto;
}
.meal-card__time-num {
  font-size: 15px;
  font-weight: 700;
  font-family: roboto;
}
.meal-card__time-unit {
  font-weight: 700;
}
.meal-card__detail-link {
  float: right;
}

.user-data {
  margin-top: 30px;
  background-color: #fff;
  border: 2px solid #4EB9AD;
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(97, 151, 145, 0.15);
}
.user-data > button {
  display: block;
  width: 100%;
  position: relative;
  padding: 20px;
  font-size: 15px;
  font-weight: 700;
  color: #4EB9AD;
  background-color: transparent;
  -webkit-appearance: none;
          appearance: none;
}
.user-data__accordion-icon {
  display: block;
  position: absolute;
  right: 22px;
  top: 22px;
  width: 12px;
  height: 12px;
}
.user-data__accordion-icon::before, .user-data__accordion-icon::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 8px;
  height: 2px;
  transform: translateY(-50%);
  background-color: #01A08E;
  border-radius: 2px;
}
.user-data__accordion-icon::before {
  transform: translateY(-50%) rotate(45deg);
}
.user-data__accordion-icon::after {
  left: 4px;
  transform: translateY(-50%) rotate(135deg);
}
.user-data.-active .user-data__accordion-icon {
  transform: rotate(180deg);
}
.user-data__body {
  display: none;
  position: relative;
  padding: 30px 22px;
}
.user-data__body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 22px;
  right: 22px;
  height: 2px;
  background-color: #DBF1EF;
}
.user-data__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  row-gap: 15px;
  padding: 0 10px;
}
.user-data__list > li {
  position: relative;
  width: 118px;
  padding-left: 29px;
  font-size: 12px;
}
.user-data__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 0;
  top: 1px;
  width: 20px;
  height: 20px;
}
.user-data__large-text {
  font-size: 13px;
  font-weight: 700;
}

.user-setting {
  margin-top: 30px;
}
.user-setting__item {
  display: flex;
  margin-top: 15px;
}
.user-setting__item.-exercise {
  display: block;
}
.user-setting__label {
  position: relative;
  width: 93px;
  padding: 8px 0 8px 29px;
  font-size: 14px;
  font-weight: bold;
}
.user-setting__label-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 0;
  top: 10px;
  width: 20px;
  height: 20px;
}
.user-setting__input-wrap {
  flex: 1 0 0%;
  position: relative;
}
.user-setting__input-wrap.-eraser .select-type01, .user-setting__input-wrap.-eraser .select-type02, .user-setting__input-wrap.-unit .input-type01 {
  max-width: calc(100% - 40px);
}
.user-setting__input-wrap .select-type01, .user-setting__input-wrap .select-type02 {
  color: #444;
}
.user-setting__eraser {
  -webkit-appearance: none;
  appearance: none;
  background: url(../images/common/icon_eraser.png) 0 0 no-repeat;
  background-size: 30px 30px;
  border: none;
  outline: 0;
  width: 30px;
  height: 30px;
  position: absolute;
  top: 5px;
  right: 0;
}
.user-setting__unit {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  position: absolute;
  top: 5px;
  right: 0;
  font-size: 14px;
}
.user-setting__radio-exercise {
  position: absolute;
  z-index: -1;
  opacity: 0;
}
.user-setting__radio-exercise + label {
  display: flex;
  align-items: center;
  position: relative;
  min-height: 85px;
  padding: 5px 20px 5px 80px;
  font-size: 14px;
  font-weight: 700;
  color: #4EB9AD;
  background-color: #fff;
  border: 2px solid #eee;
  border-radius: 10px;
  background-repeat: no-repeat;
}
.user-setting__radio-exercise#exercise1 + label {
  background-image: url(../../images/common/img_exercise_01.png);
  background-size: 30px auto;
  background-position: 23px 50%;
}
.user-setting__radio-exercise#exercise2 + label {
  background-image: url(../../images/common/img_exercise_02.png);
  background-size: 44px auto;
  background-position: 16px 50%;
}
.user-setting__radio-exercise#exercise3 + label {
  background-image: url(../../images/common/img_exercise_03.png);
  background-size: 56px auto;
  background-position: 10px 50%;
}
.user-setting__radio-exercise:checked + label {
  background-color: #EFF9FA;
  border-color: #4EB9AD;
}
.user-setting__radio-exercise-level {
  position: absolute;
  right: 5px;
  top: -15px;
  padding: 0 8px;
  font-size: 13px;
  font-weight: 700;
  border-radius: 7px;
  color: #fff;
}
#exercise1 + label .user-setting__radio-exercise-level {
  background-color: #FFBCBC;
}
#exercise2 + label .user-setting__radio-exercise-level {
  background-color: #FF9A9A;
}
#exercise3 + label .user-setting__radio-exercise-level {
  background-color: #FF7B7B;
}

.meal-search__heading {
  position: relative;
  padding-left: 20px;
  font-size: 15px;
  font-weight: 700;
}
.meal-search__heading::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0.4em;
  width: 14px;
  height: 14px;
  background-color: #4EB9AD;
  border-radius: 100%;
}
.meal-search__heading02 {
  display: flex;
  align-items: flex-start;
  font-size: 13px;
}
.meal-search__heading02-label {
  display: inline-block;
  margin-top: 4px;
  margin-right: 8px;
  padding: 0 5px;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
  border-radius: 3px;
}
.meal-search__heading02-label.-theme {
  background-color: #4EB9AD;
}
.meal-search__heading02-label.-meal {
  background-color: #63D670;
}
.meal-search__check {
  position: absolute;
  z-index: -1;
  opacity: 0;
}
.meal-search__check + label {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: relative;
  width: 100%;
  min-height: 70px;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  color: #4EB9AD;
  background-color: #fff;
  border: 2px solid #4EB9AD;
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(97, 151, 145, 0.15);
}
.meal-search__check:checked + label {
  color: #fff;
  background-color: #4EB9AD;
}
.meal-search__check + label i.meal-icon {
  display: block;
  width: 25px;
  height: 25px;
  margin-bottom: 4px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../../images/common/icon_meal_meat_gr.svg);
}

.search-theme__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}
.search-theme__list > li {
  width: calc((100% - 24px) / 4);
}
.search-theme__about {
  margin-top: 10px;
  border: 2px solid #DDD;
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(173, 173, 173, 0.15);
}
.search-theme__about > button {
  position: relative;
  width: 100%;
  padding: 10px 40px;
  font-size: 15px;
  font-weight: 700;
  background-color: transparent;
  -webkit-appearance: none;
          appearance: none;
}
.search-theme__about > button::before, .search-theme__about > button::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 17px;
  height: 2px;
  margin-top: -1px;
  background-color: #4EB9AD;
  border-radius: 2px;
}
.search-theme__about > button::after {
  transform: rotate(90deg);
}
.search-theme__about.-active button::after {
  transform: rotate(180deg);
}
.search-theme__about-body {
  display: none;
  position: relative;
  padding: 14px 20px 18px;
}
.search-theme__about-body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 20px;
  right: 20px;
  height: 2px;
  background-color: #EEE;
}
.search-theme__about-list > li + li {
  margin-top: 15px;
}

.search-meal__tab-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 15px;
}
.search-meal__tab-list > li {
  width: calc((100% - 8px) / 2);
}
.search-meal__tab-list > li > button {
  position: relative;
  cursor: pointer;
}
.search-meal__tab-list i[class^=meal-icon] {
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
}
.search-meal .tab__contents:not(.-active) {
  display: none;
}
.search-meal__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 15px;
}
.search-meal__list > li {
  width: calc((100% - 24px) / 4);
}

.meal-result-assist {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  margin-bottom: 30px;
}
.meal-result-assist__total {
  font-size: 10px;
}
.meal-result-assist__narrow-down > button {
  padding-left: 23px;
  font-size: 13px;
  text-decoration: underline;
  background: url(../../images/common/icon_setting2_gr.svg) 0 0.2em no-repeat transparent;
  background-size: 16px auto;
  -webkit-appearance: none;
          appearance: none;
}
.meal-result-assist__search {
  width: 100%;
  margin-top: 10px;
}

.meal-result-selected {
  margin-bottom: 15px;
}
.meal-result-selected > dl {
  display: flex;
}
.meal-result-selected > dl > dt {
  padding: 4px 0;
  font-size: 11px;
  white-space: nowrap;
}
.meal-result-selected > dl > dd {
  flex: 1 0 0%;
}
.meal-result-selected > dl > dd > ul {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.meal-result-selected > dl > dd > ul > li {
  padding: 3px 7px;
  font-size: 12px;
  color: #4EB9AD;
  background-color: #EFF9FA;
  border-radius: 5px;
}

.meal-result-list > .meal-card:not(:first-child) {
  display: none;
  margin-top: 20px;
}

.meal-favorite-list > .meal-card:not(:first-child) {
  margin-top: 20px;
}

.meal-card-more {
  text-decoration: underline;
  background-color: transparent;
}

.pagination {
  margin-top: 30px;
  text-align: center;
}
.pagination > ul {
  display: flex;
  justify-content: center;
  font-family: roboto;
}
.pagination > ul > li > a,
.pagination > ul > li > span {
  padding: 5px 11px;
  font-size: 16px;
  font-weight: 700;
}
.pagination > ul > li > span {
  text-decoration: underline;
  color: #4EB9AD;
}
.pagination > ul > li > a {
  text-decoration: none;
}

.narrow-down-list {
  margin-top: 12px;
}
.narrow-down-list > ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 8px;
}
.narrow-down-list > ul + ul {
  margin-top: 10px;
}
.narrow-down-list .meal-search__check + label {
  min-height: 50px;
  padding-inline: 20px;
}

#howto-meal-modal .step-list > li + li {
  margin-top: 25px;
}
#howto-meal-modal dl {
  display: inline-flex;
  justify-content: center;
  margin: 10px 0;
  text-align: left;
}
#howto-meal-modal dl dt {
  margin-top: 2px;
  margin-right: 8px;
  font-size: 16px;
  font-weight: 700;
  color: #4eb9ad;
  font-family: roboto;
  white-space: nowrap;
}
#howto-meal-modal dl dd {
  font-size: 18px;
  font-weight: 700;
}
#howto-meal-modal figure {
  margin-top: 15px;
}
#howto-meal-modal__close {
  display: none;
  position: absolute;
  bottom: 30px;
  left: 0;
  width: 100%;
  z-index: 10;
}
#howto-meal-modal__close > a {
  width: 200px;
}

.meal-guide-list__item {
  counter-increment: cnt;
  position: relative;
  margin-inline: 8px;
}
.meal-guide-list__item.circle-decimal {
  padding-left: 24px;
}
.meal-guide-list__item.circle-decimal::before {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0.3em;
  left: 0;
  width: 16px;
  height: 16px;
  font-size: 12px;
  font-weight: 700;
  font-family: roboto;
  line-height: 1;
  color: #fff;
  background-color: #E8B71A;
  border-radius: 100%;
  content: counter(cnt);
}
.meal-guide-list__item + li {
  margin-top: 20px;
}

.meal-nutrient {
  background-color: #fff;
  border: 2px solid #4EB9AD;
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(97, 151, 145, 0.15);
}
.meal-nutrient__head {
  padding: 20px 22px;
  text-align: center;
}
.meal-nutrient__heading {
  font-size: 15px;
  font-weight: 700;
  color: #4EB9AD;
}
.meal-nutrient__link {
  margin-top: 10px;
}
.meal-nutrient__link > a {
  display: inline-block;
  padding-left: 23px;
  padding-right: 10px;
  line-height: 20px;
  background: url(../images/common/icon_walk_graph_gr.svg) no-repeat 0 0.2em;
  background-size: 16px auto;
}
.meal-nutrient__body {
  position: relative;
  padding: 20px 22px;
}
.meal-nutrient__body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 22px;
  right: 22px;
  height: 2px;
  background-color: #DBF1EF;
}
.meal-nutrient__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  font-size: 12px;
}
.meal-nutrient__list > li {
  position: relative;
  width: 53%;
  padding-left: 9px;
}
.meal-nutrient__list > li::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background-color: #01A08E;
  border-radius: 100%;
}
.meal-nutrient__list > li:nth-child(2n) {
  width: calc(47% - 12px);
}
.meal-nutrient__num {
  font-size: 15px;
  font-family: roboto;
}
.meal-nutrient__unit {
  margin-left: 3px;
  font-family: roboto;
}

.meal-detail__btns {
  display: flex;
  justify-content: flex-end;
  gap: 5px;
}
.meal-detail__nutrient {
  margin-top: 8px;
}
.meal-detail__time {
  float: right;
  padding-left: 22px;
  background: url(../../images/common/icon_clock_gr.svg) 0 0.35em no-repeat;
  background-size: 16px auto;
}
.meal-detail__time-num {
  font-size: 15px;
  font-weight: 700;
  font-family: roboto;
}
.meal-detail__time-unit {
  font-weight: 700;
}
.meal-detail__menu {
  margin-top: 15px;
}
.meal-detail__menu-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
.meal-detail__menu-item + .meal-detail__menu-item {
  margin-top: 20px;
}
.meal-detail__menu-picture {
  overflow: hidden;
  width: 80px;
  border-radius: 5px;
}
.meal-detail__menu-picture [class^=meal-detail__menu-picture-type] {
  display: block;
  text-align: center;
  color: #fff;
}
.meal-detail__menu-picture-type01 {
  background-color: #E397A6;
}
.meal-detail__menu-picture-type02 {
  background-color: #89B3D6;
}
.meal-detail__menu-picture-type03 {
  background-color: #6ABC96;
}
.meal-detail__menu-picture-type04 {
  background-color: #BCD175;
}
.meal-detail__menu-picture img {
  vertical-align: top;
}
.meal-detail__menu-body {
  flex: 1 0 0%;
}
.meal-detail__menu-btn > a {
  width: 100%;
}
.meal-detail__menu-name {
  font-size: 15px;
  font-weight: 700;
}
.meal-detail__menu-cal {
  font-size: 12px;
  padding-left: 18px;
  background: url(../../images/common/icon_meal_cal_r.svg) 0 0.35em no-repeat;
  background-size: 13px auto;
}
.meal-detail__menu-cal-num {
  margin-right: 3px;
  font-size: 15px;
  font-weight: 700;
  font-family: roboto;
}
.meal-detail__menu-cal-unit {
  font-family: roboto;
}
.meal-detail__menu-btn {
  margin-top: 11px;
}
.meal-detail__menu-btn > a {
  background-image: url(../../images/common/icon_new_window_gr.svg);
  background-position: top 50% right 20px;
  background-repeat: no-repeat;
  background-size: 15px auto;
}

.meal-graph {
  padding-inline: 22px;
}

.meal-graph-detail__nutrient {
  margin-top: 30px;
  background-color: #fff;
  border: 2px solid #4EB9AD;
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(97, 151, 145, 0.15);
}
.meal-graph-detail__nutrient-head {
  padding: 20px 22px;
  text-align: center;
}
.meal-graph-detail__nutrient-heading {
  font-size: 15px;
  font-weight: 700;
  color: #4EB9AD;
}
.meal-graph-detail__nutrient-body {
  position: relative;
  padding: 20px 22px;
}
.meal-graph-detail__nutrient-body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 22px;
  right: 22px;
  height: 2px;
  background-color: #DBF1EF;
}
.meal-graph-detail__nutrient-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  font-size: 12px;
}
.meal-graph-detail__nutrient-list > li {
  position: relative;
  width: 53%;
  padding-left: 9px;
}
.meal-graph-detail__nutrient-list > li::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background-color: #01A08E;
  border-radius: 100%;
}
.meal-graph-detail__nutrient-list > li:nth-child(2n) {
  width: calc(47% - 12px);
}
.meal-graph-detail__nutrient-num {
  font-size: 15px;
  font-family: roboto;
}
.meal-graph-detail__nutrient-unit {
  margin-left: 3px;
  font-family: roboto;
}

.meal-graph-image {
  display: flex;
  gap: 7px;
}
.meal-graph-image > li {
  overflow: hidden;
  border-radius: 5px;
}
.meal-graph-image > li > img {
  vertical-align: top;
}

.meal-menu {
  background-color: #fff;
  border: 2px solid #4EB9AD;
  border-radius: 10px;
  box-shadow: 0 5px 7px rgba(97, 151, 145, 0.15);
}
.meal-menu__head {
  padding: 20px 22px;
  text-align: center;
}
.meal-menu__heading {
  font-size: 15px;
  font-weight: 700;
  color: #4EB9AD;
}
.meal-menu__body {
  position: relative;
  padding: 20px 22px;
}
.meal-menu__body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 22px;
  right: 22px;
  height: 2px;
  background-color: #DBF1EF;
}
.meal-menu__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  font-size: 12px;
}
.meal-menu__list > li {
  position: relative;
  padding-left: 9px;
}
.meal-menu__list > li::before {
  content: "";
  position: absolute;
  top: 0.55em;
  left: 0;
  width: 6px;
  height: 6px;
  background-color: #01A08E;
  border-radius: 100%;
}

#agreementCheck {
  transform: scale(1.5);
}

.meal-loading-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  margin: 25px auto 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.44;
  text-align: center;
  color: #666;
}
.meal-loading-text__line01, .meal-loading-text__line02 {
  display: flex;
  align-items: center;
  white-space: nowrap;
}
.meal-loading-text__inner {
  overflow: hidden;
  width: 0;
  white-space: nowrap;
  animation: loading-text-line 0.4s 0.2s ease-out forwards;
}
.meal-loading-text__line02 > .meal-loading-text__inner {
  animation-duration: 0.45s;
  animation-delay: 1s;
}
.meal-loading-text__dots {
  width: 18px;
  height: 18px;
}
.meal-loading-text__dots::after {
  content: "";
  display: block;
  width: 18px;
  height: 1px;
}
.meal-loading-text__dots > span {
  display: block;
  position: absolute;
  width: 0;
  height: 18px;
  overflow: hidden;
  animation: loading-text-dots 4s 0.9s ease-out infinite forwards;
}
.meal-loading-text__dots > span > span,
.meal-loading-text__dots > span::before,
.meal-loading-text__dots > span::after {
  display: block;
  position: absolute;
  top: 8px;
  width: 4px;
  height: 4px;
  background-color: #666;
  border-radius: 50%;
}
.meal-loading-text__dots > span::before,
.meal-loading-text__dots > span::after {
  content: "";
}
.meal-loading-text__dots > span > span {
  left: 1px;
}
.meal-loading-text__dots > span::before {
  left: 7px;
}
.meal-loading-text__dots > span::after {
  left: 13px;
}

@keyframes loading-text-line {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}
@keyframes loading-text-dots {
  0% {
    width: 0;
  }
  24% {
    width: 0;
  }
  25% {
    width: 6px;
  }
  49% {
    width: 6px;
  }
  50% {
    width: 12px;
  }
  74% {
    width: 12px;
  }
  75% {
    width: 18px;
  }
  100% {
    width: 18px;
  }
}
.meal-loading-tips {
  margin-top: 40px;
  padding: 15px 20px 20px;
  color: #FFF;
  background-color: #4FB9AD;
  border-radius: 10px;
}
.meal-loading-tips__title {
  margin-bottom: 8px;
  font-size: 15px;
  font-weight: 700;
  text-align: center;
}

/* 19.お問合わせ先
----------------------------------------------------------- */
.pic-info__heading {
  margin: 16px 0 8px;
  font-size: 16px;
  line-height: 1.5;
  text-align: center;
}
.pic-info__box {
  position: relative;
  padding: 20px;
  background-color: #fff;
  border-radius: 24px;
}
.pic-info__parson {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pic-info__thumb {
  width: 56px;
}
.pic-info__thumb > img {
  vertical-align: top;
}
.pic-info__text {
  flex: 1 0 0%;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4285714286;
}
.pic-info__dept {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0 10px;
  margin-bottom: 4px;
  font-weight: 400;
}
.pic-info__name {
  font-size: 18px;
  line-height: 1.4444444444;
}
.pic-info__contact {
  display: flex;
  justify-content: center;
  gap: 0 40px;
  margin-top: 16px;
}
.pic-info__contact > li > a, .pic-info__contact > li > button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 56px;
  height: 56px;
  background-color: #FFF;
  border: 3px solid #008673;
  border-radius: 8px;
}
.pic-info__contact > li > .-disabled {
  background-color: #D5D5D5;
  border-color: #939393;
  pointer-events: none;
}
.-disabled .pic-info__icon01 path, .-disabled .pic-info__icon02 path {
  stroke: #939393;
}
.-disabled .pic-info__icon03 path {
  fill: #939393;
}
.pic-info__note {
  position: relative;
  margin-top: 16px;
  padding-left: 16px;
  font-size: 12px;
  line-height: 1.1666666667;
}
.pic-info__note::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.pic-info__note-em {
  color: #9C2F2F;
}
.pic-info__link {
  margin-top: 16px;
  text-align: center;
}
.pic-info__link > a {
  display: inline-block;
  position: relative;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4285714286;
  text-decoration: none;
  color: #008673;
}
.pic-info__link > a::after {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  margin-left: 4px;
  vertical-align: -7px;
  background: url(../../images/common/icon_arrow.svg) 50% 50% no-repeat;
}
.pic-info__acc {
  background-color: #fff;
  border-radius: 24px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}
.pic-info__acc + .pic-info__acc {
  margin-top: 24px;
}
.pic-info__acc-btn {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 56px;
  padding: 12px 24px;
}
.pic-info__acc-btn > * {
  padding-right: 48px;
}
.pic-info__acc-icon[type=button] {
  display: block;
  position: absolute;
  right: 29px;
  top: 50%;
  width: 22px;
  height: 22px;
  padding: 0;
  background-color: #CCEBE6;
  border-radius: 50%;
  transform: translateY(-50%);
  -webkit-appearance: none;
          appearance: none;
}
.pic-info__acc-icon[type=button]::before, .pic-info__acc-icon[type=button]::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 10px;
  width: 14px;
  height: 2px;
  background-color: #008673;
  border-radius: 1px;
}
.pic-info__acc-icon[type=button]::after {
  transform: rotate(-90deg);
  transition: transform 0.2s;
}
.pic-info__acc.-active .pic-info__acc-icon[type=button]::after {
  transform: rotate(0);
}
.pic-info__acc-body {
  display: none;
  padding: 4px 24px 16px;
}
.pic-info__support {
  margin-top: 32px;
}
.pic-info__acc-body .pic-info__contact {
  margin-top: 8px;
}
.pic-info__error {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 22px;
}
.pic-info__error, .pic-info__error::before {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 1;
}
.pic-info__error::before {
  content: "";
  display: block;
  background-color: #FFF;
  opacity: 0.7;
  z-index: -1;
  border-radius: 24px;
}
.pic-info__error-box {
  padding: 24px 16px;
  background-color: #FDEBCC;
  border-radius: 16px;
}
.pic-info__error-heading {
  margin-bottom: 16px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #003D34;
}
.pic-info__error-text {
  font-size: 14px;
  line-height: 1.4285714286;
}
.pic-info__error-text > a {
  display: inline-block;
  font-weight: 700;
  text-decoration: none;
  color: #008673;
}
.pic-info__error-text > a::after {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-left: 4px;
  vertical-align: -2px;
  background: url(../../images/common/icon_arrow_down.svg) 50% 50% no-repeat;
}

.other-contact {
  margin-top: 16px;
  font-family: "Noto Sans JP", sans-serif;
  background-color: #FFF;
  border: 1px solid #CCEBE6;
  border-radius: 16px;
  overflow: hidden;
}
.other-contact__heading {
  padding: 16px;
  font-size: 14px;
  line-height: 1.4285714286;
  text-align: center;
  color: #003D34;
  background-color: #CCEBE6;
}
.other-contact__body {
  padding: 16px;
}
.other-contact .pic-info-support__link {
  margin-top: 16px;
}

.pic-info-support {
  margin-top: 32px;
}
.pic-info-support__text {
  font-size: 14px;
  line-height: 1.4285714286;
}
.pic-info-support__link {
  margin-top: 8px;
}
.pic-info-support__link > a {
  display: inline-block;
  padding: 4px 0 4px 36px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  text-decoration: none;
  color: #008673;
  background: url(../../images/common/icon_support.svg) 3px 50% no-repeat;
}

.line-contact {
  text-align: left;
  font-family: "Noto Sans JP", sans-serif;
}
.line-contact__heading {
  margin-bottom: 16px;
  font-size: 16px;
  line-height: 1.5;
}
.line-contact__text {
  margin: 16px 0;
  font-size: 14px;
  line-height: 1.4285714286;
}
.line-contact__image {
  margin: 16px 0;
}
.line-contact__image img {
  vertical-align: top;
}
.line-contact__checkbox {
  position: relative;
  margin: 16px 0;
}
.line-contact__checkbox > input[type=checkbox] {
  display: none;
}
.line-contact__checkbox > input + label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 16px;
  line-height: 1.5;
}
.line-contact__checkbox > input + label::before {
  content: "";
  display: block;
  width: 32px;
  height: 32px;
  background: url(../../images/common/icon_checkbox.png) 0 0 no-repeat;
  background-size: cover;
}
.line-contact__checkbox > input:checked + label::before {
  background-position-x: -32px;
}
.line-contact__btn {
  margin-top: 32px;
}

.pic-list {
  margin-top: 32px;
  font-family: "Noto Sans JP", sans-serif;
}
.pic-list__heading {
  margin-bottom: 16px;
  padding-top: 0;
  font-size: 18px;
  line-height: 1.4444444444;
  text-align: center;
}
.pic-list .pic-info__note {
  margin-top: 24px;
}

/* Slick Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
}

.slick-track:before,
.slick-track:after {
  display: table;
  content: "";
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px;
  outline: none;
}

[dir=rtl] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
  margin: 0 auto;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* Slider */
/* Arrows */
.slick-prev,
.slick-next {
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  display: block;
  width: 40px;
  height: 96px;
  margin-top: -48px;
  padding: 0;
  cursor: pointer;
  color: transparent;
  background: none;
  border: none;
  outline: 0;
  z-index: 900;
}

.slick-prev:focus,
.slick-next:focus {
  outline: 0;
}

.slick-prev.slick-disabled,
.slick-next.slick-disabled {
  display: none !important;
}

.slick-prev {
  left: 0;
  border-radius: 0;
}

.slick-prev:hover {
  opacity: 0.8;
}

.slick-next {
  right: 0;
  border-radius: 0;
}

.slick-next:hover {
  opacity: 0.8;
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 0px;
}

.slick-dots {
  position: absolute;
  bottom: 0px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  width: 8px;
  height: 8px;
  margin: 0 6px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 4px;
  outline: 0;
  border: none;
  background: #dddddd;
  border: 1px solid #fff;
  cursor: pointer;
}

.slick-dots li button:hover,
.slick-dots li.slick-active button {
  background: #4fb9ad;
  border: 1px solid #4fb9ad;
}

/* SP */
@media screen and (max-width: 768px) {
  /*--------------*/
}
/*
	File Name   : module.scss
	Description : 共通モジュールcss
*/
/* common
----------------------------------------------- */
img {
  max-width: 100%;
  height: auto;
}

th img,
td img {
  max-width: inherit;
  height: inherit;
}

.cl {
  clear: both;
}

.none {
  display: none !important;
}

/* clearfix */
.cf:before, .cf:after {
  content: "";
  display: table;
}

.cf:after {
  clear: both;
}

/* font系 */
.bold {
  font-weight: 700 !important;
}

.normal {
  font-weight: 400 !important;
}

/* view */
.sp-view {
  display: block !important;
}

/**/
.align-r_sp {
  text-align: right !important;
}

.align-c_sp {
  text-align: center !important;
}

.align-l_sp {
  text-align: left !important;
}

/* font-size */
.fs8_sp {
  font-size: 8px !important;
}

.fs9_sp {
  font-size: 9px !important;
}

.fs10_sp {
  font-size: 10px !important;
}

.fs11_sp {
  font-size: 11px !important;
}

.fs12_sp {
  font-size: 12px !important;
}

.fs13_sp {
  font-size: 13px !important;
}

.fs14_sp {
  font-size: 14px !important;
}

.fs15_sp {
  font-size: 15px !important;
}

.fs16_sp {
  font-size: 16px !important;
}

.fs17_sp {
  font-size: 17px !important;
}

.fs18_sp {
  font-size: 18px !important;
}

.fs19_sp {
  font-size: 19px !important;
}

.fs20_sp {
  font-size: 20px !important;
}

.fs21_sp {
  font-size: 21px !important;
}

.fs22_sp {
  font-size: 22px !important;
}

.fs23_sp {
  font-size: 23px !important;
}

.fs24_sp {
  font-size: 24px !important;
}

.fs25_sp {
  font-size: 25px !important;
}

/* margin-top */
.mt10_sp_minus {
  margin-top: -10px !important;
}

.mt5_sp_minus {
  margin-top: -5px !important;
}

.mt0_sp {
  margin-top: 0 !important;
}

.mt5_sp {
  margin-top: 5px !important;
}

.mt10_sp {
  margin-top: 10px !important;
}

.mt15_sp {
  margin-top: 15px !important;
}

.mt20_sp {
  margin-top: 20px !important;
}

.mt25_sp {
  margin-top: 25px !important;
}

.mt30_sp {
  margin-top: 30px !important;
}

.mt35_sp {
  margin-top: 35px !important;
}

.mt40_sp {
  margin-top: 40px !important;
}

.mt45_sp {
  margin-top: 45px !important;
}

.mt50_sp {
  margin-top: 50px !important;
}

/* margin-bottom */
.mb0_sp {
  margin-bottom: 0 !important;
}

.mb5_sp {
  margin-bottom: 5px !important;
}

.mb10_sp {
  margin-bottom: 10px !important;
}

.mb15_sp {
  margin-bottom: 15px !important;
}

.mb20_sp {
  margin-bottom: 20px !important;
}

.mb25_sp {
  margin-bottom: 25px !important;
}

.mb30_sp {
  margin-bottom: 30px !important;
}

.mb35_sp {
  margin-bottom: 35px !important;
}

.mb40_sp {
  margin-bottom: 40px !important;
}

.mb50_sp {
  margin-bottom: 50px !important;
}

.mb60_sp {
  margin-bottom: 60px !important;
}

.mb70_sp {
  margin-bottom: 70px !important;
}

.mb100_sp {
  margin-bottom: 100px !important;
}

/* margin-right */
.mr10_sp_minus {
  margin-right: -10px !important;
}

.mr0_sp {
  margin-right: 0 !important;
}

.mr5_sp {
  margin-right: 5px !important;
}

.mr10_sp {
  margin-right: 10px !important;
}

.mr15_sp {
  margin-right: 15px !important;
}

.mr20_sp {
  margin-right: 20px !important;
}

.mr30_sp {
  margin-right: 30px !important;
}

.mr40_sp {
  margin-right: 40px !important;
}

.mr50_sp {
  margin-right: 50px !important;
}

/* margin-left */
.ml0_sp {
  margin-left: 0 !important;
}

.ml5_sp {
  margin-left: 5px !important;
}

.ml10_sp {
  margin-left: 10px !important;
}

.ml15_sp {
  margin-left: 15px !important;
}

.ml20_sp {
  margin-left: 20px !important;
}

.ml30_sp {
  margin-left: 30px !important;
}

.ml40_sp {
  margin-left: 40px !important;
}

.ml50_sp {
  margin-left: 50px !important;
}

/* padding-top */
.pt0_sp {
  padding-top: 0 !important;
}

.pt5_sp {
  padding-top: 5px !important;
}

.pt10_sp {
  padding-top: 10px !important;
}

.pt15_sp {
  padding-top: 15px !important;
}

.pt20_sp {
  padding-top: 20px !important;
}

.pt25_sp {
  padding-top: 25px !important;
}

.pt30_sp {
  padding-top: 30px !important;
}

.pt35_sp {
  padding-top: 35px !important;
}

.pt40_sp {
  padding-top: 40px !important;
}

.pt45_sp {
  padding-top: 45px !important;
}

.pt50_sp {
  padding-top: 50px !important;
}

/* padding-bottom */
.pb0_sp {
  padding-bottom: 0 !important;
}

.pb5_sp {
  padding-bottom: 5px !important;
}

.pb10_sp {
  padding-bottom: 10px !important;
}

.pb15_sp {
  padding-bottom: 15px !important;
}

.pb20_sp {
  padding-bottom: 20px !important;
}

.pb25_sp {
  padding-bottom: 25px !important;
}

.pb30_sp {
  padding-bottom: 30px !important;
}

.pb35_sp {
  padding-bottom: 35px !important;
}

.pb40_sp {
  padding-bottom: 40px !important;
}

.pb50_sp {
  padding-bottom: 50px !important;
}

/* padding-right */
.pr0_sp {
  padding-right: 0 !important;
}

.pr5_sp {
  padding-right: 5px !important;
}

.pr10_sp {
  padding-right: 10px !important;
}

.pr15_sp {
  padding-right: 15px !important;
}

.pr20_sp {
  padding-right: 20px !important;
}

.pr30_sp {
  padding-right: 30px !important;
}

.pr40_sp {
  padding-right: 40px !important;
}

.pr50_sp {
  padding-right: 50px !important;
}

/* padding-left */
.pl0_sp {
  padding-left: 0 !important;
}

.pl5_sp {
  padding-left: 5px !important;
}

.pl10_sp {
  padding-left: 10px !important;
}

.pl15_sp {
  padding-left: 15px !important;
}

.pl20_sp {
  padding-left: 20px !important;
}

.pl30_sp {
  padding-left: 30px !important;
}

.pl40_sp {
  padding-left: 40px !important;
}

.pl50_sp {
  padding-left: 50px !important;
}

/* width-size % */
.w100p_sp {
  width: 100% !important;
}

.w50p_sp {
  width: 50% !important;
}

.w25p_sp {
  width: 25% !important;
}

/* flex-order */
.order1_sp {
  order: 1 !important;
}

.order2_sp {
  order: 2 !important;
}

.order3_sp {
  order: 3 !important;
}

.order4_sp {
  order: 4 !important;
}

.order5_sp {
  order: 5 !important;
}

.border-container {
  border: 1px solid #ccc;
  text-align: center;
  border-radius: 10px;
}

.icon-btn {
  position: relative;
}
.icon-btn .icon-btn__help {
  background: url(../images/common/icon_help.png) 0 0 no-repeat;
  background-size: 30px 30px;
  width: 30px;
  height: 30px;
  position: absolute;
  top: 50%;
  right: -10px;
  transform: translate(100%, -50%);
}

.course-container01 {
  background: url(../images/common/chara_right.svg) no-repeat;
  background-size: 33px auto;
  background-position: 0 50%;
}
.course-container02 {
  background: url(../images/common/chara_kameron.svg) no-repeat;
  background-size: 32px auto;
  background-position: 0 50%;
}
.course-container03 {
  background: url(../images/common/chara_usarin.svg) no-repeat;
  background-size: 38px auto;
  background-position: 0 50%;
}
.course-inner {
  line-height: 1.5;
}
.course-ttl {
  font-size: 20px;
  font-weight: bolder;
  color: #01a08e;
  font-family: "Roboto", sans-serif;
}
.course-link {
  position: relative;
  text-decoration: none !important;
}
.course-imgContainer01 {
  width: 57px;
  margin: 20px auto;
}
.course-imgContainer02 {
  width: 48px;
  margin: 20px auto;
}
.course-imgContainer03 {
  width: 45px;
  margin: 20px auto;
}
.course-imgContainer04 {
  position: relative;
}
.course-inModal {
  position: absolute;
  bottom: 15px;
  right: 5px;
  width: 30px;
  height: 30px;
}

.link-arrow {
  position: relative;
  padding-right: 1em;
}
.link-arrow::before {
  position: absolute;
  content: "";
  display: block;
  top: 50%;
  right: 0;
  width: 5px;
  height: 5px;
  border-right: 2px solid #4eb9ad;
  border-bottom: 2px solid #4eb9ad;
  transform: translate(0, -50%) rotate(-45deg);
}

.font-roboto {
  letter-spacing: 1px;
  font-family: "Roboto", sans-serif;
}
.font-hirakaku {
  font-family: "[HiraKakuStd]", sans-serif;
}
.font-bold {
  font-weight: bold;
}

.course-button {
  width: 100%;
  background: none;
  border: none;
  outline: none;
  -webkit-appearance: none;
          appearance: none;
  border: 3px solid transparent;
  text-align: center;
  border-radius: 10px;
  transition: border-color 0.3s ease-in-out, background-color 0.3s ease-in-out;
  box-sizing: border-box;
  box-shadow: 0 0 3px 0 #ccc;
}
.course-button.is-push {
  border: 3px solid #01a08e;
  background: #eff9fa;
}
.course-button [type=radio] {
  display: none;
}

.stepGoal-area {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 16px;
}
.stepGoal-area__inner {
  -webkit-appearance: none;
          appearance: none;
  background: #f6f6f6;
  border: none;
  border-radius: 9999px;
  outline: none;
  cursor: pointer;
  font-weight: bold;
  text-align: right;
  padding: 5px 15px;
  width: 150px;
  margin: 0 5px;
  color: #01a08e;
}
.stepGoal-area__inner.is-push {
  color: gray;
}

.btn-type01[name], [name].btn-type07, [name].btn-type01--new {
  transition: border-color 0.3s ease-in-out, background-color 0.3s ease-in-out;
}
.btn-type01[name].is-push, [name].is-push.btn-type07, [name].is-push.btn-type01--new {
  border: 2px solid gray;
  background: gray;
}

.ios-flow {
  font-size: 12px;
  counter-reset: section;
}
.ios-flow--item {
  position: relative;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 25px;
  padding-left: 1.5em;
}
.ios-flow--item::before {
  position: absolute;
  top: 0;
  left: 0;
  counter-increment: section;
  content: counter(section) ".";
}
.ios-flow--img {
  width: 100%;
  margin-top: 15px;
  padding: 0 30px;
}

.close-btn {
  position: absolute;
  display: block;
  top: 30px;
  right: 15px;
  border: none;
  width: 40px;
  height: 40px;
  background: url(../images/common/header_menu-close.svg) 50% 50% no-repeat;
  background-size: 20px 20px;
}

.icon-link__wrapper {
  display: inline-flex;
  justify-content: center;
  align-items: flex-end;
  padding-bottom: 2px;
  border-bottom: 1px solid #000;
}

.icon__question {
  display: block;
  background: url(../images/common/icon_help.png) no-repeat;
  background-size: 20px 20px;
  background-position: center;
  width: 20px;
  height: 20px;
}

body.menu-open #gnav-bg {
  pointer-events: auto;
}

#top-entry-modal .top-entry-modal__inner:not(:first-child).dash {
  border-top: dashed 2px #eee;
}

.marker {
  background: linear-gradient(transparent 60%, #ffe195 60%);
}

.terms-list > .terms-list__item {
  margin-top: 1em;
  padding-left: 0;
  list-style: none;
}
.terms-list > .terms-list__item::before {
  display: none;
}
.terms-list__list {
  padding-left: 1em;
  counter-reset: cnt;
}
.terms-list__item {
  counter-increment: cnt;
  position: relative;
}
.terms-list__item.brackets {
  padding-left: 1em;
}
.terms-list__item.brackets::before {
  position: absolute;
  top: 0.5em;
  left: 0;
  line-height: 1;
  transform: translate(-50%, -0.25em);
  content: "(" counter(cnt) ") ";
}
.terms-list__item.decimal {
  padding-left: 1.5em;
}
.terms-list__item.decimal::before {
  position: absolute;
  top: 0.5em;
  left: 0.5em;
  line-height: 1;
  transform: translate(-0.25em, -0.25em);
  content: counter(cnt) ".";
}
.terms-list__item.disc {
  padding-left: 1em;
}
.terms-list__item.disc::before {
  position: absolute;
  top: 0.8em;
  left: 0;
  width: 4px;
  height: 4px;
  background: #000;
  border-radius: 9999px;
  line-height: 1;
  transform: translate(0, -50%);
  content: "";
}/*# sourceMappingURL=style.css.map */