@charset "utf-8";

body {
  color: #333;
}

.main {
  min-height: 0;
}

.inner {
  max-width: 1240px;
}

.headerPC .headerNav ul li.current a,
.headerPC .headerNav ul li a:hover {
  border-bottom-color: #f6a100;
}

.headerPC .headerSearch a:before,
.headerSP .headerSearch a:before {
  background-color: #8c8c8c;
}

.topicpath {
  margin: 0;
  background: transparent;
}

.topicpath ul {
  max-width: 1240px;
  margin: 0 auto;
  padding: 16px 20px;
  font-size: 0.8em;
}

.topicpath ul li {
  display: inline-block;
  margin-right: 8px;
  color: #888;
}

.topicpath ul li:last-child:after {
  content: "";
  display: none;
}

.topicpath ul li a {
  color: #f6a100;
}

.cord-hero {
  position: relative;
  color: #fff;
  background: url(../images/detail_main_bg.png) center center / cover no-repeat;
}

.cord-hero:before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 77, 117, 0.35);
}

.cord-hero .inner {
  position: relative;
  padding-top: 72px;
  padding-bottom: 58px;
}

.cord-hero h1 {
  font-size: 2em;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.2;
}

.cord-hero p {
  margin-top: 10px;
  font-size: 1.2em;
  font-weight: bold;
}

.cord-page-hero h1 {
  font-size: 1.7em;
}

.cord-page-hero p {
  font-size: 1.35em;
}

.cord-content {
  padding: 36px 0 90px;
}

.cord-block-title {
  margin-bottom: 32px;
  text-align: center;
}

.cord-block-title h2 {
  display: inline-block;
  font-size: 2em;
  font-weight: bold;
  color: #333;
  line-height: 1;
}

.cord-block-title p {
  margin-top: 10px;
  color: #f6a100;
  font-weight: bold;
}

.cord-section {
  padding: 56px 0 76px;
}

.cord-section.is-white {
  background: #f7f7f7;
}

.cord-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px 18px;
}

.cord-card a {
  display: block;
}

.cord-card figure {
  margin-bottom: 10px;
  overflow: hidden;
}

.cord-card img {
  width: 100%;
  height: auto;
  display: block;
}

.cord-tag {
  display: inline-block;
  margin-bottom: 8px;
  padding: 3px 9px;
  color: #fff;
  font-size: 0.9em;
  line-height: 1.2;
  border-radius: 3px;
}

.cord-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 8px;
  margin-bottom: 8px;
}

.cord-tag-list .cord-tag {
  margin-bottom: 0;
}

