/* ======================
共通設定・リセット
====================== */
img {
  width: 100%;
}
h2,
h3,
h4,
ul,
li,
p,
div {
  margin: 0;
  padding: 0;
  background: none;
  list-style: none;
}
.body .article,
.article,
.article p,
.article dl,
.article ul,
.article ol,
.article ul li,
.article ol li,
.article dd,
.article h2,
.article h3,
.article h4,
.article h5,
.article h6 {
  margin: 0;
}
p {
  display: block;
  margin-block: 0;
  margin-inline: 0;
  unicode-bidi: isolate;
}
dd {
  display: block;
  margin-inline-start: 0;
  unicode-bidi: isolate;
}
.content {
  margin-top: 0 !important;
}
.main {
  position: relative;
  width: 860px;
  padding: 0 !important;
  border: 1px solid transparent;
  border-radius: var(--cocoon-basic-border-radius);
}
.entry-content {
  margin-top: 0 !important;
  margin-bottom: 3em;
}
.container .article-header {
  display: none;
}
div#custom_html-9 {
  margin: 0;
}
@media screen and (max-width: 834px) {
  .article ul,
  .article ol {
    padding-left: 0;
  }
}

/* ======================
フッター
====================== */
.footer {
  margin-top: 0;
  padding: 8px 0 30px;
}
.footer-bottom-logo img {
  width: auto;
  height: 60px;
}
.footer-center,
.footer-mobile {
  display: flex;
  justify-content: center;
}
.footer-center h3,
.footer-left,
.footer-right {
  display: none;
}
.footer-center .widget.widget_media_image,
.footer-mobile .widget.widget_media_image {
  margin: 0 5px;
}
.footer-mobile .widget.widget_media_image {
  width: 45%;
}
.copyright {
  font-size: 10px;
}
@media screen and (max-width: 834px) {
  .footer {
    padding-bottom: 100px;
  }
  .navi-footer-in > .menu-footer li.menu-item {
    display: flex;
    justify-content: center;
    flex: 0 0 auto;
    width: 40%;
    margin: 2px;
    border: 0;
    text-align: center;
  }
}
@media screen and (max-width: 400px) {
  .navi-footer-in > .menu-footer li.menu-item a {
    font-size: 12px;
  }
}

/* ======================
PC / SP 表示切替
====================== */
@media screen and (min-width: 769px) {
  .sp-display {
    display: none;
  }
  .pc-display {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .pc-display {
    display: none;
  }
  .sp-display {
    display: block;
  }
}

/* ======================
スライダー
====================== */
#slide_area {
  position: relative;
}
#slide_area .slide_txt01,
#slide_area .slide_txt02 {
  display: inline-block;
  margin-bottom: 5px;
  padding: 0 15px;
  color: #4f5865;
  font-size: 2.8em;
  font-weight: bold;
  line-height: 1.5em;
  text-shadow:
    2px 2px 2px #fff,
    -2px 2px 2px #fff,
    -2px -2px 2px #fff,
    2px -2px 2px #fff;
}
@media screen and (min-width: 900px) {
  #slider_pc {
    display: block;
  }
  #slider_sp {
    display: none;
  }
  #slide_area .slide_txtarea {
    position: absolute;
    top: 10%;
    left: -1%;
  }
}
@media screen and (max-width: 899px) {
  #slider_pc {
    display: block;
  }
  #slider_sp {
    display: none;
  }
  #slide_area .slide_txtarea {
    position: absolute;
    top: 10%;
    left: -1%;
  }
  #slide_area .slide_txt01,
  #slide_area .slide_txt02 {
    font-size: 2.2em;
  }
}
@media screen and (max-width: 768px) {
  #slider_pc {
    display: none;
  }
  #slider_sp {
    display: block;
  }
  #slide_area .slide_txtarea {
    position: absolute;
    top: 10%;
    left: -2%;
  }
  #slide_area .slide_txt01,
  #slide_area .slide_txt02 {
    margin-bottom: 5px;
    padding: 0 10px 0 20px;
    font-size: 2.4em;
    line-height: 1.5em;
  }
}
@media screen and (max-width: 650px) {
  #slide_area .slide_txtarea {
    top: 7%;
    left: -2%;
  }
}
@media screen and (max-width: 390px) {
  #slide_area .slide_txt01,
  #slide_area .slide_txt02 {
    padding: 0 10px 0 20px;
    font-size: 2em;
  }
}

/* ======================
フェードイン
====================== */
.fade-in-up {
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.6s ease-in-out;
}
.fade-in-up.is-show {
  opacity: 1;
  transform: translateY(0);
}

