@charset "UTF-8";
/*
rev. 2025-08-01
copyright © 2025
*/
/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
*, :before, :after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
  min-width: 0;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  margin: 0;
}

main {
  display: block;
}

p, table, blockquote, address, pre, iframe, form, figure, dl {
  margin: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

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

dt {
  font-weight: 700;
}

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

abbr[title] {
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
}

b, strong {
  font-weight: bolder;
}

code, kbd, samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

svg, img, embed, object, iframe {
  vertical-align: bottom;
}

button, input, optgroup, select, textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
}

button, [type=button], [type=reset], [type=submit] {
  cursor: pointer;
}

button:disabled, [type=button]:disabled, [type=reset]:disabled, [type=submit]:disabled {
  cursor: default;
}

:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

option {
  padding: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

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

[type=search] {
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

[type=number] {
  -moz-appearance: textfield;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable]:focus {
  outline: auto;
}

table {
  border-color: inherit;
  border-collapse: collapse;
}

caption {
  text-align: left;
}

td, th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: 700;
}

@font-face {
  font-family: dinFs;
  src: url(data:font/woff;base64,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) format("woff");
}
:root {
  --base-font-color: #333;
  --base-font-size: 17px;
  --base-line-height: 1.8;
  --border-color: #333;
  --content-width: 45.1764705882rem;
  --wide-layout-width: 58.3529411765rem;
  --font-family-body: sans-serif;
  --font-family-heading: Helvetica, sans-serif;
  --font-size-h1: 4em;
  --font-size-h2: 2.66667em;
  --font-size-h3: 2em;
  --font-size-h4: 1.6em;
  --font-size-h5: 1.33333em;
  --font-size-h6: 1.14286em;
  font-size: var(--base-font-size);
}

html:focus-within {
  scroll-behavior: smooth;
  scroll-padding-top: 114px;
}

@media screen and (max-width: 790px) {
  html:focus-within {
    scroll-padding-top: 73px;
  }
}
body {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
}

body *, body :before, body :after {
  box-sizing: unset;
  min-inline-size: auto;
}

body:has(> div.web-degima > div.provider) {
  margin-block-end: 87px;
}

@media screen and (min-width: 769px) {
  body a[href*="tel:"] {
    text-decoration: none;
    pointer-events: none;
    cursor: default;
  }
}
@media screen and (max-width: 768px) {
  body:has(> div.web-degima > div.provider) {
    margin-block-end: 63px;
  }
}
button {
  border-radius: 0;
}

.button__link {
  box-sizing: border-box;
  display: block;
  text-decoration: none;
}

.button, .button__link {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  cursor: pointer;
  border-radius: 60px;
  transition: all 0.3s ease;
}

.button--small {
  padding: 5px 20px;
  font-size: 14px;
  line-height: 22px;
}

.button--medium {
  inline-size: 440px;
  block-size: 70px;
  font-size: 26px;
}

.button--blue {
  color: #fff;
  background: #0099e4;
  border: none;
}

.button--blue:disabled {
  cursor: unset;
  opacity: 0.4;
}

.button--blue:not(:disabled):hover {
  color: #0099e4;
  background: #fff;
  border: solid 1px #0099e4;
}

.button--blue--outline {
  color: #0099e4;
  background-color: transparent;
  border: solid 1px #0099e4;
}

.button--blue--outline:hover {
  color: #fff;
  border: solid 1px #0099e4;
}

.button--blue--black {
  color: #000;
}

.button--green {
  color: #fff;
  background: #00ad9f;
  border: none;
}

.button--green:hover {
  color: #00ad9f;
  background: #fff;
  border: solid 1px #00ad9f;
}

.button--green--outline {
  color: #00ad9f;
  background-color: transparent;
  border: solid 1px #00ad9f;
}

.button--green--outline:hover {
  color: #fff;
  border: solid 1px #00ad9f;
}

.button--green--black {
  color: #000;
}

@media screen and (max-width: 768px) {
  .button--small {
    padding: 5px 20px;
    font-size: 14px;
    line-height: 22px;
  }
  .button--medium {
    inline-size: 440px;
    block-size: 70px;
    font-size: 26px;
  }
}
.top {
  inline-size: 100%;
  overflow-x: hidden;
}

.top-wrapper {
  position: relative;
  z-index: 2;
}

.top-decoration {
  position: absolute;
}

.top-decoration.decoration1 {
  inset-block-start: 830px;
  inset-inline-end: 0;
  inline-size: 452px;
  block-size: 816px;
  background: url(/img/top/top_decoration1.svg) no-repeat center;
}

.top-decoration.decoration2 {
  inset-block-start: 1850px;
  inset-inline-start: 0;
  inline-size: 885px;
  block-size: 768px;
  background: url(/img/top/top_decoration2.svg) no-repeat center;
}

.top-decoration.decoration3 {
  inset-block-start: 2520px;
  inset-inline-end: 0;
  inline-size: 636px;
  block-size: 1176px;
  background: url(/img/top/top_decoration3.svg) no-repeat center;
}

.top-decoration.decoration4 {
  inset-block-start: 4000px;
  inset-inline-start: 0;
  inline-size: 889px;
  block-size: 830px;
  background: url(/img/top/top_decoration4.svg) no-repeat center;
}

.top-decoration.decoration5 {
  inset-block-start: 4710px;
  inset-inline-end: 0;
  inline-size: 511px;
  block-size: 937px;
  background: url(/img/top/top_decoration5.svg) no-repeat center;
}

.top-decoration.decoration6 {
  inset-block-start: 6130px;
  inset-inline-start: 0;
  inline-size: 290px;
  block-size: 350px;
  background: url(/img/top/top_decoration6.svg) no-repeat top;
}

.top-decoration.decoration7 {
  inset-block-start: 6400px;
  inset-inline-end: 0;
  z-index: -1;
  inline-size: 636px;
  block-size: 1176px;
  background: url(/img/top/top_decoration7.svg) no-repeat top;
}

@media screen and (max-width: 768px) {
  .top-decoration {
    position: absolute;
  }
  .top-decoration.decoration1 {
    inset-block-start: 1300px;
    inset-inline-end: 0;
    inline-size: 229px;
    block-size: 454.08px;
    background: url(/img/top/top_decoration1_sp.svg) no-repeat center;
  }
  .top-decoration.decoration2 {
    inset-block-start: 2100px;
    inset-inline-start: 0;
    inline-size: 250px;
    block-size: 514px;
    background: url(/img/top/top_decoration2_sp.svg) no-repeat center;
  }
  .top-decoration.decoration3 {
    inset-block-start: 3450px;
    inset-inline-end: 0;
    inline-size: 237px;
    block-size: 514px;
    background: url(/img/top/top_decoration3_sp.svg) no-repeat center;
  }
  .top-decoration.decoration4 {
    inset-block-start: 4370px;
    inset-inline-start: 0;
    inline-size: 375px;
    block-size: 708.74px;
    background: url(/img/top/top_decoration4_sp.svg) no-repeat bottom;
  }
  .top-decoration.decoration5 {
    inset-block-start: 5820px;
    inset-inline-end: 0;
    inline-size: 271px;
    block-size: 560.83px;
    background: url(/img/top/top_decoration5_sp.svg) no-repeat center;
  }
  .top-decoration.decoration6 {
    inset-block: auto 2600px;
    inset-inline-start: 0;
    inline-size: 193px;
    block-size: 321.5px;
    background: url(/img/top/top_decoration6_sp.svg) no-repeat bottom;
  }
  .top-decoration.decoration7 {
    inset-block: auto 1000px;
  }
}
.TopAnnounce {
  position: relative;
  inline-size: calc(100% - 48px);
  max-inline-size: 1160px;
  margin: 120px auto;
}

.TopAnnounce h2 {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 36px;
  font-weight: 700;
  line-height: 140%;
  color: #212121;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopAnnounce__list {
  margin-block-start: 56px;
}

.TopAnnounce__list li + li {
  margin-block-start: 2px;
}

.TopAnnounce__list-cn {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  display: flex;
  gap: 24px;
  padding: 16px 66px 16px 24px;
  font-size: 16px;
  line-height: 25.6px;
  color: #333;
  letter-spacing: 0.02em;
  text-decoration: none;
  background: #e3f1fc;
  border-radius: 3px;
}

.TopAnnounce__list-cn.is-link:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 32px;
  inline-size: 8px;
  block-size: 8px;
  margin: auto 0;
  content: "";
  border-block-start: solid 2px #0074bf;
  border-inline-end: solid 2px #0074bf;
  transform: rotate(45deg);
}