.cord-tag.red { background: #cf4e59; }
.cord-tag.blue { background: #3f91bb; }
.cord-tag.green { background: #67b13e; }
.cord-tag.orange { background: #f39b3e; }
.cord-tag.purple { background: #7c66a6; }

.cord-card h3 {
  font-size: 1.3em;
  line-height: 1.5;
  font-weight: bold;
}

.cord-card p {
  font-size: 1.1em;
  line-height: 1.5;
}

.cord-related-columns {
  margin-top: 48px;
  padding: 36px;
  background: #f7f7f7;
}

.cord-related-columns h3 {
  margin-bottom: 24px;
  font-size: 1.5em;
  font-weight: bold;
  line-height: 1.4;
}

.cord-more {
  margin-top: 40px;
  text-align: center;
}

.cord-more a {
  display: inline-block;
  min-width: 160px;
  padding: 12px 24px;
  color: #fff;
  font-weight: bold;
  border-radius: 999px;
  background: #f6a100;
}

.cord-topics {
  padding: 52px 0 78px;
  background: #f7f7f7;
}

.cord-topics .cord-cards {
  grid-template-columns: repeat(5, 1fr);
}

.cord-topics-slider-wrap .cord-topics-head,
.cord-topics-slider-wrap .cord-topics-foot {
  width: 100%;
  margin: 0 auto;
  padding: 0 20px;
}

.cord-topics-slider-wrap .cord-topics-slider {
  width: 100%;
  max-width: none;
  margin: 0;
}

.cord-topics-slider-wrap .cord-topics-slider .cord-card {
  margin: 0 12px;
}

.cord-topics-slider-wrap .cord-topics-slider .cord-card a {
  display: block;
}

.cord-topics-slider-wrap .cord-topics-slider .slick-list {
  padding-top: 4px;
  padding-bottom: 4px;
}

.cord-topics-slider-wrap .cord-topics-foot {
  margin-top: 26px;
}

.cord-topics-slider-wrap .cord-more {
  margin-top: 0;
}

.cord-carousel-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 26px;
}

.cord-carousel-nav .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #cdcdcd;
}

.cord-carousel-nav .dot.active {
  background: #f6a100;
}

.cord-topics-slider-wrap .js-topics-dots .slick-dots {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.cord-topics-slider-wrap .js-topics-dots .slick-dots li button {
  width: 6px;
  height: 6px;
  padding: 0;
  text-indent: 200%;
  white-space: nowrap;
  border: 0;
  border-radius: 50%;
  background: #cdcdcd;
  overflow: hidden;
}

.cord-topics-slider-wrap .js-topics-dots .slick-dots li.slick-active button {
  background: #f6a100;
}

.cord-topics-slider-wrap .cord-carousel-nav .slick-arrow.slick-disabled {
  opacity: 0.4;
  cursor: default;
}

.cord-circle-btn {
  width: 30px;
  height: 30px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: #f6a100;
  position: relative;
  cursor: pointer;
}

.cord-circle-btn:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 7px;
  height: 7px;
  margin-top: -4px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}

.cord-circle-btn.prev:before {
  margin-left: -2px;
  transform: rotate(-135deg);
}

.cord-circle-btn.next:before {
  margin-left: -6px;
  transform: rotate(45deg);
}

.cord-bottom-cta {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.cord-cta-box {
  padding: 54px 20px 52px;
  text-align: center;
  color: #fff;
}

.cord-cta-box h2 {
  margin-bottom: 20px;
  font-size: 1.35em;
  font-weight: bold;
}

.cord-cta-box p {
  font-size: 1.1em;
  line-height: 1.7;
}

.cord-cta-box .icon {
  width: 64px;
  margin: 18px auto;
}

.cord-cta-box .bubble {
  position: relative;
  width: 72px;
  height: 48px;
  margin: 14px auto 20px;
}

.cord-cta-box .bubble:before,
.cord-cta-box .bubble:after {
  content: "";
  position: absolute;
  border-radius: 50%;
}

.cord-cta-box .bubble:before {
  top: 0;
  left: 0;
  width: 50px;
  height: 34px;
  background: #35b9be;
}

.cord-cta-box .bubble:after {
  right: 0;
  top: 8px;
  width: 38px;
  height: 28px;
  background: #fff;
}

.cord-cta-box .btn {
  margin-top: 8px;
}

.cord-cta-box .btn a {
  display: inline-block;
  min-width: 220px;
  padding: 14px 20px;
  border-radius: 999px;
  background: #fff;
  font-size: 1.35em;
  font-weight: bold;
}

.cord-cta-dl {
  background: #d78f00;
}

.cord-cta-contact {
  background: #e2a735;
}

.cord-site-footer {
  background: #f8f8f8;
}

.cord-site-footer .inner {
  padding-top: 42px;
  padding-bottom: 38px;
}

.cord-footer-nav {
  margin-bottom: 30px;
}

.cord-footer-nav ul {
  display: flex;
  gap: 20px;
  font-size: 1em;
}

.cord-footer-main {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 20px;
}

.cord-company strong {
  display: block;
  margin-bottom: 12px;
  font-size: 1.5em;
  font-weight: bold;
}

.cord-company p {
  font-size: 1em;
  line-height: 1.7;
}

.cord-footer-actions {
  display: grid;
  grid-template-columns: auto auto;
  grid-template-areas:
    "sns contact"
    "links links";
  justify-content: end;
  align-items: center;
  column-gap: 16px;
  row-gap: 12px;
  text-align: right;
}

.cord-footer-sns {
  grid-area: sns;
  display: flex;
  justify-content: center;
  gap: 10px;
  margin: 0;
}

.cord-footer-sns a {
  width: 38px;
  height: 38px;
}

.cord-footer-contact {
  grid-area: contact;
}

.cord-footer-contact a {
  display: inline-block;
  min-width: 250px;
  padding: 14px 22px;
  color: #fff;
  text-align: center;
  font-size: 1.35em;
  font-weight: bold;
  border-radius: 999px;
  background: #f6a100;
}

.cord-footer-links {
  grid-area: links;
  margin-top: 6px;
  font-size: 0.95em;
}

.cord-footer-links ul {
  display: flex;
  justify-content: flex-end;
  gap: 14px;
}

.cord-copyright {
  padding: 18px 20px;
  text-align: center;
  color: #fff;
  background: #2f2f31;
}

.cord-pagetop a {
  width: 46px;
  height: 46px;
  padding-top: 20px;
  border-radius: 50%;
  font-size: 0;
  background: #777;
}

.cord-pagetop a:before {
  top: 17px;
  border-color: #fff;
}

.cord-index-hero {
    position: relative;
    padding: 0px 0 0px;
    color: #111;
}
.cord-index-hero .inner {
  position: relative;
  z-index: 1;
}

.cord-index-hero h1 {
  max-width: 680px;
  padding-bottom: 16px;
  margin-bottom: 12px;
  font-size: 2em;
  line-height: 1.35;
  font-weight: bold;
  border-bottom: 2px solid #f6a100;
}


.cord-list-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 240px;
  gap: 34px;
}

.cord-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 40px;
}

.cord-filter li a {
  display: block;
  padding: 10px 18px;
  border-radius: 999px;
  color: #555;
  background: #ececec;
  font-weight: bold;
}

.cord-filter li.current a {
  color: #fff;
  background: #f6a100;
}

.cord-list-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 34px 32px;
}

.cord-list-grid.is-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 34px 24px;
}