/* ======================
5つの理由
====================== */
#Reason5 {
  width: 100%;
  margin-top: 50px;
  text-align: center;
}
#Reason5 .r_inner {
  width: 100%;
  margin-top: -25px;
  padding: 50px 0 30px;
  background: #effdfd;
}
#Reason5 .fukidasi {
  position: relative;
  display: inline-block;
  min-width: 300px;
  max-width: 94%;
  margin: -50px auto 0;
  padding: 7px 10px;
  color: #fff;
  font-size: 1.2em;
  font-weight: bold;
  line-height: 1.2em;
  background: #0d9e88;
}
#Reason5 .fukidasi:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 10px solid #0d9e88;
}
#Reason5 h2 {
  font-size: 1.5em;
  font-weight: bold;
}
#Reason5 h2 .s_txt {
  font-size: 0.8em;
  font-weight: normal;
}
#Reason5 h2 .b_txt {
  color: #f13b66;
  font-size: 1.5em;
}
#Reason5 .r5_img {
  position: relative;
  width: 100%;
  margin: 1rem 0 0;
}
#Reason5 .r5_img img {
  width: 100%;
}
#Reason5 .r_point {
  position: relative;
  width: 100%;
  min-height: 150px;
}
#Reason5 .r5_box {
  position: absolute;
  top: -50px;
  right: 0;
  display: block;
  width: 90%;
  max-width: 600px;
  padding: 10px 20px;
  text-align: left;
  background: #fff;
  border-radius: 15px 0 0 15px;
}
#Reason5 .r5_box li {
  position: relative;
  margin: 7px 0;
  padding-left: 20px;
  font-weight: bold;
  line-height: 1.4em;
}
#Reason5 .r5_box li:before {
  content: "";
  position: absolute;
  top: 0.3em;
  left: 0;
  width: 5px;
  height: 10px;
  border-right: 3px solid #f13b66;
  border-bottom: 3px solid #f13b66;
  transform: rotate(50deg);
}
#Reason5 .r_txt {
  width: 92%;
  margin: 0 auto;
  text-align: left;
}
@media screen and (max-width: 400px) {
  #Reason5 .fukidasi {
    max-width: 98%;
  }
  #Reason5 .r5_box {
    width: 95%;
  }
}
@media screen and (min-width: 440px) {
  #Reason5 .r5_box {
    min-height: 160px;
  }
}
@media screen and (min-width: 550px) {
  #Reason5 .r_point {
    min-height: 160px;
  }
}
@media screen and (min-width: 769px) {
  #Reason5 .r5_img {
    max-height: 400px;
    overflow: hidden;
  }
}
@media (min-width: 1000px) {
  #Reason5 .r5_box_wrap {
    display: flex;
    width: 92%;
    margin: 2rem auto;
    background: #fff;
  }
  #Reason5 .r5_img {
    width: 45%;
    margin: 0;
  }
  #Reason5 .r_point {
    width: 55%;
  }
  #Reason5 .r5_box {
    position: relative;
    top: auto;
    right: auto;
    width: 100%;
    margin: 0;
    padding: 30px;
    font-size: 1.2em;
    border-radius: 0;
  }
  #Reason5 .r_txt {
    text-align: center;
  }
  #Reason5 .r5_box li {
    line-height: 1.8em;
  }
}

