@charset "UTF-8";
* {
  box-sizing: border-box;
}

#top-hiro {
  margin: 80px 0 0 0 !important;
}

.front-main {
  line-height: 1.2;
}
.front-main * {
  box-sizing: border-box;
}

.hero-section {
  width: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: 50%;
  position: relative;
}
.hero-section .hiro-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.hero-section .hiro-logo img {
  width: auto;
  height: 50%;
  filter: drop-shadow(2px 2px 3px rgba(0, 0, 0, 0.7));
}

.front-base-head {
  font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-size: 2rem;
  text-align: center !important;
  margin: 0 !important;
  padding: 1em;
}
.front-base-head span {
  display: block;
  font-size: .9rem;
  font-weight: 400;
  margin: 8px 0 0 0;
}

.new-post-container {
  width: 100%;
  background-color: #fffaf0;
  clip-path: polygon(0 5%, 100% 0, 100% 95%, 0 100%);
  background-image: url("../../images/elements/icons/logomark-wh.svg");
  background-repeat: no-repeat;
  background-size: 480px auto;
  background-position: bottom -240px right -30%;
}
.new-post-container .new-post-wrap {
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.new-post-container .new-post-wrap .new-post-list {
  line-height: 1.2;
}
.new-post-container .new-post-wrap .new-post-list .category-title {
  font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 400;
  margin-bottom: 1em;
  text-align: center;
}
.new-post-container .new-post-wrap .new-post-list .post-item {
  display: block;
  border-bottom: 1px solid #aaa;
  padding: 1em 0;
}
.new-post-container .new-post-wrap .new-post-list .post-item:first-child {
  border-top: 1px solid #aaa;
}
.new-post-container .new-post-wrap .new-post-list .post-item .post-meta {
  display: block;
  margin: 0 0 0.8em 0;
}
.new-post-container .new-post-wrap .new-post-list .post-item .post-title {
  font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 400 !important;
  color: #0052cc;
  margin: 0;
  padding: 0;
}
.new-post-container .new-post-wrap .new-post-list .post-item .post-title a {
  color: inherit;
  text-decoration: none;
}
.new-post-container .new-post-wrap .new-post-list .post-item .post-excerpt {
  font-size: 0.9rem;
  color: #333;
  text-align: left;
  margin: 0;
  padding: 0;
}
.new-post-container .new-post-wrap .new-post-list .post-item .sticky-mark,
.new-post-container .new-post-wrap .new-post-list .post-item .new-mark,
.new-post-container .new-post-wrap .new-post-list .post-item .post-cat {
  display: inline-block;
  padding: 3px 4px;
  font-size: 0.7rem;
  line-height: 1;
  color: #fff;
  border-radius: 5px;
}
.new-post-container .new-post-wrap .new-post-list .post-item .sticky-mark {
  background-color: #32cd32;
}
.new-post-container .new-post-wrap .new-post-list .post-item .new-mark {
  background-color: #b22222;
}
.new-post-container .new-post-wrap .new-post-list .post-item .post-cat {
  border: 1px solid #888;
  border-radius: 5px;
  color: #333;
}

.front-newpost {
  padding: 2em 0;
  background-color: #fffaf0;
  clip-path: polygon(0 5%, 100% 0, 100% 95%, 0 100%);
  padding: 80px 0;
  background-image: url("../../images/elements/icons/logomark-wh.svg");
  background-repeat: no-repeat;
  background-size: 480px auto;
  background-position: bottom -240px right -30%;
}
.front-newpost .newpost {
  margin: 0 auto 2em auto;
}
.front-newpost .newpost ul {
  margin: 0 !important;
  padding: 0 !important;
  list-style-type: none;
}
.front-newpost .newpost ul li {
  display: block;
  border-bottom: 1px solid #aaa;
  padding: 1em;
}
.front-newpost .newpost ul li:first-child {
  border-top: 1px solid #aaa;
}
.front-newpost .newpost ul li:hover {
  background-color: #fff;
}
.front-newpost .newpost ul li .post-meta {
  display: block;
  font-size: .8rem;
  margin: 0 0 .8em 0;
}
.front-newpost .newpost ul li h3, .front-newpost .newpost ul li p {
  margin: 0;
  padding: 0;
}
.front-newpost .newpost ul li .np-h3 {
  font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1.1rem;
  font-weight: 400 !important;
  color: #0052cc;
}
.front-newpost .newpost ul li .np-note {
  font-size: .9rem;
  color: #333;
  text-align: left;
}
.front-newpost .newpost ul li .sticky-mark,
.front-newpost .newpost ul li .new-mark,
.front-newpost .newpost ul li .post-cat {
  display: inline-block;
  padding: 3px 4px;
  font-size: .7rem;
  line-height: 1;
  color: #fff;
  border-radius: 5px;
}
.front-newpost .newpost ul li .sticky-mark {
  background-color: #32cd32;
}
.front-newpost .newpost ul li .new-mark {
  background-color: #b22222;
}
.front-newpost .newpost ul li .post-cat {
  border: 1px solid #888;
  border-radius: 5px;
  color: #333;
}
.front-newpost .newpost .page-change {
  text-align: center;
  margin: 0 0 2em 0 !important;
}
.front-newpost .newpost .page-change a {
  font-size: .9rem;
  display: inline-block;
  padding: .5em 1em;
  border: 2px solid #888;
  background-color: #fff;
  border-radius: 8px;
  color: #333;
  transition: transform 0.3s ease-in-out, border-color 0.3s ease, background-color 0.3s ease, color 0.3s ease-in-out;
}
.front-newpost .newpost .page-change a:hover {
  border: 2px solid #0052cc;
  background-color: #0052cc;
  color: #fff;
}

.etc-link {
  margin: 2em auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.etc-link .etc-link-item {
  width: 31%;
}
.etc-link .etc-link-item img {
  border-radius: 10px;
}

.bnr-link-wrap {
  margin: 2em auto 5em auto;
}
.bnr-link-wrap .bnr-link-inner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.bnr-link-wrap .bnr-link-inner .link-relation {
  width: 28%;
  padding: 1em;
}
.bnr-link-wrap .bnr-link-inner .link-relation ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
}
.bnr-link-wrap .bnr-link-inner .link-relation a {
  padding: 0 0 0 24px;
  background-image: url("../../images/elements/icons/ico-link.svg");
  background-repeat: no-repeat;
  background-size: 18px auto;
  background-position: top 50% left 0;
}
.bnr-link-wrap .bnr-link-inner .bnr-link {
  width: 65%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.bnr-link-wrap .bnr-link-inner .bnr-link .bnr-link-item {
  width: 30%;
}
.bnr-link-wrap .bnr-link-inner .bnr-link .bnr-link-item img {
  width: 100%;
  height: auto;
}

@media (max-width: 767px) {
  .front-base-head {
    font-size: 1.5rem;
    padding: 1em;
  }
  .front-base-head span {
    font-size: .8rem;
    margin: 8px 0 0 0;
  }

  .mobile-nav {
    width: 100%;
    padding: 0 20px;
    margin: 80px 0 20px 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .mobile-nav .mn-item {
    width: calc(100% / 3);
    font-size: .7rem;
  }
  .mobile-nav .mn-item a {
    display: block;
    background-color: #eee8aa;
    color: #333;
    text-align: center;
    border: 2px solid #f0f0f0;
    font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 700;
    background-size: 32px auto;
    background-position: top 20px left 50%;
    background-repeat: no-repeat;
    padding: 64px 0 16px 0;
  }
  .mobile-nav .mn1 a {
    background-image: url("../../images/elements/icons/invoice.png");
  }
  .mobile-nav .mn2 a {
    background-image: url("../../images/elements/icons/download.png");
  }
  .mobile-nav .mn3 a {
    background-image: url("../../images/elements/icons/seminar.png");
  }
  .mobile-nav .mn4 a {
    background-image: url("../../images/elements/icons/support.png");
  }
  .mobile-nav .mn5 a {
    background-image: url("../../images/elements/icons/newsletter.png");
  }
  .mobile-nav .mn6 a {
    background-image: url("../../images/elements/icons/contact.png");
  }

  .front-main {
    max-width: 100%;
    margin: 20px auto 0 auto;
    padding: 0 20px;
  }

  .new-post-container {
    padding: 3em 0 !important;
    clip-path: polygon(0 5%, 100% 0, 100% 95%, 0 100%);
    background-size: 480px auto;
    background-position: bottom -240px right -30%;
  }
  .new-post-container .new-post-wrap {
    max-width: 100%;
    padding: 0 20px;
  }
  .new-post-container .new-post-wrap .new-post-list {
    width: 100%;
  }
  .new-post-container .new-post-wrap .new-post-list .category-title {
    font-size: 1.2rem;
    margin-bottom: 1em;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item {
    padding: 1em !important;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-meta {
    font-size: 0.8rem;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-title {
    font-size: 1rem;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-title a:hover {
    text-decoration: underline;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-excerpt {
    font-size: 0.8rem;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .sticky-mark,
  .new-post-container .new-post-wrap .new-post-list .post-item .new-mark,
  .new-post-container .new-post-wrap .new-post-list .post-item .post-cat {
    padding: 3px 4px;
    font-size: 0.7rem;
  }

  .etc-link {
    width: 100%;
    margin: 1em auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .etc-link .etc-link-item {
    width: 100%;
    margin: 0 0 1em 0;
  }
  .etc-link .etc-link-item:last-child {
    margin: 0;
  }
  .etc-link .etc-link-item a img {
    border-radius: 10px;
  }

  .bnr-link-wrap {
    width: 90%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 2em auto 5em auto;
  }
  .bnr-link-wrap .bnr-link-inner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation {
    width: 100%;
    padding: 1em 0;
    margin: 0 0 2em 0;
    border-top: 1px dashed #aaa;
    border-bottom: 1px dashed #aaa;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul {
    display: flex;
    flex-wrap: wrap;
    gap: 1em 0;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li {
    width: 100%;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li::after {
    content: "";
    width: 30%;
    height: 0;
    display: block;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li a {
    font-size: .9rem;
    padding: 0 0 0 24px;
    background-size: 18px auto;
    background-position: top 50% left 0;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link {
    width: 100%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link .bnr-link-item {
    width: 48%;
    margin: 0 0 1em 0;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link .bnr-link-item img {
    width: 100%;
    height: auto;
  }
}
@media (min-width: 768px) and (max-width: 1025px) {
  .front-base-head {
    font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-size: 1.6rem;
    text-align: center !important;
    margin: 0 !important;
    padding: 1em;
  }
  .front-base-head span {
    display: block;
    font-size: .9rem;
    font-weight: 400;
    margin: 8px 0 0 0;
  }

  .front-main {
    max-width: 100%;
    margin: 0 auto;
  }

  .new-post-container {
    padding: 5em 0 !important;
    clip-path: polygon(0 5%, 100% 0, 100% 95%, 0 100%);
    background-size: 480px auto;
    background-position: bottom -240px right -30%;
  }
  .new-post-container .new-post-wrap {
    max-width: 100%;
    padding: 0 20px;
  }
  .new-post-container .new-post-wrap .new-post-list {
    width: 48%;
  }
  .new-post-container .new-post-wrap .new-post-list .category-title {
    font-size: 1.2rem;
    margin-bottom: 1em;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item {
    padding: 1em;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-meta {
    font-size: 0.8rem;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-title {
    font-size: 1rem !important;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-title a:hover {
    text-decoration: underline;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-excerpt {
    font-size: 0.8rem;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .sticky-mark,
  .new-post-container .new-post-wrap .new-post-list .post-item .new-mark,
  .new-post-container .new-post-wrap .new-post-list .post-item .post-cat {
    padding: 3px 4px;
    font-size: 0.7rem;
  }

  .etc-link {
    width: 94%;
    margin: 1em auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .etc-link .etc-link-item {
    width: 31%;
  }
  .etc-link .etc-link-item a img {
    border-radius: 10px;
  }

  .bnr-link-wrap {
    width: 90%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 2em auto 5em auto;
  }
  .bnr-link-wrap .bnr-link-inner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation {
    width: 100%;
    padding: 1em 0;
    margin: 0 0 2em 0;
    border-top: 1px dashed #aaa;
    border-bottom: 1px dashed #aaa;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul {
    display: flex;
    flex-wrap: wrap;
    gap: 1em 5%;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li {
    width: 30%;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li::after {
    content: "";
    width: 30%;
    height: 0;
    display: block;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li a {
    font-size: .9rem;
    padding: 0 0 0 24px;
    background-size: 18px auto;
    background-position: top 50% left 0;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link {
    width: 100%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link .bnr-link-item {
    width: 32%;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link .bnr-link-item img {
    width: 100%;
    height: auto;
  }

  .hero-section {
    width: 100%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    position: relative;
  }
}
@media (min-width: 768px) and (max-width: 1025px) and (orientation: portrait) {
  .hero-section {
    height: 50vh;
    min-height: 300px;
    background-image: url("../../images/pages/front/top-hiro-tb.jpg");
    background-size: cover;
    background-position: center;
    clip-path: ellipse(100% 95% at 50% 0%);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .hero-section .hiro-logo {
    position: static;
    transform: none;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .hero-section .hiro-logo img {
    max-width: 50%;
    max-height: 50%;
    width: auto;
    height: auto;
  }
}
@media (min-width: 768px) and (max-width: 1025px) and (orientation: landscape) {
  .hero-section {
    height: 68vh;
    min-height: 300px;
    background-image: url("../../images/pages/front/top-hiro-tb.jpg");
    background-size: cover;
    background-position: center;
    clip-path: ellipse(100% 95% at 50% 0%);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .hero-section .hiro-logo {
    position: static;
    transform: none;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .hero-section .hiro-logo img {
    max-width: 60%;
    max-height: 60%;
    width: auto;
    height: auto;
  }
}
@media (min-width: 1026px) {
  .hero-section {
    background-image: url("../../images/pages/front/top-hiro.jpg");
    height: 70vh;
    clip-path: ellipse(100% 95% at 50% 0%);
  }
  .hero-section .hiro-logo img {
    height: calc(30vw * 0.5625);
    max-height: 300px;
  }

  .front-main {
    width: 100%;
    margin: 0 auto;
  }

  .etc-link {
    width: 1200px;
    margin: 2em auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .etc-link .etc-link-item {
    width: 31%;
  }
  .etc-link .etc-link-item a img {
    border-radius: 10px;
  }

  .new-post-container {
    padding: 8em 0 !important;
    clip-path: polygon(0 5%, 100% 0, 100% 95%, 0 100%);
    background-size: 480px auto;
    background-position: bottom -240px right -30%;
  }
  .new-post-container .new-post-wrap {
    max-width: 1240px;
    padding: 0 20px;
  }
  .new-post-container .new-post-wrap .new-post-list {
    width: 48%;
  }
  .new-post-container .new-post-wrap .new-post-list .category-title {
    font-size: 1.5rem;
    margin-bottom: 1em;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item {
    padding: 1em 0;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-meta {
    font-size: 0.8rem;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-title {
    font-size: 1.1rem;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-title a:hover {
    text-decoration: underline;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .post-excerpt {
    font-size: 0.9rem;
  }
  .new-post-container .new-post-wrap .new-post-list .post-item .sticky-mark,
  .new-post-container .new-post-wrap .new-post-list .post-item .new-mark,
  .new-post-container .new-post-wrap .new-post-list .post-item .post-cat {
    padding: 3px 4px;
    font-size: 0.7rem;
  }

  .newpost {
    max-width: 800px;
    margin: 0 auto;
  }

  .bnr-link-wrap {
    width: 1200px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 2em auto 5em auto;
  }
  .bnr-link-wrap h2 {
    width: 100%;
    text-align: center;
  }
  .bnr-link-wrap .bnr-link-inner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation {
    width: 100%;
    padding: 1em 0;
    margin: 0 0 2em 0;
    border-top: 1px dashed #aaa;
    border-bottom: 1px dashed #aaa;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul {
    display: flex;
    flex-wrap: wrap;
    gap: 1em 5%;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li {
    width: 30%;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li::after {
    content: "";
    width: 30%;
    height: 0;
    display: block;
  }
  .bnr-link-wrap .bnr-link-inner .link-relation ul li a {
    font-size: .9rem;
    padding: 0 0 0 24px;
    background-size: 18px auto;
    background-position: top 50% left 0;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link .bnr-link-item {
    width: 24%;
  }
  .bnr-link-wrap .bnr-link-inner .bnr-link .bnr-link-item img {
    width: 100%;
    height: auto;
  }
}
@media (min-width: 2401px) {
  .front-main {
    max-width: 100%;
    margin: 0 auto;
  }

  .hero-section {
    clip-path: ellipse(100% 99.5% at 50% 0%);
    height: 80vh;
    clip-path: ellipse(100% 95% at 50% 0%);
  }

  .etc-link {
    width: 1200px;
    margin: 2em auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .etc-link .etc-link-item {
    width: 31%;
  }
  .etc-link .etc-link-item a img {
    border-radius: 10px;
  }
}