.cord-list-grid .cord-card p, .cord-list-grid .cord-card h3 {
    font-size: 1.15em;
    margin-bottom: 10px;
}

.cord-side-banners .banner {
  margin-bottom: 14px;
}

.cord-side-banners .banner a {
  display: block;
  position: relative;
}

.cord-side-banners .banner span {
  display: none !important;
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.8em;
  font-weight: bold;
  background: rgba(0, 0, 0, 0.2);
}

.cord-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 56px;
}

.cord-pagination .num {
  font-size: 1em;
}

.cord-detail-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 36px;
}

.cord-article h2{
  margin-bottom: 30px;
  font-size: 2em;
  font-weight: bold;
}
.cord-page-article h2 {
  margin-bottom: 30px;
  font-size: 2em;
  font-weight: bold;
  text-align: center;
}
.cord-article .cord-dl-download-body p{
  margin-bottom: 0;
  
}
.cord-article .cord-dl-download-body p.cord-dl-download-title{
  font-weight: bold;
}
.cord-dl-download-action a{
  display: block;
  background-color: #333;
  color: #FFF;
  padding: 10px;
  text-align: center;
}
.cord-article p{
  margin-bottom: 26px;
  font-size: 1em;
  line-height: 1.9;
}
.cord-page-article p {
  margin-bottom: 26px;
  font-size: 1em;
  line-height: 1.9;
}
.cord-dl-download-list {
    display: grid;
    gap: 30px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 30px;
}


.cord-article figure {
  margin-bottom: 30px;
}

.cord-inline-image {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 24px;
  align-items: start;
  margin-bottom: 26px;
}