/* ======================
講師紹介
====================== */
.teach_box {
  width: 92%;
  margin: 2rem auto 0;
  background: #fff;
  border: 2px solid #0d9e88;
}
.teach_box_tit {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.teach_box_tit p {
  width: 50%;
  font-size: 1.5em;
  font-weight: bold;
}
.teach_box_tit img {
  width: 50%;
}
.teach_box ul {
  display: block;
  padding: 0;
}
.teach_box ul li {
  display: block;
  padding: 15px;
}
.teach_box ul li dl {
  display: flex;
  justify-content: space-between;
  padding-bottom: 15px;
  border-bottom: 1px solid #0d9e88;
}
.teach_box ul li:nth-child(1) dl {
  padding-top: 30px;
}
.teach_box ul li:nth-child(4) dl {
  border-bottom: none;
}
.teach_box ul li dt {
  line-height: 1.6;
  text-align: left;
}
.teach_box ul li dt .t_txt02 {
  font-size: 1.2em;
  font-weight: bold;
}
.teach_box ul li dt .t_txt03 {
  margin-bottom: 15px;
  font-size: 0.8em;
}
.teach_box ul li dt .t_txt04 {
  display: block;
  width: 100%;
  padding: 10px;
  font-size: 0.8em;
  background: #fdf6d6;
}
.teach_box ul li .t_box_txt {
  width: 53%;
}
.teach_box ul li .t_box_img {
  width: 44%;
}
.teach_box .sp-br {
  display: none;
}
@media screen and (min-width: 951px) {
  .teach_box {
    width: 80%;
  }
  .teach_box_tit p {
    width: 65%;
    margin-left: 5%;
    font-size: 2em;
    text-align: left;
  }
  .teach_box_tit img {
    width: 30%;
  }
  .teach_box ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  .teach_box ul li {
    width: 48%;
    padding: 10px;
  }
  .teach_box ul li:nth-child(1) dl {
    padding-top: 0;
  }
  .teach_box ul li:nth-child(3) dl,
  .teach_box ul li:nth-child(4) dl {
    border-bottom: none;
  }
}
@media screen and (min-width: 650px) and (max-width: 950px) {
  .teach_box {
    width: 92%;
  }
  .teach_box_tit p {
    width: 65%;
    margin-left: 5%;
    font-size: 2em;
    text-align: left;
  }
  .teach_box_tit img {
    width: 30%;
  }
  .teach_box ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  .teach_box ul li {
    width: 48%;
    padding: 10px;
  }
  .teach_box ul li .t_box_txt {
    width: 57%;
  }
  .teach_box ul li .t_box_img {
    width: 40%;
  }
  .teach_box ul li .t_box_txt .t_txt01 {
    font-size: 0.8em;
  }
  .teach_box ul li .t_box_txt .t_txt02 {
    font-size: 1em;
  }
  .teach_box ul li .t_box_txt .t_txt03 {
    margin-bottom: 0;
  }
  .teach_box ul li .t_box_txt .t_txt04 {
    padding: 5px;
  }
  .teach_box ul li:nth-child(1) dl {
    padding-top: 0;
  }
  .teach_box ul li:nth-child(3) dl,
  .teach_box ul li:nth-child(4) dl {
    border-bottom: none;
  }
}
@media (min-width: 500px) and (max-width: 649px) {
  .teach_box ul li .t_box_txt {
    width: 67%;
  }
  .teach_box ul li .t_box_img {
    width: 30%;
  }
}
@media screen and (max-width: 450px) {
  .teach_box .sp-br {
    display: block;
  }
}
/* ======================
サポート校
====================== */
#support_school {
  width: 100%;
  margin: 2rem 0;
}
#support_school h2.ss1 {
  font-size: 2em;
  font-weight: bold;
}
#support_school .s_inner {
  position: relative;
  width: 92%;
  margin: 0 auto 3rem;
}
#support_school .s_inner div {
  display: flex;
  justify-content: space-around;
  vertical-align: bottom;
}
#support_school .ss_img01 {
  width: 50%;
  margin-top: -15px;
}
#support_school .ss_txt01 {
  width: 65%;
  padding-top: 1rem;
}
#support_school .ss_txt02 {
  font-size: 2em;
  font-weight: bold;
  line-height: 1.4em;
  text-align: center;
}
#support_school .trg_wrap {
  position: relative;
  width: 200px;
  height: 50px;
  margin: 3rem auto 0;
  text-align: center;
}
#support_school .triangle_r {
  width: 0;
  height: 0;
  border-top: 50px solid #f13b66;
  border-right: 100px solid transparent;
  border-left: 100px solid transparent;
}
#support_school .trg_text {
  position: absolute;
  top: 5px;
  left: 0;
  width: 100%;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
}
#support_school h2.ss2 {
  width: 100%;
  margin-top: -1rem;
  margin-bottom: -0.2rem;
  padding: 2rem 0;
  font-size: 1.2em;
  font-weight: normal;
  text-align: center;
  background: #f2d54e;
}
#support_school h2.ss2 span {
  color: #f13b66;
  font-size: 1.5em;
  font-weight: bold;
}
#support_school .s2_inner {
  width: 100%;
  padding: 3rem 0;
  background: #fdf6d6;
}
#support_school .school_box01,
#support_school .school_box02 {
  position: relative;
}
#support_school .school_box01 {
  margin-bottom: 5rem;
}
#support_school .school_box01 .simg_box {
  width: 85%;
  max-width: 700px;
  margin: 0 0 0 auto;
  padding-bottom: 2rem;
}
#support_school .school_box02 .simg_box {
  width: 85%;
  max-width: 600px;
  margin: 0 auto 0 0;
  padding-bottom: 2rem;
}
#support_school .school_box01 h3 {
  position: absolute;
  top: 5%;
  left: 0;
  padding: 15px 15px 15px 30px;
  font-size: 1.5em;
  font-weight: bold;
  background: #f2d54e;
}
#support_school .school_box02 h3 {
  position: absolute;
  top: 5%;
  right: 0;
  padding: 15px 30px 15px 15px;
  color: #fff;
  font-size: 1.5em;
  font-weight: bold;
  background: #0d9e88;
}
#support_school .school_box01 .stxt_box {
  position: absolute;
  top: 65%;
  left: 0;
  display: block;
  width: 80%;
  padding: 15px 15px 15px 30px;
  background: #fff;
  border-radius: 0 10px 10px 0;
}
#support_school .school_box02 .stxt_box {
  position: absolute;
  top: 65%;
  right: 0;
  display: block;
  width: 80%;
  padding: 15px 30px 15px 15px;
  background: #fff;
  border-radius: 10px 0 0 10px;
}
#support_school .m_kakeru {
  width: 10%;
  margin: 0 auto 2rem;
}
#support_school .s3_tit {
  max-width: 750px;
  margin: -3rem auto 0;
  padding: 15px;
  color: #fff;
  font-size: 1.5em;
  font-weight: bold;
  text-align: center;
  background: #0d9e88;
}
#support_school .s3_inner {
  width: 100%;
  margin-top: 5rem;
  padding: 1rem 0 2rem;
  background: #fff;
}
#support_school .s3_box {
  position: relative;
  width: 92%;
  max-width: 750px;
  margin: 3rem auto 0;
  background: #fff;
  border: 2px solid #0d9e88;
}
#support_school .s3_box .s3_box_tit {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 5px;
}
#support_school .s3_box .s3_box_tit p {
  width: 65%;
  padding-top: 25px;
  padding-left: 15px;
  color: #0d9e88;
  font-size: 1.2em;
  font-weight: bold;
  line-height: 1.4em;
}
#support_school .s3_box .s3_box_tit p .sp_br {
  display: none;
}
#support_school .s3_box .s3_box_tit img {
  width: 30%;
}
#support_school .s3_box .accordionX_content p {
  padding: 10px;
}
#support_school .s3_box .step-icon {
  position: absolute;
  top: -35px;
  left: 0;
  width: 70px;
}
#support_school .s3_box .step-icon img {
  width: 100%;
}
#support_school .s3_box .step-icon .s_number {
  position: absolute;
  top: 25%;
  left: 26%;
  color: #fff;
  font-size: 1.5em;
  font-weight: bold;
}
#support_school .bb_txt {
  margin: 2rem auto;
  font-size: 1.5em;
  font-weight: bold;
  text-align: center;
}
#support_school .s4_tit {
  margin: 1rem auto 2rem;
  text-align: center;
}
#support_school .s4_tit .r_txt,
#support_school .s4_tit .rb_txt {
  color: #f13b66;
}
#support_school .s4_tit .rb_txt {
  font-size: 1.5em;
}
#support_school .s_merit {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 92%;
  margin: 0 auto;
}
#support_school .s_merit li {
  width: 48%;
  margin-bottom: 1rem;
  line-height: 1.4em;
  text-align: center;
}
#support_school .s_merit li img {
  margin-bottom: 0.5em;
}
@media screen and (max-width: 400px) {
  #support_school h2.ss1 {
    font-size: 1.5em;
  }
  #support_school .ss_txt01 {
    width: 70%;
    font-size: 0.9em;
  }
  #support_school .ss_txt02 {
    font-size: 1.5em;
  }
  #support_school .school_box01 h3 {
    padding: 10px 15px 10px 30px;
  }
  #support_school .school_box02 h3 {
    padding: 10px 30px 10px 15px;
  }
  #support_school .s3_tit {
    padding: 5px 15px;
  }
  #support_school .s_merit .s4_txt {
    font-size: 0.9em;
  }
}
@media screen and (max-width: 690px) {
  #support_school .s3_box .s3_box_tit p {
    font-size: 1.5em;
  }
  #support_school .s3_box .s3_box_tit p .sp_br {
    display: block;
  }
}
@media screen and (max-width: 460px) {
  #support_school .s3_box .s3_box_tit p {
    font-size: 1.2em;
  }
}
@media screen and (min-width: 769px) {
  #support_school {
    margin: 4rem 0;
  }
  #support_school .ss_txt01 {
    width: 65%;
    margin-top: 50px;
    padding-top: 0;
    font-size: 1.2em;
    line-height: 2em;
  }
  #support_school .ss_img01 {
    width: 30%;
    margin-top: -50px;
    margin-right: 0;
  }
  #support_school .school_box01 {
    margin-bottom: 0;
  }
  #support_school .school_box01 .simg_box,
  #support_school .school_box02 .simg_box {
    padding-bottom: 3rem;
  }
  #support_school .school_box01 .stxt_box {
    top: 65%;
    left: 10%;
    width: 40%;
    border-radius: 0;
  }
  #support_school .school_box02 .stxt_box {
    top: 65%;
    right: 10%;
    width: 40%;
    border-radius: 0;
  }
  #support_school .school_box01 .simg_box {
    width: 80%;
    margin: 0 4% 0 auto;
  }
  #support_school .school_box02 .simg_box {
    width: 80%;
    margin: 0 auto 0 4%;
  }
  #support_school .school_box01 h3 {
    top: 55%;
    left: 10%;
  }
  #support_school .school_box02 h3 {
    top: 55%;
    right: 10%;
  }
  #support_school .m_kakeru {
    width: 5%;
  }
  #support_school .s3_inner {
    width: 92%;
    margin: 2rem auto 0;
    padding-bottom: 3rem;
  }
  #support_school .s3_box .s3_box_tit p {
    width: 75%;
  }
  #support_school .s3_box .s3_box_tit img {
    width: 15%;
  }
  #support_school .s_merit li {
    width: 24%;
  }
}
/* =========================
状況に応じたサポート
========================= */
#s_message{
  text-align:center;
}
#s_message h2{
  display:inline-block;
  position:relative;
  font-size:1.4em;
  font-weight:700;
  color:#5f6974;
  line-height:1.2em;
  padding-bottom:.5rem;
  margin:0 auto 3rem;
  text-align:center;
}
#s_message h2::before{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:100%;
  height:2px;
  background:#5f6974;
}
#s_message h2::after{
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-7px;
  width:0;
  height:0;
  border-left:7px solid transparent;
  border-right:7px solid transparent;
  border-top:9px solid #5f6974;
}