.TopAnnounce__list-cn.is-link:hover {
  color: #fff;
  background: #0074bf;
}

.TopAnnounce__list-cn.is-link:hover .TopAnnounce__list-text {
  text-decoration: underline;
}

.TopAnnounce__list-cn.is-link:hover .TopAnnounce__list-text-icon:after {
  background-color: #fff;
}

.TopAnnounce__list-cn.is-link:hover:after {
  border-color: #fff;
}

.TopAnnounce__list-date {
  font-weight: 700;
}

.TopAnnounce__list-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  flex: 1;
  font-weight: 400;
}

.TopAnnounce__list-text-icon:after {
  display: inline-block;
  inline-size: 18px;
  block-size: 18px;
  content: "";
  background-color: #0074bf;
  -webkit-mask-image: url(/img/top/new_window.svg);
  mask-image: url(/img/top/new_window.svg);
  transform: translate(2px, 4px);
}

@media screen and (min-width: 769px) {
  .TopAnnounce br.pc {
    display: block;
  }
  .TopAnnounce br.sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .TopAnnounce {
    margin: 20px auto 60px;
  }
  .TopAnnounce br.pc {
    display: none;
  }
  .TopAnnounce br.sp {
    display: block;
  }
  .TopAnnounce h2 {
    font-size: 32px;
  }
  .TopAnnounce__list {
    margin-block-start: 32px;
  }
  .TopAnnounce__list-cn {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px 50px 12px 16px;
    font-size: 15px;
    line-height: 24px;
    border-radius: 2px;
  }
  .TopAnnounce__list-cn.is-link:after {
    inset-block-end: 0;
    inset-inline-end: 23px;
    inline-size: 6px;
    block-size: 6px;
  }
}
.TopCase {
  box-sizing: border-box;
  inline-size: calc(100% - 144px);
  max-inline-size: 1256px;
  padding: 80px 48px 80.6px;
  margin: 100px auto 0;
  background: url(/img/top/case_bg.webp) no-repeat center/cover;
  border-radius: 10px;
}

.TopCase-head-catch {
  inline-size: 392.09px;
  block-size: 34px;
  margin: 0 auto;
  background: url(/img/top/case_catch.webp) no-repeat no-repeat center/contain;
}

.TopCase-head h2 {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  margin: 16px auto;
  font-size: 40px;
  font-weight: 700;
  line-height: 140%;
  color: #212121;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopCase-head-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopCase .swiper-slide {
  block-size: auto;
}

.TopCase-slide {
  box-sizing: border-box;
  display: flex;
  flex: 1;
  flex-direction: column;
  block-size: 100%;
  text-decoration: none;
  cursor: pointer;
  border-radius: 3px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3019607843), 0 2px 8px 1px rgba(0, 0, 0, 0.1019607843);
}

