/* ------------------------
  reset
------------------------ */
html,
body {
  height: 100%;
}

*,
*::after,
*::before {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
  font-size: inherit;
  line-height: inherit;
}

pre,
textarea {
  overflow: auto;
}

[hidden],
template {
  display: none;
}

details,
main,
summary {
  display: block;
}

input[type=number] {
  width: auto;
}

input[type=search] {
  -webkit-appearance: textfield;
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

progress {
  display: inline-block;
}

small {
  font-size: 75%;
}

sub,
sup {
  position: relative;
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

textarea {
  resize: vertical;
}

audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

audio:not([controls]) {
  display: none;
}

img {
  border: 0;
  max-width: 100%;
  height: auto;
}

button,
input,
select,
textarea {
  min-height: 1.5em;
  color: inherit;
  font-family: inherit;
  font-weight: inherit;
  font-style: inherit;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

input {
  line-height: normal;
}

button,
html input[type=button],
input[type=reset],
input[type=submit] {
  border-style: none;
  cursor: pointer;
  background-color: transparent;

  -webkit-appearance: button;
}

button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0;
}

code,
kbd,
pre,
samp {
  font-family: monospace;
}

ol,
ul {
  list-style: none;
}

select {
     -moz-appearance: none;
  -webkit-appearance: none;
}

table {
  border-spacing: 0;
  border-collapse: collapse;
}

fieldset {
  border: 0;
}

p {
  margin-bottom: 0;
}

/* ------------------------
  Base Settings
------------------------ */
html {
  font-size: 1.333333333vw;
}
@media (min-width: 768px) {
  html {
    font-size: 0.78125vw;
  }
}
@media (min-width: 1024px) {
  html {
    font-size: 10px;
  }
}

body {
  background-color: #fff;
  word-wrap: break-word;
  color: #211815;
  line-height: 1.777;

  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}
@media (min-width: 768px) {
  body {
    min-width: 1060px;
  }
}

a {
  text-decoration: underline;
  color: #00f;
}
a:hover {
  text-decoration: none;
  color: #f00;
}
a[href^="tel:"]:hover {
  color: #00f;
}
@media (min-width: 768px) {
  a[href^="tel:"] {
    cursor: text;
    text-decoration: none;
  }
}

em {
  font-style: normal;
}

:root {
  --c-bg-magenta: 248, 238, 245;
  --c-main-blue: 74, 93, 170;
  --c-main-magenta: 181, 30, 144;
  --c-text-base: 0, 0, 0;
  --c-text-gray: 51, 51, 51;
  --c-true-black: 0, 0, 0;
  --c-true-white: 255, 255, 255;
}

/* ------------------------
  Components
------------------------ */
.c-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-style: solid;
  border-color: rgba(var(--c-main-blue), 1);
  border-radius: 100%;
  background-color: rgba(var(--c-true-white), 1);
}
@media (max-width: 767.98px) {
  .c-icon {
    border-width: var(--circle-border-width, 0.6666666667vw);
    width: var(--circle-size, 19.6vw);
    height: var(--circle-size, 19.6vw);
  }
}
@media (min-width: 768px) {
  .c-icon {
    border-width: var(--circle-border-width, 3px);
    width: var(--circle-size, 94px);
    height: var(--circle-size, 94px);
  }
}
.c-icon img {
  width: auto;
  height: 100%;
}
@media (min-width: 768px) {
  .c-icon img {
    width: var(--icon-size, 94px);
  }
}
.c-icon svg {
  width: 100%;
  height: 100%;

  fill: rgba(var(--c-main-blue), 1);
}
@media (max-width: 767.98px) {
  .c-icon svg {
    width: var(--icon-size, 4.6666666667vw);
  }
}
@media (min-width: 768px) {
  .c-icon svg {
    width: var(--icon-size, 94px);
  }
}

.c-section-title {
  display: block;
  color: rgba(var(--c-main-blue), 1);
  font-weight: 600;
}
@media (max-width: 767.98px) {
  .c-section-title {
    font-size: var(--section-title-size, 9.6vw);
    line-height: 1.3;
  }
}
@media (min-width: 768px) {
  .c-section-title {
    font-size: var(--section-title-size, 42px);
  }
}

.c-arrow {
  position: absolute;
  top: 50%;
  right: 0;

  fill: var(--arrow-color, rgba(var(--c-main-white), 1));
}
@media (max-width: 767.98px) {
  .c-arrow {
    right: 2.6666666667vw;
    margin-top: -1.0666666667vw;
    width: 2vw;
    height: 2.2666666667vw;
  }
}
@media (min-width: 768px) {
  .c-arrow {
    right: 10px;
    margin-top: -5px;
    width: 8px;
    height: 10px;
  }
}

.c-lead {
  color: rgba(var(--c-main-blue), 1);
  font-weight: 600;
}
@media (max-width: 767.98px) {
  .c-lead {
    letter-spacing: 0.073em;
    font-size: var(--section-title-size, 5.8666666667vw);
    line-height: 1.1;
  }
}
@media (min-width: 768px) {
  .c-lead {
    letter-spacing: 0.073em;
    font-size: var(--section-title-size, 29px);
    line-height: 1.3;
  }
}

@media (max-width: 767.98px) {
  .c-text {
    font-size: var(--section-title-size, 2.9333333333vw);
    line-height: 1.27;
  }
}
@media (min-width: 768px) {
  .c-text {
    font-size: var(--section-title-size, 16px);
    line-height: 1.75;
  }
}

.c-button {
  position: relative;
  width: 100%;
  background-color: rgba(var(--c-main-magenta), 1);
  color: rgba(var(--c-true-white), 1);
  line-height: 1.3;
}
@media (hover: hover) {
  .c-button {
    cursor: pointer;
    transition: opacity 0.2s ease-out;
    transition: opacity 0.2s;
  }
  .c-button:hover {
    opacity: 0.8;
  }
}
@media (max-width: 767.98px) {
  .c-button {
    padding-top: 3.7333333333vw;
    padding-bottom: 3.7333333333vw;
    border-radius: 1.3333333333vw;
    font-size: var(--section-title-size, 3.4666666667vw);
  }
}
@media (min-width: 768px) {
  .c-button {
    padding-top: 13px;
    padding-bottom: 13px;
    border-radius: 10px;
    font-size: var(--section-title-size, 16px);
  }
}

/* ------------------------
  utilities Classes
------------------------ */
.u-hidden {
  display: none !important;
  visibility: hidden;
}

@media (max-width: 767.98px) {
  .u-hidden-sm {
    display: none !important;
    visibility: hidden;
  }
}

.u-hidden-up-sm {
  display: none !important;
  visibility: hidden;
}

@media (max-width: 767.98px) {
  .u-hidden-down-sm {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 768px) and (max-width: 1023.98px) {
  .u-hidden-md {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 768px) {
  .u-hidden-up-md {
    display: none !important;
    visibility: hidden;
  }
}

@media (max-width: 1023.98px) {
  .u-hidden-down-md {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 1024px) and (max-width: 1599.98px) {
  .u-hidden-lg {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 1024px) {
  .u-hidden-up-lg {
    display: none !important;
    visibility: hidden;
  }
}

@media (max-width: 1599.98px) {
  .u-hidden-down-lg {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 1600px) {
  .u-hidden-xl {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 1600px) {
  .u-hidden-up-xl {
    display: none !important;
    visibility: hidden;
  }
}

.u-hidden-down-xl {
  display: none !important;
  visibility: hidden;
}

.u-visuallyhidden {
  overflow: hidden;
  clip: rect(0 0 0 0);
  position: absolute;
  margin: -1px;
  padding: 0;
  border: 0;
  width: 1px;
  height: 1px;
}

.u-visuallyhidden.focusable:active,
.u-visuallyhidden.focusable:focus {
  overflow: visible;
  clip: auto;
  position: static;
  margin: 0;
  width: auto;
  height: auto;
}

.u-invisible {
  visibility: hidden;
}

.u-color--main-blue {
  color: rgba(var(--c-main-blue), 1);
}

.u-highlight {
  font-weight: 600;
}

.u-text-adjust--all-view {
  display: inline-flex;
  margin-right: -0.45em;
}
.u-text-adjust--down-sm {
  display: inline-flex;
  margin-right: -0.45em;
}
.u-text-adjust--up-md {
  display: inline-flex;
  margin-right: -0.45em;
}

@media (max-width: 767.98px) {
  .u-br--visible-down-sm {
    overflow: hidden;
    height: 0;
    text-align: left;
    text-indent: -9999px;
    font-size: 1px;
    line-height: 100%;
  }
}
@media (max-width: 767.98px) {
  .u-br--visible-down-sm::before {
    content: "\a";
    white-space: pre;
    font-size: 1px;
    line-height: 100%;
  }
}
@media (min-width: 768px) {
  .u-br--visible-up-md {
    overflow: hidden;
    height: 0;
    text-align: left;
    text-indent: -9999px;
    font-size: 1px;
    line-height: 100%;
  }
}
@media (min-width: 768px) {
  .u-br--visible-up-md::before {
    content: "\a";
    white-space: pre;
    font-size: 1px;
    line-height: 100%;
  }
}

.u-boxshadow {
  box-shadow: 0.6666666667vw 1.3333333333vw 1.3333333333vw 0 rgba(0, 0, 0, 0.25);
}
@media (min-width: 768px) {
  .u-boxshadow {
    box-shadow: 5px 10px 10px 0px rgba(0, 0, 0, 0.25);
  }
}
@media (max-width: 767.98px) {
  .u-boxshadow.--hidden-down-sm {
    box-shadow: none;
  }
}
@media (min-width: 768px) {
  .u-boxshadow.--hidden-up-md {
    box-shadow: none;
  }
}

.u-text-center {
  text-align: center;
}

@media (max-width: 767.98px) {
  .u-text-center-sm {
    text-align: center;
  }
}

.u-text-bold {
  font-weight: 600;
}

@media (max-width: 767.98px) {
  .l-contents {
    padding: 0 6.6666666667vw;
  }
}
@media (min-width: 768px) {
  .l-contents {
    margin-right: auto;
    margin-left: auto;
    width: 1040px;
  }
}

/* --------------------------------
  Header
-------------------------------- */
/* Overwrite template
-------------------------------- */
.o-header_logo {
  margin: 0 auto;
}
@media (max-width: 767.98px) {
  .o-header_logo {
    right: 0;
    left: 0;
    width: 26.5rem;
  }
}

/* --------------------------------
  Footer
-------------------------------- */
/* Overwrite template
-------------------------------- */
.o-footer {
  position: relative;
}

/* ------------------------
  Print Styles
------------------------ */
@media print {
  *,
  *::before,
  *::after {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  a,
  a:visited {
    text-decoration: underline;
  }
  tr,
  img {
    page-break-inside: avoid;
  }
  img {
    max-width: 100% !important;
  }
  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3;
  }
  h2,
  h3 {
    page-break-after: avoid;
  }
}
/*
* main.css
*
*/