/* =========================
卒業資格
========================= */
#graduates{
  margin-top:3rem;
}
#graduates h2{
  width:100%;
  padding:1rem 0;
  margin:3rem auto 1rem;
  background:#f0f1f3;
  text-align:center;
  font-weight:400;
}
#graduates h2 span{
  font-size:1.5em;
  font-weight:700;
}
#graduates .s_inner{
  width:92%;
  margin:0 auto;
}
#graduates .sst_txt{
  padding:0 0 1rem;
  text-align:left;
}
#graduates p.credit_img{
  width:100%;
  max-width:750px;
  margin:0 auto 1rem;
}
#graduates .trg_wrap{
  position:relative;
  width:100px;
  height:15px;
  text-align:center;
  margin:2rem auto;
}
#graduates .triangle_y{
  width:0;
  height:0;
  border-left:50px solid transparent;
  border-right:50px solid transparent;
  border-top:25px solid #f2d54d;
}
#graduates .sst2_txt{
  text-align:center;
  font-weight:700;
  margin:2rem auto 1rem;
}
#graduates .sst2_txt span{
  font-size:1.2em;
}
#graduates #credit_r{
  width:100%;
  max-width:750px;
  border:3px solid #f2d54e;
  margin:2rem auto 0;
  padding:1rem 0;
}
#graduates #credit_r h3{
  width:40%;
  margin:1rem auto 2rem;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
}
#graduates #credit_r h3 img{
  width:30px;
  height:auto;
  display:block;
}
#graduates #credit_r h3 p{
  font-size:1.2em;
  font-weight:700;
  color:#0d9e88;
  line-height:1;
}
#graduates #credit_r p.credit_txt{
  padding:0 15px;
  font-size:.8em;
}
#graduates .sst_box{
  position:relative;
  margin-bottom:3rem;
}
#graduates .sst_box .simg_box{
  width:85%;
  max-width:800px;
  margin:0 0 0 auto;
  padding-bottom:2rem;
}
#graduates .sst_box .stxt_box{
  display:block;
  width:65%;
  position:absolute;
  top:40%;
  left:0;
  padding:15px 15px 15px 30px;
  background:#fdf6d6;
  border-radius:0 10px 10px 0;
  line-height:1.4em;
}
#graduates .sst_box .stxt_box ol{
  font-size:1.5em;
  font-weight:700;
  list-style:none;
  padding-left:0;
  counter-reset:list-counter;
}
#graduates .sst_box .stxt_box ol li{
  counter-increment:list-counter;
  margin:10px 0;
  display:flex;
  align-items:center;
}
#graduates .sst_box .stxt_box ol li::before{
  content:counter(list-counter);
  display:inline-flex;
  justify-content:center;
  align-items:center;
  width:30px;
  height:30px;
  margin-right:10px;
  border-radius:50%;
  background-color:#0d9e88;
  color:#fff;
  font-weight:700;
}
#diploma .step-wrap{
  max-width:750px;
  width:100%;
  margin:0 auto .5rem;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
}
#diploma .step-label{
  width:15%;
  min-width:90px;
  aspect-ratio:1/1;
  background:url("https://shinshu-tsushinsupport.jp/wp-content/uploads/2026/05/diploma_step_bg.png") center/cover no-repeat;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  color:#fff;
  font-weight:700;
  line-height:1.8em;
  flex-shrink:0;
  padding-bottom:5%;
}
#diploma .step-label .step{
  font-size:clamp(1em,1.5vw,3rem);
  letter-spacing:.05em;
  margin-bottom:.2em;
}
#diploma .step-label .num{
  font-size:clamp(2rem,5vw,2.5rem);
}
#diploma .step-content{
  width:80%;
  background:#f0fafa;
  padding:1rem 15px;
  text-align:left;
}
#diploma .step-content h3{
  margin:0 0 .5rem;
  color:#0d9e88;
  font-size:clamp(1.2rem,2.5vw,1.8rem);
  font-weight:700;
}
#diploma .step-content p{
  margin:0;
  font-size:1rem;
  line-height:1.7;
  color:#333;
}