.TopCase-slide-head {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  inline-size: 100%;
  padding: 8px 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 160%;
  color: #fff;
  text-align: center;
  letter-spacing: 0.02em;
  background: linear-gradient(90deg, #002e60 0.72%, #1757a0 99.68%);
  border-radius: 3px 3px 0 0;
}

.TopCase-slide-contents {
  box-sizing: border-box;
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  inline-size: 100%;
  padding: 16px;
  background: #fff;
  border: 1px solid transparent;
  border-radius: 0 0 3px 3px;
}

.TopCase-slide-image {
  inline-size: auto;
  max-inline-size: 333px;
  block-size: auto;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.TopCase-slide-name {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  padding: 0 0 0 30px;
  font-size: 16px;
  font-weight: 700;
  line-height: 160%;
  color: #333;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.TopCase-slide-name:before {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 22px;
  block-size: 22px;
  margin: auto 0;
  content: "";
  background: #0074bf;
  border-radius: 100%;
  transition: all 0.3s ease;
}

.TopCase-slide-name:after {
  position: absolute;
  inset-block-start: 8px;
  inset-inline-start: 7px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto;
  content: "";
  border-block-start: 1.57px solid #fff;
  border-inline-end: 1.57px solid #fff;
  transform: rotate(45deg);
}

.TopCase-slide-info {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
  inline-size: 100%;
  padding: 8px 16px 4px;
  background: #e5f0f9;
}

.TopCase-slide-info-name {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 150%;
  color: #0074bf;
  letter-spacing: 0.02em;
}

.TopCase-slide-info-table {
  inline-size: 100%;
  border-spacing: 0 8px;
  border-collapse: separate;
}

.TopCase-slide-info-table-head {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  padding: 0 12px 0 0;
  font-size: 14px;
  font-weight: 400;
  line-height: 150%;
  vertical-align: top;
  color: #333;
  letter-spacing: 0.02em;
  white-space: nowrap;
  border-inline-end: 1px solid #d9d9d9;
}

.TopCase-slide-info-table-contents {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  padding: 0 0 0 12px;
  font-size: 14px;
  font-weight: 400;
  line-height: 150%;
  color: #333;
  letter-spacing: 0.02em;
}

.TopCase-slide-info-table > caption {
  display: none;
}

.TopCase-slide:hover {
  box-shadow: 0 4px 16px 3px #54ade1, 0 1px 6px #57bbfd;
}

.TopCase-slide:hover .TopCase-slide-head {
  background: #0074bf;
}

.TopCase-slide:hover .TopCase-slide-name {
  color: #0074bf;
  text-decoration: underline;
}

.TopCase-slide:hover .TopCase-slide-contents {
  border: 1px solid #0074bf;
}

.TopCase-slide:hover .TopCase-slide-info-table-head {
  font-weight: 700;
}

.TopCase-toList {
  padding: 23px 50px 27px 32px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  background-color: #0099e4;
  border: none;
  border-radius: 100px;
  transition: all 0.3s ease;
  position: relative;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  inline-size: 384px;
  margin: 56px auto 0;
  line-height: 150%;
  background: linear-gradient(270deg, #027bc8, #0062ad);
  border: 1px solid transparent;
}

.TopCase-toList:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 30px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto 0;
  content: "";
  border-block-start: 2px solid #fff;
  border-inline-end: 2px solid #fff;
  transform: rotate(45deg);
}

.TopCase-toList:hover {
  color: #0074bf;
  background: #fff;
  border: 1px solid #0074bf;
}

.TopCase-toList:hover:after {
  border-color: #0074bf;
}

@media screen and (min-width: 769px) {
  .TopCase br.pc {
    display: block;
  }
  .TopCase br.sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .TopCase {
    inline-size: 100%;
    padding: 60px 24px;
    margin: 61px auto 0;
    background: url(/img/top/case_bg_sp.webp) no-repeat center/cover;
    border-radius: unset;
  }
  .TopCase-head-catch {
    inline-size: 228px;
    block-size: 54px;
    background: url(/img/top/case_catch_sp.webp) no-repeat center/contain;
  }
  .TopCase-head h2 {
    margin: 12px auto 0;
    font-size: 30px;
  }
  .TopCase-head-text {
    margin: 12px auto 0;
    font-size: 15px;
  }
  .TopCase .swiper-slide {
    flex: none;
  }
  .TopCase-slide {
    min-inline-size: 0;
    max-inline-size: 327px;
  }
  .TopCase-slide-image {
    max-inline-size: 100%;
    block-size: auto;
  }
  .TopCase-slide-name {
    margin: 16px 0 0;
    font-size: 15px;
  }
  .TopCase-toList {
    inline-size: 280px;
    padding: 14px 42px 16px 24px;
    margin: 32px auto 0;
    font-size: 14px;
  }
  .TopCase-toList:after {
    inset-inline-end: 22px;
  }
}
.TopColumns {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  box-sizing: border-box;
  inline-size: calc(100% - 48px);
  max-inline-size: 1160px;
  margin: 120px auto 0;
}

.TopColumns-head {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.TopColumns-head h2 {
  font-size: 36px;
  font-weight: 700;
  line-height: 140%;
  color: #1a1919;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopColumns-head-text {
  font-size: 16px;
  line-height: 160%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopColumns .swiper-slide {
  block-size: auto;
}

.TopColumns-slide {
  box-sizing: border-box;
  display: flex;
  flex: 1;
  flex-direction: column;
  block-size: 100%;
  text-decoration: none;
  cursor: pointer;
  border-radius: 3px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3019607843), 0 2px 8px 1px rgba(0, 0, 0, 0.1019607843);
}

.TopColumns-slide-head {
  inline-size: 100%;
  padding: 8px 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 160%;
  color: #fff;
  text-align: center;
  letter-spacing: 0.02em;
  background: linear-gradient(90deg, #002e60 0.72%, #1757a0 99.68%);
  border-radius: 3px 3px 0 0;
}

.TopColumns-slide-contents {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  inline-size: 100%;
  background: #fff;
  border: 1px solid transparent;
  border-radius: 0 0 3px 3px;
}

.TopColumns-slide-image {
  box-sizing: border-box;
  inline-size: 100%;
  padding: 16px 16px 0;
}

.TopColumns-slide-image > img {
  inline-size: 100%;
  block-size: auto;
}

.TopColumns-slide-detail {
  box-sizing: border-box;
  padding: 0 24px 24px;
}

.TopColumns-slide-detail-text {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 8px;
}

.TopColumns-slide-detail-text-tags {
  display: flex;
  gap: 8px;
}

.TopColumns-slide-detail-text-tags > span.tag {
  box-sizing: border-box;
  inline-size: fit-content;
  padding: 8px;
  font-size: 13px;
  font-weight: 700;
  line-height: 100%;
  color: #0074bf;
  letter-spacing: 0.02em;
  background: #fff;
  border: 1px solid #0074bf;
  transition: all 0.3s ease;
}

.TopColumns-slide-detail-text > span.title {
  font-size: 16px;
  font-weight: 700;
  line-height: 160%;
  color: #333;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.TopColumns-slide-detail-text > span.date {
  font-size: 14px;
  line-height: 150%;
  color: #333;
  letter-spacing: 0.02em;
}

.TopColumns-slide-detail-more {
  position: relative;
  display: block;
  inline-size: fit-content;
  padding: 0 0 0 30px;
  margin: 16px 0 0 auto;
  font-size: 16px;
  font-weight: 700;
  line-height: 100%;
  color: #333;
  text-align: end;
  letter-spacing: 0.02em;
  text-decoration: none;
  transition: all 0.3s ease;
}

.TopColumns-slide-detail-more:before {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  inline-size: 22px;
  block-size: 22px;
  margin: auto;
  content: "";
  background: #0074bf;
  border-radius: 100%;
}

.TopColumns-slide-detail-more:after {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 7px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto;
  content: "";
  border-block-start: 1.57px solid #fff;
  border-inline-end: 1.57px solid #fff;
  transform: rotate(45deg);
}

.TopColumns-slide:hover {
  box-shadow: 0 4px 16px 3px #54ade1, 0 1px 6px #57bbfd;
}

.TopColumns-slide:hover .TopColumns-slide-head {
  background: #0074bf;
}

.TopColumns-slide:hover .TopColumns-slide-contents {
  border: 1px solid #0074bf;
}

.TopColumns-toList {
  padding: 22px 50px 24px 32px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  background-color: #0099e4;
  border: none;
  border-radius: 100px;
  transition: all 0.3s ease;
  position: relative;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  inline-size: 384px;
  margin: 56px auto 0;
  line-height: 150%;
  background: linear-gradient(270deg, #027bc8, #0062ad);
  border: 1px solid transparent;
}

.TopColumns-toList:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 30px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto 0;
  content: "";
  border-block-start: 2px solid #fff;
  border-inline-end: 2px solid #fff;
  transform: rotate(45deg);
}

.TopColumns-toList:hover {
  color: #0074bf;
  background: #fff;
  border: 1px solid #0074bf;
}

.TopColumns-toList:hover:after {
  border-color: #0074bf;
}

@media screen and (min-width: 769px) {
  .TopColumns br.pc {
    display: block;
  }
  .TopColumns br.sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .TopColumns {
    inline-size: 100%;
    padding: 0 24px 60px;
    margin: 20px auto 0;
  }
  .TopColumns-head h2 {
    font-size: 30px;
  }
  .TopColumns-head-text {
    margin: 12px auto 0;
    font-size: 15px;
  }
  .TopColumns .swiper-slide {
    flex: none;
  }
  .TopColumns-slide {
    min-inline-size: 0;
    max-inline-size: 327px;
  }
  .TopColumns-slide-image {
    max-inline-size: 100%;
    block-size: auto;
  }
  .TopColumns-toList {
    inline-size: 280px;
    padding: 14px 42px 16px 24px;
    margin: 32px auto 0;
    font-size: 14px;
  }
  .TopColumns-toList:after {
    inset-inline-end: 22px;
  }
}
.introduction {
  padding: 120px 0 0;
  text-align: center;
}

.introduction-head-catch {
  inline-size: 266px;
  block-size: 34px;
  margin: 0 auto;
  background: url(/img/top/introduction_catch.webp) no-repeat center/contain;
}

.introduction-head h2 {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  margin: 16px auto;
  font-size: 40px;
  font-weight: 700;
  line-height: 140%;
  color: #212121;
  text-align: center;
  letter-spacing: 0.02em;
}

.introduction-head-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
}

.introduction__list {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 32px;
  justify-content: center;
  inline-size: calc(100% - 48px);
  max-inline-size: 1160px;
  margin: 56px auto 0;
}

.introduction__list > li {
  box-sizing: border-box;
  inline-size: calc(50% - 16px);
  min-inline-size: 327px;
}

.introduction__list > li > a {
  text-decoration: none;
}

.introduction__list > li img {
  inline-size: 100%;
  block-size: auto;
  transition: all 0.3s ease;
}

.introduction__list-image-wrapper {
  display: flex;
  overflow: hidden;
  border-radius: 3px;
}

.introduction__list-image-wrapper img {
  transform-origin: 20% 70%;
}

.introduction__list-image-wrapper img:hover {
  transform: scale(1.1);
  transition: 0.3s all;
}

.introduction__list-contents {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
  padding: 0 24px 16px;
}

.introduction__list-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-start;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
  color: #333;
  text-align: start;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.introduction__list-text > span.title {
  font-size: 18px;
  font-weight: 700;
}

.introduction__list-more {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  padding: 3px 0 3px 30px;
  margin: 0 0 0 auto;
  font-size: 16px;
  font-weight: 700;
  line-height: 100%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.introduction__list-more:before {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 22px;
  block-size: 22px;
  content: "";
  background: #0074bf;
  border-radius: 100%;
}

.introduction__list-more:after {
  position: absolute;
  inset-block-start: 8px;
  inset-inline-start: 7px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto;
  content: "";
  border-block-start: 1.57px solid #fff;
  border-inline-end: 1.57px solid #fff;
  transform: rotate(45deg);
}

.introduction__list > li > a {
  display: flex;
  flex-direction: column;
  gap: 16px;
  cursor: pointer;
  background: #fff;
  border-radius: 3px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3019607843), 0 2px 8px 1px rgba(0, 0, 0, 0.1019607843);
  transition: all 0.3s ease;
}

.introduction__list > li > a:hover {
  box-shadow: 0 4px 16px 3px #54ade1, 0 1px 6px #57bbfd;
}

.introduction__list > li > a:hover .introduction__list-text, .introduction__list > li > a:hover .introduction__list-more {
  color: #0074bf;
}

.introduction__list > li > a:hover .introduction__list-text > span.title, .introduction__list > li > a:hover .introduction__list-more > span.title {
  text-decoration: underline;
}

.introduction__list > li > a:hover .introduction__list-image-wrapper img {
  transform: scale(1.1);
  transition: 0.3s all;
}

.introduction__toList {
  padding: 23px 50px 27px 32px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  background-color: #0099e4;
  border: none;
  border-radius: 100px;
  transition: all 0.3s ease;
  position: relative;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  inline-size: 384px;
  margin: 48px auto 0;
  line-height: 150%;
  background: linear-gradient(270deg, #027bc8, #0062ad);
  border: 1px solid transparent;
}

.introduction__toList:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 30px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto 0;
  content: "";
  border-block-start: 2px solid #fff;
  border-inline-end: 2px solid #fff;
  transform: rotate(45deg);
}

.introduction__toList:hover {
  color: #0074bf;
  background: #fff;
  border: 1px solid #0074bf;
}

.introduction__toList:hover:after {
  border-color: #0074bf;
}

@media screen and (min-width: 769px) {
  .introduction .sp {
    display: none;
  }
  .introduction .pc {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .introduction {
    padding: 60px 0 0;
  }
  .introduction .pc {
    display: none;
  }
  .introduction-head-catch {
    inline-size: 238px;
    block-size: 34px;
    margin: 0 auto;
    background: url(/img/top/introduction_catch.webp) no-repeat center/contain;
  }
  .introduction-head h2 {
    margin: 12px auto 0;
    font-size: 30px;
  }
  .introduction-head-text {
    margin: 12px auto 0;
    font-size: 15px;
  }
  .introduction__list {
    margin: 32px auto 0;
  }
  .introduction__list-text {
    font-size: 15px;
  }
  .introduction__list-text > span.title {
    font-size: 15px;
  }
  .introduction__list-more {
    padding: 3.5px 0 3.5px 30px;
    font-size: 15px;
  }
  .introduction__toList {
    inline-size: 280px;
    padding: 14px 42px 16px 24px;
    margin: 32px auto 0;
    font-size: 14px;
  }
  .introduction__toList:after {
    inset-inline-end: 22px;
  }
}
.TopKeyVisual {
  position: relative;
  inline-size: 100%;
}

.TopKeyVisual-bg {
  position: absolute;
  z-index: 2;
  inline-size: 100%;
  block-size: 432px;
  background: url(/img/top/kv_bg.webp) no-repeat center/cover;
  mix-blend-mode: overlay;
}

.TopKeyVisual-wrap {
  background: linear-gradient(90deg, #015198, #015ca5 40%);
}

.TopKeyVisual-contents {
  display: flex;
  justify-content: center;
  inline-size: calc(100% - 10px);
  max-inline-size: 1400px;
  block-size: 432px;
  margin: 0 auto;
  overflow: hidden;
}

.TopKeyVisual-contents-textarea {
  position: relative;
  inset-block-start: 64px;
  inset-inline-start: 69px;
  z-index: 3;
  inline-size: 621px;
}

.TopKeyVisual-contents-head {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 140%;
  color: #fff;
  white-space: nowrap;
}

.TopKeyVisual-contents-head > span.small {
  font-size: 40px;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: 0.02em;
}

.TopKeyVisual-contents-head > span.yellow {
  font-size: 40px;
  font-weight: 700;
  line-height: 140%;
  color: #fdfe54;
  letter-spacing: -0.02em;
}

.TopKeyVisual-contents-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  inline-size: 483px;
  margin: 16px 0 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
  color: #fff;
  letter-spacing: 0.02em;
}

.TopKeyVisual-contents-award {
  position: absolute;
  inset-block-start: 118px;
  inset-inline-end: 4px;
}

.TopKeyVisual-contents-imagearea {
  position: relative;
  inset-block-start: 28.86px;
  inset-inline-end: 33px;
  min-inline-size: 506.6px;
  block-size: 403.14px;
}

.TopKeyVisual-contents-image-title {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 62px;
  z-index: 4;
  inline-size: 389px;
  block-size: 135.65px;
}

.TopKeyVisual-contents-image-model {
  position: absolute;
  inset-block-end: 0;
  inset-inline-start: 0;
  z-index: 4;
  inline-size: 476px;
}

.TopKeyVisual-contents-image-logo {
  position: absolute;
  inset-block-start: 207.14px;
  inset-inline-start: 384.59px;
  z-index: 4;
  inline-size: 122px;
  block-size: 45.8px;
}

.TopKeyVisual-contents-light {
  position: absolute;
  inset-block-start: -48px;
  inset-inline-start: 0;
  z-index: 1;
  inline-size: 525px;
  block-size: 525px;
  background: radial-gradient(50% 50% at 50% 50%, #0079d1 35.5%, #015ca5);
}

.TopKeyVisual-suggestion {
  position: absolute;
  inset-block-start: 382px;
  inset-inline: 0;
  z-index: 5;
  display: flex;
  justify-content: center;
  inline-size: 696px;
  margin: 0 auto;
}

.TopKeyVisual-suggestion:before {
  position: absolute;
  inset-block-start: 0;
  inline-size: 100%;
  block-size: 85px;
  content: "";
  background: url(/img/top/top_suggestion_bg.svg) no-repeat center;
}

.TopKeyVisual-suggestion > ul {
  z-index: 6;
  display: flex;
  gap: 12px 16px;
  margin: 12px 24px;
}

.TopKeyVisual-suggestion > ul > li {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.TopKeyVisual-suggestion-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 150%;
  color: #212121;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopKeyVisual-suggestion-btn {
  padding: 18px 42px 18px 24px;
  font-size: 16px;
  font-weight: 700;
  color: #212121;
  text-decoration: none;
  background-color: #0099e4;
  border: none;
  border-radius: 100px;
  transition: all 0.3s ease;
  position: relative;
  box-sizing: border-box;
  display: block;
  inline-size: 296px;
  line-height: 22.4px;
  text-align: center;
  background: linear-gradient(90deg, #fb0, #f8c801);
  border: 1px solid transparent;
}

.TopKeyVisual-suggestion-btn:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 30px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto 0;
  content: "";
  border-block-start: 2px solid #212121;
  border-inline-end: 2px solid #212121;
  transform: rotate(45deg);
}

.TopKeyVisual-suggestion-btn:hover {
  background: #fff;
  border: 1px solid #f8c801;
}

.TopKeyVisual-suggestion-btn:hover:after {
  border-color: #0074bf;
}

.TopKeyVisual-notes {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  inline-size: calc(100% - 20px);
  margin: 67px auto 0;
  font-size: 13px;
  font-weight: 400;
  line-height: 150%;
  color: #6c6c6c;
  text-align: center;
  letter-spacing: 0.02em;
}

@media screen and (min-width: 769px) {
  .TopKeyVisual br.pc {
    display: block;
  }
  .TopKeyVisual br.sp {
    display: none;
  }
  .TopKeyVisual__image.pc {
    display: block;
  }
}
@media screen and (max-width: 1140px) {
  .TopKeyVisual-bg {
    block-size: 575.3px;
  }
  .TopKeyVisual-wrap {
    background: linear-gradient(180deg, #015198 -2.26%, #015ca5 33.27%);
  }
  .TopKeyVisual-contents {
    flex-direction: column;
    align-items: center;
    block-size: auto;
  }
  .TopKeyVisual-contents-textarea {
    inset-block-start: 0;
    inset-inline-start: 0;
    margin: 14px 0 0;
  }
  .TopKeyVisual-contents-head {
    text-align: center;
  }
  .TopKeyVisual-contents-text {
    display: none;
  }
  .TopKeyVisual-contents-imagearea {
    inset-block-start: 0;
    inset-inline-end: auto;
    min-inline-size: 506.6px;
    block-size: 403.14px;
    margin: 12.61px 0 0;
  }
  .TopKeyVisual-contents-light {
    background: radial-gradient(50% 50% at 50% 50%, #0079d1 35.5%, #015ca5);
  }
  .TopKeyVisual-suggestion {
    inset-block-start: 550px;
  }
  .TopKeyVisual-notes {
    margin: 80px auto 0;
    text-align: start;
  }
}
@media screen and (max-width: 768px) {
  .TopKeyVisual-bg {
    block-size: 417px;
    background: url(/img/top/kv_bg_sp.webp) no-repeat center/cover;
  }
  .TopKeyVisual-contents {
    flex-direction: column;
    gap: 22.61px;
    align-items: center;
    block-size: 417px;
  }
  .TopKeyVisual-contents-textarea {
    inset-block-start: 0;
    inset-inline-start: 0;
    inline-size: 325px;
    margin: 14px 0 0;
  }
  .TopKeyVisual-contents-head {
    font-size: 18px;
    line-height: 150%;
    text-align: start;
    letter-spacing: 0.02em;
  }
  .TopKeyVisual-contents-head > span.small {
    padding: 0 0 2.39px;
    font-size: 16px;
    line-height: 160%;
    letter-spacing: 0.02em;
  }
  .TopKeyVisual-contents-head > span.middle {
    font-size: 22px;
    line-height: 150%;
  }
  .TopKeyVisual-contents-head > span.yellow {
    font-size: 22px;
    line-height: 150%;
    letter-spacing: 0.02em;
  }
  .TopKeyVisual-contents-award {
    inset-block-start: 20.39px;
    inset-inline-end: 0;
    inline-size: 119px;
    block-size: 107px;
  }
  .TopKeyVisual-contents-imagearea {
    inset-block-start: 0;
    inset-inline-end: auto;
    min-inline-size: 319.68px;
    block-size: 244px;
    margin: 0;
  }
  .TopKeyVisual-contents-image-title {
    inset-block-start: 0;
    inset-inline-start: 39.13px;
    inline-size: 245.09px;
    block-size: 85.6px;
  }
  .TopKeyVisual-contents-image-model {
    inset-block-end: -4px;
    inset-inline-start: 0;
    inline-size: 300.37px;
    block-size: auto;
  }
  .TopKeyVisual-contents-image-logo {
    inset-block-start: 130.71px;
    inset-inline-start: 242.7px;
    inline-size: 76.99px;
    block-size: 28.78px;
  }
  .TopKeyVisual-contents-light {
    inline-size: 313.29px;
    block-size: 313.29px;
    background: radial-gradient(50% 50% at 50% 50%, #0079d1 35.5%, #015ca5);
  }
  .TopKeyVisual-suggestion {
    inset-block-start: 389px;
    inline-size: 325px;
  }
  .TopKeyVisual-suggestion:before {
    block-size: 41.85px;
  }
  .TopKeyVisual-suggestion > ul {
    flex-direction: column;
    margin: 12px 14px 0 15px;
  }
  .TopKeyVisual-suggestion-text {
    font-size: 13px;
  }
  .TopKeyVisual-suggestion-btn {
    inline-size: 280px;
    padding: 16px 42px 16px 24px;
    font-size: 14px;
    line-height: 19.6px;
  }
  .TopKeyVisual-notes {
    inline-size: calc(100% - 48px);
    margin: 168px auto 0;
    font-size: 12px;
    color: #6c6c6c;
    text-align: start;
  }
}
.TopMovies {
  padding: 60px 0 0;
}

.TopMovies > h2 {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
  font-size: 36px;
  font-weight: 700;
  line-height: 140%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopMovies > h2 > span.catch {
  font-size: 26px;
  font-weight: 700;
  line-height: 150%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopMovies > h2 > span.catch > span.blue {
  color: #0074bf;
}

.TopMovies__contents {
  display: flex;
  flex-wrap: wrap;
  gap: 32px 24px;
  inline-size: calc(100% - 48px);
  max-inline-size: 1000px;
  margin: 32px auto 0;
}

.TopMovies__contents > li {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  min-inline-size: 392px;
}

.TopMovies__contents-iframeWrapper {
  inline-size: 100%;
  block-size: auto;
  aspect-ratio: 16/9;
}

.TopMovies__contents-movie {
  inline-size: 100%;
  block-size: 100%;
  border-radius: 3px;
}

.TopMovies__contents-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  flex: 1;
  font-size: 16px;
  font-weight: 700;
  line-height: 160%;
  color: #212121;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopMovies__contents-link {
  padding: 0 2px 0 0;
  font-size: 16px;
  color: #fff;
  text-decoration: none;
  background-color: #0074bf;
  border: none;
  border-radius: 100px;
  transition: all 0.3s ease;
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 296px;
  block-size: 56px;
  margin: 8px 0 0;
  font-weight: 700;
  line-height: 140%;
  text-align: center;
  letter-spacing: 0.02em;
  background: linear-gradient(270deg, #027bc8, #0062ad);
  border: 1px solid #0074bf;
}

.TopMovies__contents-link:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 22px;
  inline-size: 8px;
  block-size: 8px;
  margin: auto 0;
  content: "";
  border-block-start: solid 2px #fff;
  border-inline-end: solid 2px #fff;
  transform: rotate(45deg);
}

.TopMovies__contents-link:hover {
  color: #0074bf;
  background: #fff;
}

.TopMovies__contents-link:hover:after {
  border-block-start: solid 2px #0074bf;
  border-inline-end: solid 2px #0074bf;
}

@media screen and (min-width: 769px) {
  .TopMovies br.pc {
    display: block;
  }
  .TopMovies br.sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .TopMovies {
    padding: 40px 0 0;
  }
  .TopMovies br.pc {
    display: none;
  }
  .TopMovies br.sp {
    display: block;
  }
  .TopMovies > h2 {
    font-size: 26px;
    line-height: 150%;
  }
  .TopMovies > h2 > span.catch {
    font-size: 18px;
  }
  .TopMovies__contents > li {
    gap: 8px;
    min-inline-size: 100%;
  }
  .TopMovies__contents-text {
    font-size: 15px;
  }
  .TopMovies__contents-link {
    box-sizing: border-box;
    inline-size: 280px;
    block-size: 50px;
    font-size: 14px;
    line-height: 140%;
  }
}
.TopResources {
  position: relative;
  padding: 80px 0 0;
  margin: 120px auto 93.39px;
}

.TopResources-bg {
  position: absolute;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: -1;
  inline-size: calc(100% - 20px);
  max-inline-size: 1256px;
  block-size: auto;
  margin: 0 auto;
  border-radius: 10px;
}

.TopResources-head-main {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 36px;
  font-weight: 700;
  line-height: 140%;
  color: #fff;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopResources-head-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  display: block;
  margin: 24px auto 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
  color: #fff;
  text-align: center;
  letter-spacing: 0.02em;
}

.TopResources-contents {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  justify-content: center;
  inline-size: calc(100% - 48px);
  max-inline-size: 1160px;
  margin: 56px auto 0;
}

.TopResources-contents-image {
  inline-size: 100%;
  block-size: auto;
}

.TopResources-contents-cn {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 16px;
  padding: 16px 24px 24px;
  background: #fff;
  border-radius: 3px;
}

.TopResources-contents-text {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 8px;
}

.TopResources-contents-text > span.tag {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  box-sizing: border-box;
  inline-size: fit-content;
  padding: 8px;
  font-size: 13px;
  font-weight: 700;
  line-height: 100%;
  color: #0074bf;
  letter-spacing: 0.02em;
  background: #fff;
  border: 1px solid #0074bf;
  transition: all 0.3s ease;
}

.TopResources-contents-text > span.title {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 160%;
  color: #333;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.TopResources-contents-more {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  display: block;
  inline-size: fit-content;
  padding: 0 0 0 30px;
  margin: 0 0 0 auto;
  font-size: 16px;
  font-weight: 700;
  line-height: 100%;
  color: #333;
  text-align: end;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.TopResources-contents-more:before {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  inline-size: 22px;
  block-size: 22px;
  margin: auto;
  content: "";
  background: #0074bf;
  border-radius: 100%;
}

.TopResources-contents-more:after {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 7px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto;
  content: "";
  border-block-start: 1.57px solid #fff;
  border-inline-end: 1.57px solid #fff;
  transform: rotate(45deg);
}

.TopResources-contents > li {
  display: flex;
  flex-direction: column;
  inline-size: calc(33.33333% - 16px);
  min-inline-size: 327px;
}

.TopResources-contents > li > a {
  display: flex;
  flex: 1;
  flex-direction: column;
  text-decoration: none;
  background: #fff;
  border: 1px solid transparent;
  border-radius: 3px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3019607843), 0 2px 8px 1px rgba(0, 0, 0, 0.1019607843);
}

.TopResources-contents > li > a:hover {
  border-color: #0074bf;
  box-shadow: 0 4px 16px 3px #54ade1, 0 1px 6px #57bbfd;
}

.TopResources-contents > li > a:hover .TopResources-contents-text > span.tag {
  color: #fff;
  background: #0074bf;
}

.TopResources-contents > li > a:hover .TopResources-contents-text > span.title {
  color: #0074bf;
  text-decoration-line: underline;
}

.TopResources-contents > li > a:hover .TopResources-contents-more {
  color: #0074bf;
}

.TopResources-toList {
  padding: 23px 50px 27px 32px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  background-color: #0099e4;
  border: none;
  border-radius: 100px;
  transition: all 0.3s ease;
  position: relative;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  inline-size: 384px;
  margin: 56px auto 0;
  line-height: 150%;
  background: linear-gradient(270deg, #027bc8, #0062ad);
  border: 1px solid transparent;
}

.TopResources-toList:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 30px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto 0;
  content: "";
  border-block-start: 2px solid #fff;
  border-inline-end: 2px solid #fff;
  transform: rotate(45deg);
}

.TopResources-toList:hover {
  color: #0074bf;
  background: #fff;
  border: 1px solid #0074bf;
}

.TopResources-toList:hover:after {
  border-color: #0074bf;
}

@media screen and (min-width: 769px) {
  .TopResources br.sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .TopResources {
    padding: 60px 0 63.92px;
    margin: 60px auto 0;
  }
  .TopResources-bg {
    inline-size: 100%;
    border-radius: 0;
  }
  .TopResources-head-main {
    font-size: 30px;
  }
  .TopResources-head-text {
    margin: 12px auto 0;
    font-size: 15px;
  }
  .TopResources-contents {
    margin: 32px auto 0;
  }
  .TopResources-contents-cn {
    padding: 16px 24px;
  }
  .TopResources-contents-text > span.tag {
    font-size: 12px;
  }
  .TopResources-contents-text > span.title {
    font-size: 15px;
  }
  .TopResources-contents-more {
    font-size: 15px;
  }
  .TopResources-toList {
    inline-size: 280px;
    padding: 14px 42px 16px 24px;
    margin: 32px auto 0;
    font-size: 14px;
  }
  .TopResources-toList:after {
    inset-inline-end: 22px;
  }
}
.top-user-flow {
  box-sizing: border-box;
  inline-size: calc(100% - 144px);
  max-inline-size: 1256px;
  padding: 80px 48px 80.6px;
  margin: 100px auto 0;
  background: linear-gradient(98.91deg, #1a98d8 5.5%, #055ba7 58.8%, #0c4d8e 97.39%);
  border-radius: 10px;
}

.top-user-flow-head {
  position: relative;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  inline-size: 681px;
  padding: 0 88px;
  margin: 0 auto;
}

.top-user-flow-head-subhead {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 286px;
  block-size: 34px;
  font-size: 16px;
  font-weight: 700;
  line-height: 100%;
  color: #fff;
  text-align: center;
  letter-spacing: 0.02em;
}

.top-user-flow-head-subhead:before {
  position: absolute;
  top: 0;
  right: 6px;
  bottom: 0;
  left: 6px;
  content: "";
  border: 1px solid #fff;
  transform: skew(-20deg);
}

.top-user-flow-head-mainhead {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  margin: 16px 0 0;
  font-size: 40px;
  font-weight: 700;
  line-height: 140%;
  color: #fff;
  text-align: center;
  letter-spacing: 0.02em;
}

.top-user-flow-head-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  margin: 24px 0 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
  color: #fff;
  text-align: center;
}

.top-user-flow-head-tag {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: absolute;
  inset-block-start: 32px;
  inset-inline: 0 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 80px;
  block-size: 80px;
  font-size: 16px;
  font-weight: 700;
  line-height: 22px;
  color: #002e60;
  text-align: center;
  letter-spacing: 0.02em;
  background: #fff;
  border-radius: 100%;
}

.top-user-flow .swiper-slide {
  block-size: auto;
}

.top-user-flow-slide {
  box-sizing: border-box;
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  min-inline-size: 370px;
  block-size: 100%;
  padding: 24px;
  text-decoration: none;
  cursor: pointer;
  background: #fff;
  border-radius: 3px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3019607843), 0 2px 8px 1px rgba(0, 0, 0, 0.1019607843);
}

.top-user-flow-slide-head {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 150%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.top-user-flow-slide-image {
  position: relative;
  flex: 1;
  margin: 24px 0 0;
}

.top-user-flow-slide-image-pc {
  inline-size: 232.05px;
  object-fit: contain;
}

.top-user-flow-slide-image-icon {
  position: absolute;
  inset-block-end: 0;
  inset-inline-end: -22.97px;
  inline-size: 90px;
  block-size: 90px;
}

.top-user-flow-slide-name {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  display: flex;
  align-items: center;
  padding: 0 0 0 30px;
  margin: 29px 0 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 160%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.top-user-flow-slide-name:before {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  inline-size: 22px;
  block-size: 22px;
  margin: auto 0;
  content: "";
  border-radius: 100%;
  transition: all 0.3s ease;
}

.top-user-flow-slide-name:after {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 7px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto;
  content: "";
  border-block-start: 1.57px solid #fff;
  border-inline-end: 1.57px solid #fff;
  transform: rotate(45deg);
}

.top-user-flow-slide-name.diagnosis-ict:before {
  background: #f8a001;
}

.top-user-flow-slide-name.diagnosis-condition:before {
  background: #01a674;
}

.top-user-flow-slide-name.diagnosis-business:before {
  background: #0074bf;
}

.top-user-flow-slide-name.diagnosis-dx:before {
  background: #d7105d;
}

.top-user-flow-slide:hover {
  box-shadow: 0 4px 16px 3px #54ade1, 0 1px 6px #57bbfd;
}

.top-user-flow-slide:hover .top-user-flow-slide-head {
  color: #0074bf;
  text-decoration: underline;
}

.top-user-flow-slide:hover .top-user-flow-slide-name {
  color: #0074bf;
}

.top-user-flow-slide:hover .top-user-flow-slide-name:before {
  background: #0074bf;
}

.top-user-flow-toList {
  padding: 22px 49px 26px 31px;
  font-size: 16px;
  font-weight: 700;
  color: #0074bf;
  text-decoration: none;
  background-color: #fff;
  border: none;
  border-radius: 100px;
  transition: all 0.3s ease;
  position: relative;
  box-sizing: border-box;
  display: block;
  inline-size: 384px;
  margin: 56px auto 0;
  line-height: 22.4px;
  text-align: center;
  border: 1px solid #0074bf;
}

.top-user-flow-toList:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 30px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto 0;
  content: "";
  border-block-start: 2px solid #0074bf;
  border-inline-end: 2px solid #0074bf;
  transform: rotate(45deg);
}

.top-user-flow-toList:hover {
  color: #fff;
  background: linear-gradient(270deg, #027bc8, #0062ad);
  border: 1px solid #fff;
}

.top-user-flow-toList:hover:after {
  border-block-start: 2px solid #fff;
  border-inline-end: 2px solid #fff;
}

@media screen and (min-width: 769px) {
  .top-user-flow br.pc {
    display: block;
  }
  .top-user-flow br.sp {
    display: none;
  }
}
@media screen and (max-width: 840px) {
  .top-user-flow-head {
    inline-size: 265px;
    padding: 0;
  }
  .top-user-flow-head-subhead {
    inline-size: 265px;
    block-size: 34px;
    font-size: 15px;
  }
  .top-user-flow-head-mainhead {
    font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
    padding: 0 0 0 82px;
    margin: 12px 0 0;
    font-size: 30px;
  }
  .top-user-flow-head-text {
    font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
    margin: 12px 0 0;
    font-size: 15px;
  }
  .top-user-flow-head-tag {
    inset-block-start: 55.5px;
    inset-inline: 7px auto;
    inline-size: 66px;
    block-size: 65px;
    font-size: 13px;
    line-height: 19px;
  }
}
@media screen and (max-width: 768px) {
  .top-user-flow {
    inline-size: 100%;
    padding: 60px 24px;
    margin: 60px auto 0;
    background: linear-gradient(99.75deg, #1a98d8 4.05%, #055ba7, #0c4d8e 72.49%);
    border-radius: unset;
  }
  .top-user-flow-slide {
    min-inline-size: 0;
    max-inline-size: 327px;
    padding: 16px 0;
  }
  .top-user-flow-slide-head {
    font-size: 18px;
  }
  .top-user-flow-slide-image-pc {
    inline-size: auto;
    block-size: 120px;
  }
  .top-user-flow-slide-image-icon {
    inset-inline-end: -21.02px;
    inline-size: 82.36px;
    block-size: 82.36px;
  }
  .top-user-flow-slide-name {
    margin: 16px 0 0;
    font-size: 15px;
  }
  .top-user-flow-toList {
    inline-size: 280px;
    padding: 14px 42px 16px 24px;
    margin: 32px auto 0;
    font-size: 14px;
    line-height: 19.6px;
  }
  .top-user-flow-toList:after {
    inset-inline-end: 22px;
  }
}
.web-movie-seminar {
  margin: 100px auto 0;
}

.web-movie-seminar-head-main {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 36px;
  font-weight: 700;
  line-height: 140%;
  color: #212121;
  text-align: center;
  letter-spacing: 0.02em;
}

.web-movie-seminar-head-text {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  display: block;
  margin: 24px auto 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
  color: #333;
  text-align: center;
  letter-spacing: 0.02em;
}

.web-movie-seminar-contents {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  justify-content: center;
  inline-size: calc(100% - 48px);
  max-inline-size: 1160px;
  margin: 56px auto 0;
}

.web-movie-seminar-contents-image {
  inline-size: 100%;
  block-size: auto;
  border-radius: 2px 2px 0 0;
}

.web-movie-seminar-contents-cn {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 16px;
  padding: 24px;
  background: #fff;
}

.web-movie-seminar-contents-text {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 8px;
}

.web-movie-seminar-contents-text > span.date {
  font-size: 14px;
  font-weight: 700;
  line-height: 150%;
  color: #6c6c6c;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.web-movie-seminar-contents-text > span.title {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 160%;
  color: #333;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.web-movie-seminar-contents-more {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  position: relative;
  display: block;
  inline-size: fit-content;
  padding: 0 0 0 30px;
  margin: 0 0 0 auto;
  font-size: 16px;
  font-weight: 700;
  line-height: 100%;
  color: #333;
  text-align: end;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
}

.web-movie-seminar-contents-more:before {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  inline-size: 22px;
  block-size: 22px;
  margin: auto;
  content: "";
  background: #0074bf;
  border-radius: 100%;
}

.web-movie-seminar-contents-more:after {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 7px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto;
  content: "";
  border-block-start: 1.57px solid #fff;
  border-inline-end: 1.57px solid #fff;
  transform: rotate(45deg);
}

.web-movie-seminar-contents > li {
  display: flex;
  flex-direction: column;
  inline-size: calc(33.33333% - 16px);
  min-inline-size: 327px;
}

.web-movie-seminar-contents > li > a {
  display: flex;
  flex: 1;
  flex-direction: column;
  text-decoration: none;
  border-radius: 3px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3019607843), 0 2px 8px 1px rgba(0, 0, 0, 0.1019607843);
}

.web-movie-seminar-contents > li > a .web-movie-seminar-contents-cn {
  border: 1px solid transparent;
  border-block-start: none;
  border-radius: 3px;
}

.web-movie-seminar-contents > li > a:hover {
  box-shadow: 0 4px 16px 3px #54ade1, 0 1px 6px #57bbfd;
}

.web-movie-seminar-contents > li > a:hover .web-movie-seminar-contents-cn {
  border-color: #0074bf;
}

.web-movie-seminar-contents > li > a:hover .web-movie-seminar-contents-text > span.date {
  color: #0074bf;
  text-decoration-line: underline;
}

.web-movie-seminar-contents > li > a:hover .web-movie-seminar-contents-text > span.title {
  color: #0074bf;
  text-decoration-line: underline;
}

.web-movie-seminar-contents > li > a:hover .web-movie-seminar-contents-more {
  color: #0074bf;
}

.web-movie-seminar-toList {
  padding: 23px 50px 27px 32px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  background-color: #0099e4;
  border: none;
  border-radius: 100px;
  transition: all 0.3s ease;
  position: relative;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  inline-size: 384px;
  margin: 56px auto 0;
  line-height: 150%;
  background: linear-gradient(270deg, #027bc8, #0062ad);
  border: 1px solid transparent;
}

.web-movie-seminar-toList:after {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 30px;
  inline-size: 5px;
  block-size: 5px;
  margin: auto 0;
  content: "";
  border-block-start: 2px solid #fff;
  border-inline-end: 2px solid #fff;
  transform: rotate(45deg);
}

.web-movie-seminar-toList:hover {
  color: #0074bf;
  background: #fff;
  border: 1px solid #0074bf;
}

.web-movie-seminar-toList:hover:after {
  border-color: #0074bf;
}

@media screen and (min-width: 769px) {
  .web-movie-seminar br.sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .web-movie-seminar {
    margin: 60px auto 0;
  }
  .web-movie-seminar-head-main {
    font-size: 30px;
  }
  .web-movie-seminar-head-text {
    margin: 12px auto 0;
    font-size: 15px;
  }
  .web-movie-seminar-contents {
    margin: 32px auto 0;
  }
  .web-movie-seminar-contents-cn {
    padding: 16px 24px;
  }
  .web-movie-seminar-contents-text {
    gap: 4px;
  }
  .web-movie-seminar-contents-text > span.date {
    font-size: 13px;
  }
  .web-movie-seminar-contents-text > span.title {
    font-size: 15px;
  }
  .web-movie-seminar-contents-more {
    font-size: 15px;
  }
  .web-movie-seminar-toList {
    inline-size: 280px;
    padding: 14px 42px 16px 24px;
    margin: 32px auto 0;
    font-size: 14px;
  }
  .web-movie-seminar-toList:after {
    inset-inline-end: 22px;
  }
}
.slideshow {
  position: relative;
  inline-size: 100%;
  margin: 56px auto 0;
  overflow: visible;
}

.slideshow .swiper {
  overflow: visible;
}

.slideshow-pagination {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: center;
  block-size: 28px;
  margin-block-start: 32px;
}

.slideshow-pagination-page-button {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: center;
  inline-size: fit-content;
}

.slideshow-pagination-nav-button {
  display: block;
  inline-size: 12px;
  block-size: 12px;
  padding: 0;
  cursor: pointer;
  background: none;
  border: none;
  border-block-start: 2px solid #fff;
  border-inline-end: 2px solid #fff;
}

.slideshow-pagination-nav-button.prev {
  transform: rotate(-135deg);
}

.slideshow-pagination-nav-button.next {
  transform: rotate(45deg);
}

.slideshow-pagination.dark .slideshow-pagination-nav-button {
  border-block-start: 2px solid #0074bf;
  border-inline-end: 2px solid #0074bf;
}

@media screen and (max-width: 768px) {
  .slideshow {
    margin: 32px auto 0;
  }
  .slideshow-pagination {
    margin-block-start: 24px;
  }
}
.slideshow .swiper-slide {
  inline-size: 370px;
}

.slideshow-pagination-page-button .swiper-pagination-bullet {
  box-sizing: border-box;
  padding: 3.5px;
  cursor: pointer;
  background: #fff;
  border: none;
  border-radius: 100%;
  opacity: 1;
}

.slideshow-pagination-page-button .swiper-pagination-bullet-active {
  background: none;
  border: 2px solid #fff;
}

.slideshow-pagination.dark .slideshow-pagination-page-button .swiper-pagination-bullet {
  background: #6c6c6c;
}

.slideshow-pagination.dark .slideshow-pagination-page-button .swiper-pagination-bullet-active {
  background: none;
  border: 2px solid #0074bf;
}

@media screen and (max-width: 768px) {
  .slideshow .swiper-slide {
    inline-size: 327px;
  }
}
.ColumnsSlideshow {
  position: relative;
  inline-size: 100%;
  margin: 56px auto 0;
  overflow: visible;
}

.ColumnsSlideshow .swiper {
  overflow: visible;
}

.ColumnsSlideshow-pagination {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: center;
  block-size: 28px;
  margin-block-start: 32px;
}

.ColumnsSlideshow-pagination-page-button {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: center;
  inline-size: fit-content;
}

.ColumnsSlideshow-pagination-nav-button {
  display: block;
  inline-size: 12px;
  block-size: 12px;
  padding: 0;
  cursor: pointer;
  background: none;
  border: none;
  border-block-start: 2px solid #fff;
  border-inline-end: 2px solid #fff;
}

.ColumnsSlideshow-pagination-nav-button.prev {
  transform: rotate(-135deg);
}

.ColumnsSlideshow-pagination-nav-button.next {
  transform: rotate(45deg);
}

.ColumnsSlideshow-pagination.dark .ColumnsSlideshow-pagination-nav-button {
  border-block-start: 2px solid #0074bf;
  border-inline-end: 2px solid #0074bf;
}

@media screen and (max-width: 768px) {
  .ColumnsSlideshow {
    margin: 32px auto 0;
  }
  .ColumnsSlideshow-pagination {
    margin-block-start: 24px;
  }
}
.ColumnsSlideshow .swiper-slide {
  inline-size: 370px;
}

.ColumnsSlideshow-pagination-page-button .swiper-pagination-bullet {
  box-sizing: border-box;
  padding: 3.5px;
  cursor: pointer;
  background: #fff;
  border: none;
  border-radius: 100%;
  opacity: 1;
}

.ColumnsSlideshow-pagination-page-button .swiper-pagination-bullet-active {
  background: none;
  border: 2px solid #fff;
}

.ColumnsSlideshow-pagination.dark .ColumnsSlideshow-pagination-page-button .swiper-pagination-bullet {
  background: #6c6c6c;
}

.ColumnsSlideshow-pagination.dark .ColumnsSlideshow-pagination-page-button .swiper-pagination-bullet-active {
  background: none;
  border: 2px solid #0074bf;
}

@media screen and (max-width: 768px) {
  .ColumnsSlideshow .swiper-slide {
    inline-size: 327px;
  }
}
.TopImportantAnnounce {
  font-family: Noto Sans JP, メイリオ, system-ui, -apple-system, Helvetica, Arial, sans-serif;
  background: #fff7f7;
  border-block-start: 1px solid #e22900;
}

.TopImportantAnnounce-content {
  box-sizing: border-box;
  display: flex;
  gap: 16px;
  inline-size: 100%;
  max-inline-size: 1400px;
  padding: 12px 71px 12px 24px;
  margin: 0 auto;
  text-decoration: none;
}

.TopImportantAnnounce > a .TopImportantAnnounce-right:after {
  position: absolute;
  inset-inline-end: -50px;
  inline-size: 18px;
  block-size: 18px;
  content: "";
  background: url(/img/top/link_attention_right.svg) no-repeat;
}

.TopImportantAnnounce-left {
  display: flex;
  gap: 32px;
  align-items: center;
}

.TopImportantAnnounce-left p {
  font-size: 16px;
  color: #e22900;
}

.TopImportantAnnounce-left-title {
  position: relative;
  padding-inline-start: 39px;
  font-weight: 700;
  line-height: 16px;
}

.TopImportantAnnounce-left-title:before {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  display: flex;
  align-items: end;
  justify-content: center;
  inline-size: 26px;
  block-size: 24px;
  padding-block-end: 2px;
  margin: auto 0;
  content: "";
  background: url(/img/top/icon_attention.svg) no-repeat;
}

.TopImportantAnnounce-left-date {
  line-height: 25.6px;
}

.TopImportantAnnounce-right {
  position: relative;
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: center;
}

.TopImportantAnnounce-right p {
  margin-block-start: 14px;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 25.6px;
  color: #e22900;
  letter-spacing: 0.02em;
}

.TopImportantAnnounce-right p:first-child {
  margin-block-start: 0;
}

.TopImportantAnnounce-bold {
  font-weight: 700;
}

.TopImportantAnnounce-annotation {
  margin-block-start: 4px;
  font-size: 13px;
  font-weight: 400;
  line-height: 150%;
  color: #6c6c6c;
}

@media screen and (max-width: 768px) {
  .TopImportantAnnounce-content {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 12px 0 12px 16px;
  }
  .TopImportantAnnounce > a {
    position: relative;
  }
  .TopImportantAnnounce > a .TopImportantAnnounce-right:after {
    inset-inline-end: 10px;
  }
  .TopImportantAnnounce-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: center;
  }
  .TopImportantAnnounce-left p {
    font-size: 15px;
  }
  .TopImportantAnnounce-left-title {
    line-height: 26px;
  }
  .TopImportantAnnounce-left-date {
    inline-size: 100%;
  }
  .TopImportantAnnounce-right {
    padding-inline-end: 46px;
  }
  .TopImportantAnnounce-right p {
    font-size: 15px;
  }
}
/*$vite$:1*/
