:root {
  --color-theme: #297ec1;
  --color-foreground-subtle: #aaaaaa;
  --font-family-jp: "Noto Sans JP", sans-serif;
  --font-family-en: "Geologica", sans-serif;
  --font-weight-default: 400;
  --font-weight-bold: 500;
  --border-radius-default: 8px;
}

/* ---------------------------------------
  Layout
---------------------------------------- */
.l-section {
  margin-top: 30px;
  padding: 0;
}

.l-section-group {
  margin-bottom: 40px;
}

.l-sidemenu {
  display: flex;
}
.l-sidemenu .l-sidemenu-menu {
  width: 220px;
}
@media (max-width: 767px) {
  .l-sidemenu .l-sidemenu-menu {
    width: unset;
    max-width: 220px;
    position: fixed;
    z-index: 100;
  }
}
.l-sidemenu .l-sidemenu-main {
  flex: 1;
}

.l-button {
  margin-top: 20px;
}

/* ---------------------------------------
  Component
---------------------------------------- */
.c-sidemenu {
  height: 100vh;
  background: linear-gradient(22deg, #008a9d 14.37%, #297ec2 84.78%);
  color: var(--color-background);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
}
.c-sidemenu .sp-hamburger {
  display: none;
}
@media (max-width: 767px) {
  .c-sidemenu .sp-hamburger {
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--color-background);
    color: var(--color-theme);
    font-size: 10px;
    font-weight: var(--font-weight-bold);
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
    width: 50px;
    height: 50px;
    padding: 5px;
    border-radius: 0 20px 20px 0;
    position: absolute;
    bottom: 10px;
    left: 0;
    z-index: 100;
  }
}
.c-sidemenu .logo-area {
  padding: 30px 20px 20px;
}
@media (max-width: 767px) {
  .c-sidemenu .logo-area {
    display: none;
  }
  .c-sidemenu .logo-area.active {
    display: block;
  }
}
.c-sidemenu .logo-area .logo-img {
  width: 100%;
  max-width: 120px;
  height: auto;
}
.c-sidemenu .logo-area .site-title {
  margin-top: 5px;
  color: var(--color-background);
  font-size: var(--font-size-base);
  font-family: var(--font-family-en);
  letter-spacing: 0.05em;
}
.c-sidemenu .nav-area {
  flex: 1;
  overflow-y: auto;
  padding-left: 10px;
}
@media (max-width: 767px) {
  .c-sidemenu .nav-area {
    display: none;
  }
  .c-sidemenu .nav-area.active {
    display: block;
  }
}
.c-sidemenu .nav-area > * {
  margin-bottom: 10px;
}
.c-sidemenu .nav-area .link {
  display: block;
  padding: 10px 15px;
  border-radius: 10px 0 0 10px;
  transition: background-color 0.2s;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
}
.c-sidemenu .nav-area .link:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.c-sidemenu .nav-area .link.active {
  background-color: var(--color-background-subtle);
  color: var(--color-theme);
  font-weight: var(--font-weight-bold);
}
.c-sidemenu .nav-area .accordion-group {
  border-radius: 10px 0 0 10px;
  transition: background-color 0.2s;
}
.c-sidemenu .nav-area .accordion-group:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.c-sidemenu .nav-area .accordion-group .accordion-trigger {
  width: 100%;
  padding: 10px 15px;
  border-radius: 10px 0 0 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
}
.c-sidemenu .nav-area .accordion-group .accordion-trigger::after {
  content: "";
  width: 6px;
  height: 6px;
  border-right: 2px solid var(--color-background);
  border-bottom: 2px solid var(--color-background);
  transform: rotate(45deg);
  transition: transform 0.3s;
}
.c-sidemenu .nav-area .accordion-group .accordion-trigger[aria-expanded=true]::after {
  transform: rotate(-135deg);
}
.c-sidemenu .nav-area .accordion-group .accordion-content {
  height: 0;
  overflow: hidden;
  transition: height 0.3s ease;
}
.c-sidemenu .nav-area .accordion-group .accordion-content .link-list {
  margin-left: 15px;
}
.c-sidemenu .nav-area .accordion-group .accordion-content .link-list .link {
  padding: 8px 15px;
  font-size: var(--font-size-lv6);
  font-weight: var(--font-weight-default);
}
.c-sidemenu .nav-area .accordion-group .accordion-content .link-list .link .icon {
  display: inline-block;
  width: 12px;
  height: 12px;
}

.c-title-page {
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-theme);
  color: var(--color-theme);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
}

.c-title-section {
  color: var(--color-theme);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-base);
}

.c-card {
  margin-top: 15px;
  background: var(--color-background);
  border-radius: var(--border-radius-default);
  padding: 20px 30px;
}

/* ---------------------------------------
  Page
---------------------------------------- */
.p-body {
  background: #297ec2;
  font-size: var(--font-size-lv6);
}

.p-main {
  margin-top: 20px;
  min-height: calc(100vh - 20px);
  background: var(--color-background-subtle);
  border-radius: 30px 0 0 0;
  padding: 20px 40px;
}
@media (max-width: 767px) {
  .p-main {
    margin-top: 0;
    border-radius: 0;
    padding: 20px;
  }
}

.p-card .row {
  display: flex;
  align-items: flex-start;
}
@media (max-width: 1023px) {
  .p-card .row {
    flex-direction: column;
    gap: 20px;
  }
}
.p-card .title {
  color: var(--color-theme);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-base);
}
.p-card.parts .row .text-area {
  width: 30%;
  padding-right: 20px;
}
@media (max-width: 1023px) {
  .p-card.parts .row .text-area {
    width: 100%;
    padding-right: 0;
  }
}
.p-card.parts .row .thumbnail {
  width: 70%;
  border: 1px solid var(--color-foreground-subtle);
}
@media (max-width: 1023px) {
  .p-card.parts .row .thumbnail {
    width: 100%;
  }
}
.p-card.parts .description {
  margin-top: 5px;
  font-size: var(--font-size-lv6);
}
.p-card.parts .version {
  margin-top: 5px;
  font-size: var(--font-size-lv6);
  color: var(--color-foreground-subtle);
}
.p-card.layout .row .text-area {
  width: 20%;
  padding-right: 20px;
}
.p-card.layout .row .code-block {
  width: 80%;
  position: relative;
}
.p-card.layout .row .code-block pre {
  display: block;
  white-space: pre-wrap;
  padding: 20px;
  background: var(--color-foreground);
  color: var(--color-background);
}
.p-card.layout .row .code-block .copy-button {
  background: var(--color-foreground-subtle);
  padding: 10px;
  font-size: var(--font-size-lv7);
  position: absolute;
  top: 0;
  right: 0;
}/*# sourceMappingURL=library-style.css.map */