#credit_r .credit-wrap{
  width:92%;
  margin:0 auto;
  display:flex;
  gap:12px;
}
#credit_r .credit-box{
  flex:1;
  aspect-ratio:1/1;
  background:url("https://shinshu-tsushinsupport.jp/wp-content/uploads/2026/05/credit_list_bg.png") center/cover no-repeat;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:12px;
  min-width:0;
  margin-bottom:1rem;
}
#credit_r .lt_credit{
  margin:0;
  color:#0d9e88;
  line-height:1.5;
  font-size:clamp(1rem,2vw,3rem);
  font-weight:500;
  word-break:keep-all;
}
#credit_r .s_num{
  display:inline-block;
  font-size:2em;
  line-height:1.1;
  font-weight:700;
}

#graduates .credit02_img{
  background:url("https://shinshu-tsushinsupport.jp/wp-content/uploads/2026/05/diploma_img03_w.png") center/contain no-repeat;
  padding:3rem 0;
  width:92%;
  margin:1rem auto;
  max-width:750px;
}
#graduates .credit02_inner{
  width:80%;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
}
#graduates .credit02_inner img{
  width:82px;
  height:auto;
  display:block;
}
#graduates .credit02_inner p{
  font-size:3.5em;
  font-weight:700;
  color:#0d9e88;
  line-height:1;
}