.cord-section-heading {
    margin: 36px 0 22px;
    padding-left: 14px;
    font-size: 1.35em;
    font-weight: bold;
    border-left: 5px solid #f6a100;
    border-bottom: 1px solid #cfcfcf;
    padding-bottom: 6px;
}

.cord-sub-heading {
  margin-bottom: 16px;
  font-size: 1.13em;;
  font-weight: bold;
}

.cord-sub-heading:before {
  content: "•";
  margin-right: 6px;
  color: #f6a100;
}

.cord-cv-box {
  margin: 36px 0;
  padding: 32px 28px;
  background: #f3f3f3;
  text-align: center;
}

.cord-article p.cord-cv-title {
  margin: 0;
  color: #111;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
}

.cord-cv-lead {
  margin: 14px 0 0;
  color: #333;
  font-size: 1.4rem;
  line-height: 1.9;
}

.cord-cv-button {
  margin: 22px 0 0;
}
.headerPC .headerNav ul li a.contactBtn{
    display: block;
    top: 0;
    bottom: 0;
    margin: auto;
    background-color: #f6a100;
    color: #FFF;
    padding: 30px 30px;
}
.cord-cv-button a {
  display: block;
  padding: 18px 24px;
  border-radius: 6px;
  background: #f55656;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.4;
  text-decoration: none;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

.cord-cv-button a:hover {
  opacity: 0.9;
}

.cord-article-dates {
  margin: -6px 0 18px;
  text-align: right;
}

.cord-article-dates p {
  margin: 0;
  color: #666;
  font-size: 1rem;
  line-height: 1.6;
}

.cord-supervisor {
  margin: 36px 0 0;
  color: #333;
  font-size: 1.4rem;
  line-height: 1.8;
  text-align: right;
}

.cord-article ul {
  margin: 14px 0 28px 20px;
}

.cord-article ul li {
  margin-bottom: 8px;
  list-style: disc;
  font-size: 1.15em;
}

.cord-info-box {
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 20px;
  align-items: center;
  padding: 20px;
  background: #efefef;
}

.cord-info-box h3 {
  margin-bottom: 10px;
  color: #f6a100;
  font-size: 1.35em;
  font-weight: bold;
}

.cord-side-menu {
  margin-bottom: 20px;
  border: 1px solid #e5e5e5;
}

.cord-side-menu h3 {
  padding: 16px;
  color: #fff;
  font-size: 1.25em;
  font-weight: bold;
  background: #f6a100;
}

.cord-side-menu ul li {
  border-top: 1px solid #e5e5e5;
}

.cord-side-menu ul li a {
  position: relative;
  display: block;
  padding: 14px 34px 14px 16px;
  font-size: 1.15em;
  background: #efe6cf;
}

.cord-side-menu ul li a:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 14px;
  width: 8px;
  height: 8px;
  margin-top: -4px;
  border-top: 2px solid #d08a00;
  border-right: 2px solid #d08a00;
  transform: rotate(45deg);
}

.cord-page-wrap {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 40px;
}

.cord-local-nav {
  border: 1px solid #ddd;
}

.cord-local-nav h3 {
  padding: 14px 14px;
  color: #fff;
  font-size: 1.2em;
  font-weight: bold;
  background: #f6a100;
}

.cord-local-nav ul li {
  border-top: 1px solid #ddd;
}

.cord-local-nav ul li a {
  position: relative;
  display: block;
  padding: 12px 28px 12px 14px;
  font-size: 1.05em;
  background: #f1ead6;
}

.cord-local-nav ul li a:after {
  content: "+";
  position: absolute;
  right: 12px;
  top: 50%;
  margin-top: -9px;
  color: #d08a00;
}

.cord-local-nav ul li.sub a {
  background: #f8f8f8;
  font-size: 1em;
}

.cord-page-article .thumb-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-bottom: 12px;
}

.cord-caption {
  margin: 8px 0 30px;
  font-size: 0.9em;
}

.cord-download-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-bottom: 28px;
}