/* =========================
信州中央学院の特徴
========================= */
#sinsyuchuou h2{
  width:100%;
  padding:1rem 0;
  margin:3rem auto 1rem;
  background:#f0fafa;
  color:#0d9e88;
  text-align:center;
  font-weight:400;
}
#sinsyuchuou h2 span{
  font-size:1.5em;
  font-weight:700;
}
#sinsyuchuou .g_txt{
  width:92%;
  margin:0 auto 2rem;
}
#sinsyuchuou .g_txt span{
  color:#0d9e88;
  font-weight:700;
}
#sinsyuchuou .viewbox-item{
  border-bottom:none;
}
#sinsyuchuou .viewbox-img{
  position:relative;
  margin-bottom:2rem;
}
#sinsyuchuou .viewbox-img p{
  position:absolute;
  bottom:-20%;
  left:0;
  font-size:2.4rem;
  font-weight:700;
  color:#0d9e88;
}
#sinsyuchuou .viewbox-img p span{
  font-size:3.5rem;
  font-weight:700;
}
#sinsyuchuou h3.viewbox-title_l{
  text-align:center;
  font-weight:700;
  margin:0 0 1rem;
}

/* =========================
section title
========================= */
#scool_info h2,
#faq h2{
  width:100%;
  padding:1rem 0;
  margin:3rem auto 1rem;
  background:#0d9e88;
  color:#fff;
  text-align:center;
}

/* =========================
faq
========================= */
#faq .faq{
  position:relative;
  max-height:300px;
  overflow:hidden;
  transition:max-height .6s ease;
  padding-bottom:1rem;
}
#faq .faq::after{
  content:"";
  position:absolute;
  bottom:0;
  left:0;
  width:100%;
  height:70px;
  background:#fff;
}
#faq .faq.open{
  max-height:3000px;
}
#faq .faq.open::after{
  display:none;
}
#faq .faq-item{
  display:block;
  margin-bottom:10px;
}
#faq .faq-item dt,
#faq .faq-item dd{
  display:block;
  margin:0;
}
#faq .faq-q{
  background:#f0fafa;
  cursor:pointer;
  font-weight:700;
}
#faq .faq-q .inner{
  display:flex;
  align-items:center;
  padding:15px;
}
#faq .faq-a{
  max-height:0;
  overflow:hidden;
  opacity:0;
  transition:max-height .6s cubic-bezier(.22,1,.36,1),opacity .4s ease;
}
#faq .faq-a .inner{
  display:flex;
  padding:15px;
}
#faq .faq-item.active .faq-a{
  max-height:500px;
  opacity:1;
}
#faq .f_label{
  width:60px;
  flex-shrink:0;
  font-weight:700;
}
#faq .faq-q .f_label{
  color:#0d9e88;
}
#faq .faq-a .f_label{
  color:#f52372;
}
#faq .f_text{
  flex:1;
}
#faq .f_toggle{
  margin-left:auto;
}
#faq .view-more{
  position:absolute;
  top:220px;
  left:35%;
  z-index:1;
  margin-top:20px;
  padding:10px;
  cursor:pointer;
  width:36%;
  border:1px solid #5f6974;
  color:#5f6974;
  background:#fff;
}

/* =========================
arrow animation
========================= */
.cp_arrows{
  margin-bottom:5rem;
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;
}
.cp_arrows .cp_arrow{
  position:absolute;
  width:20%;
  height:10px;
  opacity:0;
  transform:scale(.3);
  animation:arrow-move07 3s ease-out infinite;
}
.cp_arrows .cp_arrow:first-child{
  animation:arrow-move07 3s ease-out 1s infinite;
}
.cp_arrows .cp_arrow:nth-child(2){
  animation:arrow-move07 3s ease-out 2s infinite;
}
.cp_arrows .cp_arrow:before,
.cp_arrows .cp_arrow:after{
  position:absolute;
  content:'';
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:50%;
  height:100%;
  background:#0d9e88;
  border-radius:2px;
}
.cp_arrows .cp_arrow:before{
  left:1px;
  transform:skewY(30deg);
}
.cp_arrows .cp_arrow:after{
  right:1px;
  transform:skewY(-30deg);
}
@keyframes arrow-move07{
  25%{
    opacity:.6;
  }
  43%{
    transform:translateY(1em);
    opacity:.8;
  }
  62%{
    transform:translateY(2em);
    opacity:1;
  }
  100%{
    transform:translateY(3em) scale(.5);
    opacity:0;
  }
}

/* =========================
accordion
========================= */
.accordionX_content{
  max-height:0;
  overflow:hidden;
  transition:max-height .3s ease;
}
.accordionX_content.is-open{
  max-height:2000px;
}
.accordionX_toggleBtn{
  width:100%;
  padding:8px;
  border:none;
  background:#0d9e88;
  cursor:pointer;
  display:flex;
  justify-content:center;
  align-items:center;
}
.accordionX_toggleBtn:hover{
  background:#44b5ae;
}
.accordionX_arrow{
  width:10px;
  height:10px;
  border-right:2px solid #fff;
  border-bottom:2px solid #fff;
  transform:rotate(45deg);
  transition:transform .3s ease;
}
.accordionX_arrow.is-open{
  transform:rotate(-135deg);
}

/* =========================
viewbox
========================= */
.viewbox-container{
  display:flex;
  width:92%;
  margin:0 auto;
  flex-wrap:wrap;
  gap:20px;
}
.viewbox-item{
  width:calc(50% - 10px);
  box-sizing:border-box;
  display:flex;
  flex-direction:column;
  padding-bottom:2rem;
  border-bottom:1px dotted #5f6974;
}
.y_box{
  background:#fdf6d6;
  padding-bottom:1rem;
  border:none;
}
h3.viewbox-title{
  margin:0 0 .5rem;
}
.viewbox-text-full{
  display:none;
  padding-bottom:10px;
  text-align:left;
}
.y_box .viewbox-text-full{
  padding:0 10px 10px;
}
.viewbox-item.is-open .viewbox-text-full{
  display:block;
}
.viewbox-item.is-open .viewbox-text-short{
  display:none;
}
.viewbox-toggle{
  margin-top:auto;
  margin:0 auto;
  padding:10px;
  cursor:pointer;
  width:36%;
  border:1px solid #5f6974;
  color:#5f6974;
  background:#fff;
}

/* =========================
校舎一覧
========================= */
#scool_info .sc-slider_item{
  padding:1rem 0;
}
.sc-slider-container{
  position:relative;
  margin:0 auto 20px;
  overflow:hidden;
}
.sc-slider{
  overflow:hidden;
}
.sc-slider_track{
  display:flex;
  transition:transform .5s ease;
  background:#fdf6d6;
  width:100%;
}
.sc-slider_item{
  text-align:center;
  width:49.2%;
  background:#fdf6d6;
  margin:0 1%;
  padding:0 15px;
  flex:0 0 calc(50% - 10px);
}
.sc-slider_item h3{
  color:#0d9e88;
  font-size:1.5em;
}
.sc-slider_item .sc_img{
  width:92%;
  margin:1rem auto;
}
.sc-slider_item img{
  width:100%;
  object-fit:cover;
}
.sc-slider_item .sc-googlemap{
  width:92%;
  margin:2rem auto 0;
}
.sc-slider_item dl{
  display:flex;
  flex-wrap:wrap;
  width:92%;
  margin:0 auto;
  text-align:left;
}
.sc-slider_item dt{
  display:block;
  width:22%;
  border-bottom:1px dotted #5f6974;
  padding:5px 0 5px 4%;
}
.sc-slider_item dd{
  display:block;
  width:74%;
  border-bottom:1px dotted #5f6974;
  padding:5px 0;
}
.sc-slider_btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background-color:rgba(13,158,136,.5);
  color:#fff;
  border:none;
  padding:10px;
  cursor:pointer;
  font-size:24px;
  z-index:10;
}
.sc-slider_btn-prev{
  left:5px;
}
.sc-slider_btn-next{
  right:5px;
}
.my_slider_item dd{
  margin:0;
}

/* =========================
ブログ
========================= */
#s_blog{
  padding:0 0 2rem;
}
#s_blog h2{
  width:100%;
  padding:1rem 0;
  margin:2rem auto 1rem;
  background:#0d9e88;
  color:#fff;
  text-align:center;
}
#s_blog .s_blog_inner{
  width:92%;
  margin:0 auto;
}
#s_blog{
  padding:0 0 2rem;
}
#s_info h2{
  width:100%;
  padding:1rem 0;
  margin:2rem auto 1rem;
  background:#0d9e88;
  color:#fff;
  text-align:center;
}
#s_info .s_blog_inner{
  width:92%;
  margin:0 auto;
}

.listing-item{
display:flex;
flex-direction:row-reverse;
justify-content:flex-end;
gap:12px;
}

.listing-item .date{
min-width:90px;
color:#777;
}

.listing-item a{
flex:1;
}

/* =========================
responsive
========================= */
@media screen and (min-width:769px){

  #graduates .sst_txt{
    text-align:center;
  }

  #graduates .sst_box{
    margin-bottom:0;
  }

  #graduates .sst_box .simg_box{
    padding-bottom:3rem;
  }

  #graduates .sst_box .stxt_box{
    width:40%;
    top:20%;
  }

  #sinsyuchuou .viewbox-img p{
    bottom:-25%;
    font-size:2.5rem;
  }

  #sinsyuchuou .viewbox-img p span{
    font-size:4rem;
  }

  #faq .faq{
    width:92%;
    margin:0 auto;
  }

  #faq .faq::after{
    height:100px;
  }

  .cp_arrows .cp_arrow{
    width:10%;
    height:15px;
  }

  .sc-slider-container{
    width:94%;
    margin:0 auto;
  }

  .sc-slider_track{
    justify-content:space-between;
    background:#fff;
  }

  .sc-slider_btn-prev,
  .sc-slider_btn-next{
    display:none;
  }
}

@media screen and (min-width:1000px){

  #graduates .sst_box .simg_box{
    width:60%;
    max-width:800px;
    margin:0 15% 0 auto;
  }

  #graduates .sst_box .stxt_box{
    top:50%;
    left:10%;
    width:35%;
    padding:30px;
    border-radius:0;
    line-height:1.4em;
  }
}

@media (min-width:700px){

  #diploma .step-label{
    padding-top:2%;
    min-height:130px;
  }

  #diploma .step-content{
    min-height:100px;
  }
}

@media (min-width:550px){

  #diploma .step-content{
    width:84%;
  }
}