.cord-download-grid .btn a {
  display: inline-block;
  min-width: 170px;
  padding: 10px 18px;
  color: #fff;
  font-size: 1em;
  font-weight: bold;
  text-align: center;
  border-radius: 999px;
  background: #444;
}

.cord-map {
  margin: 24px 0 40px;
}

.cord-map iframe {
  width: 100%;
  height: 220px;
}

.cord-video {
  position: relative;
  margin-bottom: 36px;
}

.cord-video .play {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 68px;
  height: 48px;
  margin: -24px 0 0 -34px;
  border-radius: 14px;
  background: #ff0000;
}

.cord-video .play:before {
  content: "";
  position: absolute;
  left: 27px;
  top: 13px;
  border-style: solid;
  border-width: 10px 0 10px 16px;
  border-color: transparent transparent transparent #fff;
}

.cord-file-box {
  margin-bottom: 18px;
  padding: 20px;
  background: #efefef;
}

.cord-file-box h3 {
  margin-bottom: 12px;
  color: #f6a100;
  font-size: 1em;
  font-weight: bold;
}

.cord-file-box.link h3 {
  color: #f09f1f;
}

@media screen and (max-width: 1180px) {
  .cord-index-hero h1,
  .cord-hero h1,
  .cord-page-hero h1 { font-size: 1.5em; }
  .cord-company strong { font-size: 1.3em; }
  .cord-card h3,
  .cord-card p,
  .cord-list-grid .cord-card p,
  .cord-list-grid .cord-card h3,
  .cord-article p,
  .cord-page-article p { font-size: 1em; }
  .cord-article h2,
  .cord-page-article h2 { font-size: 1.5em; }
}

@media screen and (max-width: 768px) {
  body { font-size: 0.9em; }
  .cord-content { padding: 20px 0 50px; }
  .topicpath ul { padding: 10px 15px; }
  .cord-index-hero { padding: 0; }
  .cord-index-hero:after { height: 120px; }
  .cord-index-hero h1,
  .cord-hero h1,
  .cord-page-hero h1 { font-size: 1.4em; }
  .cord-hero p,
  .cord-page-hero p { font-size: 1em; }
  .cord-block-title h2 { font-size: 1.7em; }
  .cord-section { padding: 34px 0 46px; }
  .cord-cards,
  .cord-topics .cord-cards,
  .cord-list-grid,
  .cord-list-grid.is-3,
  .cord-download-grid,
  .cord-page-article .thumb-row { grid-template-columns: 1fr 1fr; }
  .cord-list-wrap,
  .cord-detail-wrap,
  .cord-page-wrap,
  .cord-bottom-cta,
  .cord-info-box,
  .cord-inline-image,
  .cord-footer-main { grid-template-columns: 1fr; display: block; }
  .cord-side-banners { margin-top: 30px; }
  .cord-footer-main { align-items: flex-start; }
  .cord-footer-actions {
    justify-content: flex-start;
    text-align: left;
    grid-template-columns: 1fr;
  }
  .cord-footer-sns,
  .cord-footer-links ul { justify-content: flex-start; text-align: left; }
  .cord-footer-contact a { min-width: 200px; font-size: 1em; }
  .cord-company strong { font-size: 1.3em; }
  .cord-company p { font-size: 0.9em; }
  .cord-cta-box { padding: 36px 16px; }
  .cord-cta-box h2 { font-size: 2em; }
  .cord-cta-box .btn a { min-width: 180px; font-size: 1.2em; }
  .cord-topics-slider-wrap .cord-topics-head,
  .cord-topics-slider-wrap .cord-topics-foot {
    padding: 0 15px;
  }
  .cord-topics-slider-wrap .cord-topics-slider .cord-card {
    margin: 0 8px;
  }
  .cord-company{
    margin-bottom: 20px;
  }
  .cord-footer-links ul {
    display: grid;
    justify-content: flex-end;
    gap: 14px;
    grid-template-columns: 1fr 1fr;
  }
}