@media screen and (max-width:769px){

  #graduates .credit02_inner img{
    width:60px;
    height:auto;
    display:block;
  }

  #graduates .credit02_inner p{
    font-size:3rem;
  }
}

@media screen and (max-width:500px){

  #graduates .credit02_img{
    padding:1rem 0;
    width:100%;
  }

  #graduates .credit02_inner img{
    width:45px;
    height:auto;
    display:block;
    background:cover;
    padding:1em 0 .8em;
  }

  #graduates .credit02_inner p{
    font-size:2rem;
  }
}

@media screen and (max-width:420px){

  #graduates .sst_box{
    margin-bottom:5rem;
  }

  #graduates .sst_box .stxt_box{
    width:70%;
  }

  #graduates .sst_box .stxt_box ol{
    font-size:1.2em;
  }
}

@media (max-width:600px){

  #credit_r .credit-wrap{
    gap:8px;
  }

  #credit_r .lt_credit{
    font-size:1rem;
    line-height:1.2em;
  }

  #credit_r .s_num{
    font-size:2em;
  }
}

@media (max-width:480px){

  #diploma .step-label{
    min-width:75px;
  }

  #diploma .step-content h2{
    line-height:1.5;
  }

  #diploma .step-content p{
    font-size:.92rem;
  }
}

@media (max-width:400px){

  #graduates #credit_r h3{
    margin:.5rem auto 1rem;
  }

  #credit_r .credit-box{
    padding:5px;
  }

  .sc-slider_item dt{
    width:25%;
  }
}

@media (max-width:768px){

  .viewbox-item{
    width:100%;
  }

  .sc-slider_btn-prev,
  .sc-slider_btn-next{
    display:block;
  }

  .sc-slider_item{
    flex:0 0 100%;
  }
}

/* =========================
blog
========================= */
.container .blogcategory-info .article-header {
    display: block;
}

.pager-post-navi {
    display: none;
}


/* =================================
   カスタム投稿ページをトップ風デザインへ
================================= */

/* 本文エリア背景 */
.single-shinshu-chuo .main,
.single-nagano .main,
.single-suwa .main {
    background:#fff;
}


/* メインコンテンツ余白 */
.single-shinshu-chuo .content,
.single-nagano .content,
.single-suwa .content {
    padding-top:40px;
}


/* 記事カード */
.single-shinshu-chuo .entry-content,
.single-nagano .entry-content,
.single-suwa .entry-content {
    background:#fff;
    border-radius:16px;
    margin-bottom:50px;
}

.blogcategory-info{
	padding:45px 50px;
	margin-bottom:50px;
}

/* タイトル */
.single-shinshu-chuo .entry-title,
.single-nagano .entry-title,
.single-suwa .entry-title {

    font-size:1.5em;
    line-height:1.5;
    font-weight:700;
    color:#0d9e88;
    margin-bottom:25px;
	border-bottom:2px solid  #f2d54e;

}


/* 投稿日 */
.single-shinshu-chuo .post-date,
.single-nagano .post-date,
.single-suwa .post-date {

    color:#888;
font-size:1.0em;
}


/* 本文文字 */
.single-shinshu-chuo .entry-content p,
.single-nagano .entry-content p,
.single-suwa .entry-content p {

    font-size:16px;

    line-height:2;

    color:#444;

}


/* 見出し */
.single-shinshu-chuo .entry-content h2,
.single-nagano .entry-content h2,
.single-suwa .entry-content h2 {
	margin-top:50px;
	padding-left:18px;
  border-left:5px solid #2ba638;
 color:#333;

}


/* 画像 */
.single-shinshu-chuo .entry-content img,
.single-nagano .entry-content img,
.single-suwa .entry-content img {
border-radius:12px;
}


/* 関連記事・下部余白調整 */
.single-shinshu-chuo .related,
.single-nagano .related,
.single-suwa .related {
    display:none;
}


/* サイドバーとの間 */
.single-shinshu-chuo .main,
.single-nagano .main,
.single-suwa .main {

    padding-left:20px;
    padding-right:20px;

}


/* スマホ */
@media(max-width:767px){

.single-shinshu-chuo .entry-content,
.single-nagano .entry-content,
.single-suwa .entry-content {
    padding:25px 20px;
}


.single-shinshu-chuo .entry-title,
.single-nagano .entry-title,
.single-suwa .entry-title {
    font-size:22px;
}
}
.entry-card-thumb {
    display:none;
}
.entry-card-content {
    margin-left: 0px;
}
#s_info h2{
  width:100%;
  padding:1rem 0;
  margin:2rem auto 1rem;
  background:#0d9e88;
  color:#fff;
  text-align:center;
}
#s_info .s_blog_inner{
  width:92%;
  margin:0 auto;
}
#s_info .bloglist_btn a{
	display:block;
	text-align:center;
    margin: 20px auto 0;
    padding: 10px;
    cursor: pointer;
    width: 36%;
    border: 1px solid #5f6974;
    color: #5f6974;
    background: #fff;
}
.listing-item{
display:flex;
flex-direction:row-reverse;
justify-content:flex-end;
gap:12px;
}

.listing-item .date{
min-width:90px;
color:#777;
}

.listing-item a{
flex:1;
}
