@charset "UTF-8";
/* 

共通

*/
html { scroll-padding-top: 80px; }

body{
        font-family: "Noto Sans JP", sans-serif !important;
}

.section-title{
    color: #1B2954;
}

section h2{
    text-align: center;
    font-weight: 700;
    line-height: 3.6rem;
}

section h3{
    color: #1B2954;
    font-size: 1.5rem;
    font-weight: 700;
}

.section-guide{
    text-align: center;
}

.section-guide p{
    display: inline-block;
    text-align: left;
}

.txt-accent{
    color: #14A0DC;
}

.marker {
  background: linear-gradient(transparent 70%, #FFEA00 70%);
}

.school-label{
    border: 2px solid #1B2954;
    color: #1B2954;
    font-weight: bold;
    text-align: center;
    padding: 2px 0;
}

.high-school-fill{
    background-color: #F7DFDB !important;
}

.junior-high-fill{
    background-color: #D8E5FB !important;
}

.patent {
    background: #FFEA00;
    padding: 5px 35px;
    font-weight: bold;
    display: inline-block;
}

.flow-arrow {
    position: relative;
    width: 15px;
    height: 30px;
    background: #284b66;
    border-radius: unset !important;
}

.flow-arrow::after {
    content: "";
    position: absolute;
    right: -14px;
    bottom: -22px;
    border-top: 36px solid transparent;
    border-bottom: 36px solid transparent;
    border-left: 17px solid #284b66;
}

footer{
    text-align: center;
    margin: 10px auto;
}

/* TOP戻るボタン */

#page-top {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: #29a7e1;
    display: flex;
    align-items: center !important;
    justify-content: center !important;
  position: fixed;
  right: 20px;
  bottom: 20px;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
}

#page-top  img {
    transform: rotate(270deg);
}

#page-top.fadein {
  opacity: 1;
  visibility: visible;
}

/* サブタイトル */
.section-subtitle{
    text-align: center;
    margin: 30px auto;
}

/* お問い合わせ・資料 ボタン*/
.contact-btn {
    display: inline-block;
    background-color: #14A0DC;
    padding: 11px 26px 11px 22px;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
}

.contact-btn a {
    color: #ffffff;
    background-image: url(images/menu-icon-contact.svg);
    background-repeat: no-repeat;
    padding: 10px 27px 10px 51px;
    background-size: 23px;
    background-position-y: center;
    display: block;
    background-position-x: 18px;
    text-decoration: none;
}

/* システム名 */
.service-name{
    font-weight: bold;
    display: flex;
    align-items: center;
}

.service-name .logo{
    width: 35px;
    margin-right: .25rem;
}

/* 

ヘッダー

*/

.header {
    width: 100%;
     background: rgba(255, 255, 255, 0.8);
    position: sticky;
    top: 0;
    z-index: 1000;
}

.header-inner {
    max-width: 1400px;
    margin: 0 auto;
    height: 95px;
    display: flex;
    align-items: center;
    justify-content: space-between; /* 両端に配置 */
    padding: 0 20px;
}

.logo-box {
        display: flex;
    justify-content: center;
    align-items: center;
    padding: 5px 20px;
    font-weight: bold;
    color: #000;
    background: #F0F8FF;
    border-radius: 2rem;
}
.logo-box  img{
    width: 50px;
    margin-right: 10px;
}

.header-logo .service-name{
    color: #000;
    margin-top: 5px;
}

.header-logo a { text-decoration: none; }

.header-nav {
    flex: 1;
}
.nav-list {
    display: flex;
    list-style: none;
    gap: 20px;
    margin-bottom: 0;
}
.nav-list a {
    text-decoration: none;
    color: #000000;
    font-weight: bold;
}
.nav-list a:hover { color: #15a1d9; }

.header-right { display: flex; align-items: center; gap: 20px; }

.header .contact-btn{
    padding: 5px;
}

.cta-tel {
     text-align: right; 
    }

    .cta-tel img{
          width: 32px;
    margin-right: 6px;
    }

.tel-number {
     color: #15a1d9; 
    font-size: 1.7rem;
      font-weight: bold; 
    }
.tel-time { 
   font-size: 0.8rem;
 }

.nav-toggle, .hamburger, .mobile-cta-area, .nav-overlay { display: none; }

@media (max-width: 1200px) {

  .top-bg {
    background-size: cover !important;
    background-position: right !important;
  }

    .pc-only { display: none !important; }

    .header-logo { margin-right: auto; } 

 
/* ハンバーガーメニュー */
    .hamburger {
        display: block;
        width: 30px; height: 22px;
        position: relative;
        z-index: 1100;
        cursor: pointer;
    }
    .hamburger span {
        display: block; width: 100%; height: 3px;
        background: #333; position: absolute; transition: .4s;
    }
    .hamburger span:nth-child(1) { top: 0; }
    .hamburger span:nth-child(2) { top: 9px; }
    .hamburger span:nth-child(3) { top: 18px; }

    .header-nav {
        position: fixed; top: 0; right: -100%; /* 初期は隠す */
        width: 315px; 
        height: 100vh;
        background: #fff; 
        padding: 80px 25px;
        flex-direction: column; 
        transition: .4s;
        z-index: 1050;
         box-shadow: -5px 0 15px rgba(0,0,0,0.1);
        margin: 0;
    }
    .nav-list { flex-direction: column; gap: 0; }
    .nav-list li { border-bottom: 1px solid #f0f0f0; }
    .nav-list a { display: block; padding: 15px 0; font-size: 16px; }

    .mobile-cta-area {
        display: flex; flex-direction: column;
        margin-top: 30px; gap: 20px;
    }
    .mobile-cta-area .cta-button { justify-content: center; width: 100%; }
    .mobile-cta-area .cta-tel { text-align: center; }

    .nav-toggle:checked ~ .header-nav { right: 0; }
    .nav-toggle:checked ~ .hamburger span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
    .nav-toggle:checked ~ .hamburger span:nth-child(2) { opacity: 0; }
    .nav-toggle:checked ~ .hamburger span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }
    .nav-toggle:checked ~ .nav-overlay {
        display: block; position: fixed; top: 0; left: 0;
        width: 100%; height: 100vh; background: rgba(0,0,0,0.4); z-index: 1040;
    }
}

/* 

ファーストビュー 

*/

.top-bg {
  background-image: url("images/top_back.jpg");
      background-size: 100% 100%, 130% auto;
  background-position: center;
  background-repeat: no-repeat;
}

 #hero .hero-inner{
    padding-top: 70px;
    padding-bottom: 40px;
    display: flex;
     justify-content: space-between;
     gap: 50px;
}

 #hero .hero-copy{
    font-weight: 800;
        text-shadow: 2px 2px 0 #fff, -2px 2px 0 #fff, -2px -2px 0 #fff, 2px -2px 0 #fff;
}

 #hero  .hero-label{
    text-shadow: 2px 2px 0 #fff, -2px 2px 0 #fff, -2px -2px 0 #fff, 2px -2px 0 #fff;
 }

#hero .hero-image{
    max-width: 500px;
}

#hero .hero-image .main-img{
    position: relative;
    background: #ffff;
    padding: 5px;
    border: 7px solid #EEF2FB;
    border-radius: 1rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    width: 100%;
}

 #hero .hero-image {
  position: relative;
  display: inline-block;
}

:root {
  --ribbon-shape: polygon(0% 0%, 100% 0%, 100% 100%, 50% 88%, 0% 100%);
}

 #hero .ribbon {
    position: absolute;
    top: 180px;
    right: -30px;
    width: 150px;
    height: 185px;
  filter: drop-shadow(0 4px 5px rgba(0,0,0,0.2));
}

 #hero .ribbon-base,
 #hero .ribbon-border,
 #hero .ribbon-inner {
  position: absolute;
  inset: 0;
  clip-path: var(--ribbon-shape);
}

 #hero .ribbon-base {
  background: linear-gradient(to bottom, #FFCE33, #FFEA00);
}

 #hero .ribbon-border {
  inset: 8px;
  background: #fff;
}

 #hero .ribbon-inner {
  inset: 12px;
  background: linear-gradient(to bottom, #FFCE33, #FFEA00);
  display: flex;
  align-items: center;
  justify-content: center;
}

 #hero .ribbon-content {
  text-align: center;
}

 #hero .icon-circle {
  width: 55px;
  height: 55px;
  background: #fff;
  border-radius: 50%;
  margin: 0 auto 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

 #hero .icon-circle img {
  width: 60%;
}

 #hero .sub-text {
  margin: 0;
  font-weight: bold;
}

 #hero .main-text {
  font-weight: 900;
  font-size: 1.2rem;
}


/* 

ファイル送受信機能とは

*/

#about{
        text-shadow: 2px 2px 0 #fff, -2px 2px 0 #fff, -2px -2px 0 #fff, 2px -2px 0 #fff;
}

#about .about-title h2{
    padding-top: unset;
    text-align: center;
    font-weight: 700;
}

#about .about-link  ul{
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin-top:25px;
}

#about .about-link  li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 8px;
}

/* 丸アイコン */
#about .about-link  ul li::before {
content: "?";
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid #1B2954;
    border-radius: 50%;
    font-size: 1.3rem;
    font-weight: 500;
    color: #1B2954;
    flex-shrink: 0;
    background: #F0F8FF;
    text-shadow: none;
}

#about .about-link a{
    color: unset;
}

/*  

ファイル送受信機能は
現場の声から生まれた機能です。 

*/

#overview{
    padding-top: 50px;
}

#overview h2{
    text-align: center;
    font-weight: 700;
    padding-top: 35px;
}

#overview .section-guide p{
    margin: 20px auto;
}

#overview .problem{
    background: #F0F8FF;
}

#overview  .problem-list{
    display: flex;
    justify-content: space-evenly;
     padding-top: 30px;
}

#overview  .problem-content{
    background-color: #ffff;
    display: flex;
    align-items: center;
    padding-top: 15px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

#overview  .problem-content img{
    width: 90px;
    margin: auto 20px;
}

#overview  .problem-item .junior-high-voice{
    padding-left: 40px;
}

#overview .problem-item .high-school-voice{
    padding-right: 40px;
}

#overview .problem-item .school-label{
    border-radius: 1rem;
    width: 100px;
    margin: 0 auto 15px;
}

/* 

高等学校と中学校間の
入試書類のやりとりを安全に効率化！

*/

#overview .solution .overview-title{
    background: #f0f8ff;
    background-image: linear-gradient(to bottom left, transparent 50%, #ffffff 50%), linear-gradient(to bottom right, transparent 50%, #ffffff 50%);
    background-repeat: no-repeat;
    background-size: 50% 100%;
    background-position: left, right;
}

#overview .solution{
    color: #1B2954;
}

/* =================================
   ベース
================================= */
.flow-image {
  position: relative;
  width: 1100px;
    margin: 0 auto 125px;
    z-index: 0;
}

.flow-image::after {
    content: "";
    position: absolute;
    bottom: -40px;
    left: 0;
    width: 100%;
    height: 520px;
    background: #F9F6F4;
    box-shadow: 0 0 0 100vmax #F9F6F4;
    clip-path: inset(0 -100vmax);
    z-index: -1;
}


.flow-image img {
  display: block;
  max-width: 100%;
}

.flow-image .flow-illust {
  width: 90%;
  margin: 50px auto 100px;
}

/* 非表示 */
.flow-image .flow-illust-tb,
.flow-image .flow-illust-sp {
  display: none;
}


/* =================================
   テキスト共通
================================= */
.flow-txt {
  position: absolute;
  inset: 0;
}

.flow-txt .name li {
  position: absolute;
  top: 6px;
  list-style: none;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 2px;
}

/* 名前位置 */
.flow-txt .name li:nth-child(1) { left: 160px; }
.flow-txt .name li:nth-child(2) { left: 433px; }
.flow-txt .name li:nth-child(3) { left: 886px; }


/* =================================
   filesend 共通
================================= */
.filesend-item h4,
.filesend-item ul,
.filesend-item p,
.filesend-item img {
  position: absolute;
}

.filesend-item h4 {
  font-size: 1rem;
}

.filesend-item ul {
  font-size: 0.9rem;
  line-height: 30px;
}

.filesend-item p {
  line-height: 30px;
}


/* =================================
   conclusion 共通
================================= */
.conclusion-content {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.conclusion-content p {
  margin-top: 10px;
  font-size: 1.2rem;
  font-weight: bold;
}


/* =================================
   高校
================================= */
.flow-high-school .filesend-item {
  left: 70px;
}

/* filesend */
.flow-high-school .filesend-content:nth-child(1) h4 { top: 82px;  left: 125px; }
.flow-high-school .filesend-content:nth-child(2) h4 { top: 220px; left: 125px; }

.flow-high-school .filesend-content:nth-child(1) ul { top: 112px; left: 65px; }
.flow-high-school .filesend-content:nth-child(2) ul { top: 247px; left: 65px; }

.flow-high-school .filesend-content:nth-child(1) p { top: 175px; left: 260px; }
.flow-high-school .filesend-content:nth-child(2) p { top: 306px; left: 260px; }

.flow-high-school .filesend-item img {
  top: 170px;
  left: 323px;
}

/* conclusion */
.flow-high-school .conclusion-content {
  top: 455px;
  left: 145px;
}

.flow-high-school .conclusion-item .conclusion-icon {
  top: 527px;
}


/* =================================
   システム
================================= */
.flow-system .attention-content {
  position: absolute;
  top: 330px;
  left: 490px;
  font-size: 1.2rem;
  font-weight: bold;
  color: #fff;
}

.flow-system .conclusion-content {
  left: 491px;
  text-align: center;
  font-size: 1.2rem;
}

.flow-system .conclusion-content:nth-child(1) { top: 108px; }
.flow-system .conclusion-content:nth-child(3) { top: 430px; }

.flow-system   .repletion-item p{
    position: absolute;
    top: 650px;
    left: 400px;
    color: #000;
}

/* =================================
   中学校
================================= */
/* conclusion */
.flow-junior-high-school .conclusion-content {
  top: 156px;
  right: 143px;
}

.flow-junior-high-school .conclusion-item .conclusion-icon {
  top: 245px;
  right: 0;
}

/* filesend */
.flow-junior-high-school .filesend-content h4 {
  top: 431px;
  right: 125px;
}

.flow-junior-high-school .filesend-content ul {
  top: 458px;
  right: 175px;
}

.flow-junior-high-school .filesend-content p {
  top: 576px;
  right: 75px;
}

.flow-junior-high-school .filesend-item img {
  top: 485px;
  right: 323px;
}


/* アイコン */
.flow-file-icon {
  width: 50px;
}

.conclusion-icon {
  position: absolute;
  width: 130px;
}

@media screen and (max-width: 1200px) {
   .flow-image .flow-illust,.flow-txt{
        display: none;
    }
    .flow-image{
        width: auto;
    }

 .flow-image .flow-illust-tb {
        display: block;
              margin: 40px auto 60px;
     }

     .flow-illust-tb{
        margin: 20px auto;
        padding: 0 20px;
        width: 100%;
    }

    .supplement{
        width: 80%;
        margin: 0 auto;
    }
}

@media (max-width: 768px) {
        .flow-image-tb {
            display: none;
        }
}

.supplement .container{
        background: #fff;
    font-size: 1.2rem;
        display: flex;
    justify-content: space-evenly;
            padding: 15px 40px;
}

.supplement span{
    font-weight: bold;
}

.supplement ul{
    line-height: 2.5;
    margin-bottom: 0;
    list-style: none;
}

.supplement ul li{
    position: relative;
}

.supplement ul li::before {
    content: "";
    position: absolute;
    top: 50%;
    width: 24px;
    height: 13px;
    border-left: 5px solid #4FA3D1;
    border-bottom: 5px solid #4FA3D1;
    transform: translateX(-180%) translateY(-60%) rotate(-45deg);
}

/* 

紙と手間の運用から、全てをデジタル完結へ

*/

#features{
    margin-top: 50px;
}

#features .features-item {
  background: #F9F6F4;
margin-top: 50px;
  padding: 50px;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

#features .features-inner {
display: flex;
    align-items: center;
    justify-content: space-evenly;
    gap: 40px;
}

#features .features-txt {
  max-width: 500px;
}

#features .number {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
    color: #1a2b49;
}

#features .num {
    font-size: 2rem;
  font-weight: bold;
}

#features .features-txt h3 {
  margin-bottom: 16px;
      line-height: 2.5rem;
}

#features .features-txt p {
  line-height: 1.8;
}

#features .features-image img {
  width: 100%;
  max-width: 500px;
    border: 7px solid #EEF2FB;
    border-radius: 1rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* 

鉄壁のセキュリティ

*/

#security{
    margin-top: 100px;
    padding-top: 35px;
    padding-bottom: 100px;
    background-color: #F0F8FF;
}

#security .security-item{
    background: #ffffff;
    margin-top: 50px;
    padding: 50px 30px;
    border-radius: 10px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

#security .security-inner{
    display: flex;
    align-items: center;
    justify-content: space-evenly;
    gap: 30px;
}

#security .security-txt {
    max-width: 380px;
}

#security .security-txt h3 {
    margin-bottom: 16px;
        line-height: 2.5rem;
        font-size: 1.3rem;
}

/*図 */
/* =================================================
   trusted-system / rec_patent_Illust_01
================================================= */
.rec_patent_Illust_01 {
  flex: 3;
  font-size: 0.8rem;
  font-weight: bold;
  color: #1f3b57;
  margin-top: 15px;
}

.rec_patent_Illust_01 .card img{
  width: 45px;
   height: auto;
   object-fit: contain;
}

.rec_patent_Illust_01 .illust-group{
  display: flex;
      gap: 20px;
    margin: 15px 0 35px 35px;
}

.rec_patent_Illust_01 .card-group .wrapper{
    display: flex;
    align-items: center;
    position: relative;
}

.rec_patent_Illust_01 .card-group .wrapper::before{
position: absolute;
    content: "";
    background-image: url(images/rec_patent_Illust_01_parts_03.png);
    background-size: 100px;
    background-repeat: no-repeat;
    width: 105px;
    height: 95px;
    z-index: 1;
        bottom: -35px;
    left: -45px;
}

.rec_patent_Illust_01 .card-group .wrapper::after {
    position: absolute;
    content: "\4E2D\5B66\6821";
bottom: -35px;
    left: -30px;
    width: 75px;
    padding: 0 10px;
    text-align: center;
    border: 2px solid #284b66;
    background: #d8e5fb;
    border-radius: .5rem;
    margin: 0;
    z-index: 2;
}

.rec_patent_Illust_01 .card-group .card{
    border-radius: 1rem !important;
  overflow: hidden;
}

.rec_patent_Illust_01 .card-group .title{
  text-align: center;
  margin-bottom: 5px;
  font-size: 1rem;
}

.rec_patent_Illust_01 .card-group:first-child .title{
  margin-right: 20px;
}

.rec_patent_Illust_01 .card-group {
  display: block;
}

.rec_patent_Illust_01 .card-group .card .card-title{
  text-align: center;
  padding: 10px;
  min-height: 60px;
  margin: 0;
   display: grid;
  place-items: center;
}

.rec_patent_Illust_01 .card-group .card-blue{
  background: #d8e5fb;
    border: 3px solid #284b66;
}
.rec_patent_Illust_01 .card-group .card-blue .card-title{
      background: #284b66;
    color: #fff;
}

.rec_patent_Illust_01 .card-group .card-pink {
  background: #ffefed;
  border: 3px solid #fbb6ab;
}
.rec_patent_Illust_01 .card-group .card-pink .card-title{
    background: #fbb6ab;
    color: #284b66;
}

.rec_patent_Illust_01 .card-group .card .card-flow{
  display: flex;
  gap: 45px;
  padding: 10px 25px;
  align-items: center;
}


.rec_patent_Illust_01 .card-group .card .card-flow::before {
    content: "";
    position: absolute;
    left: 95px;
    top: 50%;
    transform: translate(-50%, 100%);
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 20px solid #284b66;
}

.rec_patent_Illust_01 .card-group .card-blue .card-flow::before{
     left: 53%;
}

.rec_patent_Illust_01 .card-group .card-blue .card-flow .note{
  text-align: center;
  margin-bottom: 5px;
  font-size: 1rem;
  color: #1f3b57;
}

.rec_patent_Illust_01 .card-group .card-pink .card-flow .note{
    background: #fbb6ab;
    border-radius: 1rem;
        padding: 5px 10px;
    text-align: center;
}

.rec_patent_Illust_01 .card-group .card-pink .card-flow .rec{
  display: flex;
    margin: 5px auto;
        align-items: center;
}
.rec_patent_Illust_01 .card-group .card-pink .card-flow .rec img{
  width: 35px;
  margin-right: 5px;
}


/* =================================================
   trusted-system / rec_patent_Illust_02
================================================= */
.rec_patent_Illust_02 {
   flex: 3;
  font-size: 0.8rem;
  font-weight: bold;
  color: #1f3b57;
  margin-top: 15px;
}

.rec_patent_Illust_02 .security-flow_02 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
}

.rec_patent_Illust_02 .flow-col {
  display: flex;
  flex-direction: column;
  gap: 0px;
}

.rec_patent_Illust_02 .flow-card {
  display: flex;
  align-items: center;
  gap: 30px;
}

.rec_patent_Illust_02 .card-group {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-flow: unset;
}

.rec_patent_Illust_02 .flow-card .left {
  flex-direction: column;
  gap: 0;
}

.rec_patent_Illust_02 .flow-card .left .img {
  display: block;
  background-color: #ffefed;
  padding: 15px;
  border-radius: 1rem;
}

.rec_patent_Illust_02 .flow-card .left .img p {
  background: #284b66;
  color: #fff;
  text-align: center;
  padding: 5px;
  margin: 15px 0;
  border-radius: 1rem;
}

.rec_patent_Illust_02 .card-group .school {
display: flex;
    flex-direction: column;
    align-items: center;
}


.rec_patent_Illust_02 .school {
  display: block;
  margin-bottom: 15px;
}

.rec_patent_Illust_02 .school img {
  width: 60px;
  height: auto;
}

.rec_patent_Illust_02 .img img {
  width: 75px;
  height: auto;
  margin-bottom: 15px;
}

.rec_patent_Illust_02 .flow-center {
  text-align: center;
  display: block;
}

.rec_patent_Illust_02 .flow-center > p:first-child {
  margin-bottom: 10px;
  padding-right: 20px;
      font-size: 1rem;
}

.rec_patent_Illust_02 .flow-deta {
  display: block;
  background: #d8e5fb;
  border-radius: 28px;
  padding: 25px 12px;
  border: 3px solid #284b66;
}

.rec_patent_Illust_02 .deta-group {
      display: flex;
    align-items: center;
  gap: 0;
  margin-bottom: 15px;
}

.rec_patent_Illust_02 .deta-group .school {
  display: flex;
  background: #fff;
  border-radius: 1rem;
  padding: 10px 25px;
  gap: 15px;
}

.rec_patent_Illust_02 .deta-group .school p {
  margin-bottom: 0;
}

.rec_patent_Illust_02 .card-group .school .school-label {
  width: 75px;
  padding: 0 10px;
  text-align: center;
  border: 2px solid #284b66;
  border-radius: .5rem;
  margin: 0;
}

.rec_patent_Illust_02 .card-group .school .school-color-a {
  background-color: #c1e4ea;
}

.rec_patent_Illust_02 .card-group .school .school-color-b {
  background-color: #d8e5fb;
}

.rec_patent_Illust_02 .card-group .school .school-color-c {
  background-color: #f7dfdb;
}

.rec_patent_Illust_02 .deta-group div {
  display: block;
  text-align: center;
  margin: 0;
}

.rec_patent_Illust_02 .deta-group img {
  width: 50px;
}

.rec_patent_Illust_02 .deta-group p {
  margin-top: 6px;
}

.rec_patent_Illust_02 .flow-deta .red-comment {
  display: inline-block;
  padding: 6px 16px;
  background: #e60012;
  color: #fff;
  border-radius: 20px;
  margin: 0;
}

.rec_patent_Illust_02 .flow-center > p:last-child {
  padding-right: 20px;
  margin-top: 12px;
}


/* 

学校に選ばれ、利用が広がり続けています

*/

#achievements{
    margin-top: 50px;
    padding-top: 50px;
    padding-bottom: 100px;
    background: #F5F5F5;
}

#achievements .achievements-item{
    padding: 40px 70px;
    background: #ffff;
    max-width: 1000px;
    margin: 0 auto;
}

#achievements .achievements-item h3{
     position: relative;
  padding-left: 40px;
    text-align: center;
    margin-bottom: 25px;
}

#achievements .achievements-item h3::before{
    content: "";
    position: absolute;
    top: 50%;
    width: 24px;
    height: 13px;
    border-left: 5px solid #4FA3D1;
    border-bottom: 5px solid #4FA3D1;
    transform: translateX(-180%) translateY(-60%) rotate(-45deg);
}

 #achievements .stats-group {
    padding: 0 70px 20px;
    background: #fff;
    box-shadow: -1px 2px 12px rgb(27 41 84 / 19%);
    border-radius: 1rem;
    margin: 50px auto;
    max-width: 1000px;
}

#achievements .stats-group h3 {
    background: #1b2954;
    color: #ffff !important;
    border-radius: 0 0 15px 15px;
    padding: 8px 50px;
    margin: 0 auto;
    width: fit-content;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
    font-size: 1rem !important;
}

#achievements .stats-group span {
    display: block;
    margin-top: 4px;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
    font-size: 1.1rem !important;
}

#achievements .stat {
    display: flex;
    align-items: center;
    padding: 25px 100px 0;
    margin: 0 auto;
}

 #achievements .stat + .stat {
    border-top: 1px dotted #ddd;
}

#achievements .tag {
    min-width: 72px;
    text-align: center;
    padding: 5px 0;
    background: #f2ece8;
    font-weight: 700;
    color: #25325b;
}

#achievements  dd {
    display: flex;
    margin: 0;
    flex-wrap: wrap;
    width: 100%;
}

#achievements  dd p {
    margin-left: 50px;
}

#achievements  b {
    margin-right: 10px;
    font-size: 3rem;
    color: #2da0df;
    line-height: 1;
    font-weight: 900;
}

/* 

安心して運用できるサポート体制

*/

#support{
    margin-top: 80px;
}

#support ul {
    margin: 50px auto 20px;
    padding: 0;
    display: flex;
    width: 85%;
    flex-wrap: nowrap;
    gap:40px;
}

#support ul li {
    background: #F0F8FF;
    border-radius: 15px;
    position: relative;
    list-style: none;
    width: calc(100% / 3);
    margin: 0 8px;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: 500;
    font-style: normal;
    padding: 30px;
    text-align: center;
}

#support img {
    display: block;
    margin: 0 auto;
}

#support .support-no {
    width: 46px;
    height: 46px;
    background: #29A7E1;
    color: #ffffff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}


/* 

個人情報の保護に最大限のセキュリティを確保しています

*/

#attestation{
    margin-top: 100px;
}

#attestation .container{
    background: #F0F8FF;
    border-radius: 15px;
    margin-top: 35px;
    padding: 35px 70px;
}

#attestation .attestation-block h3{
    text-align: center;
    background: #ffff;
    border-radius: 2rem;
    padding: 10px;
    margin-bottom: 30px;
}

#attestation .logo-image{
    background: #fff;
    padding: 5px;
    display: flex
}

#attestation .logo-image img{
    height: 100px;
    margin: 0px 5px;
    padding: 8px;
}

#attestation .attestation-content{
    display: flex;
    align-items: center;
     justify-content: center;
}

#attestation .attestation-list{
    list-style: none;
    font-weight: bold;
    line-height: 2;
}

#attestation .attestation-link{
    display: flex;
    justify-content: flex-end;
    gap: 30px;
    list-style: none;
    margin: 20px 0 0;
}

#attestation .attestation-link li{
    position: relative;
    background: #fff;
    border: 2px solid #1b2954;
}

#attestation .attestation-link li::after {
    position: absolute;
    content: "";
    top: 50%;
    right: 20px;
    width: 10px;
    height: 10px;
    border-top: 2px solid #1b2954;
    border-right: 2px solid #1b2954;
    transform: rotate(45deg) translateY(-20%) translateX(-50%);
}

#attestation .attestation-link li a{
    display: block;
    color: #1b2954;
    text-decoration: none;
    padding: 10px 55px 10px 10px;
}

/* 

調査書・入試書類の電子化なら
調査書Web登録システムにお任せください。

*/

#contact{
    margin-top: 100px;
    padding:50px;
    background-color: #1B2954;
    color: #fff;
}

#contact h2{
    color: #fff;
}

#contact .contact-btn {
    margin: 30px auto 0;
    display: table;
    border: 2px solid #fff;
}

#contact .contact-btn a{
        font-size: 1.3em;
}

#contact .container p{
    text-align: center;
    margin-top: 10px;
}

#contact .txt-accent{
    color: #EB6101;
}


/* レスポンシブ対応*/

@media screen and (max-width: 1200px) {
.section-title,#overview h2{
  margin: 0 25px;
}

#hero .hero-inner{
      flex-direction: column;
    align-items: center;
}

.contact-btn{
      display: table;
      margin: 0 auto;
}

#security .security-inner{
      flex-direction: column;
}

#security .security-item:nth-child(even)  .security-inner {
  flex-direction: column-reverse;
}

#security .security-txt{
  max-width: 600px;
}

#security .security-txt h3{
  text-align: center;
}

#security .patent{
  display: table;
  margin: 0 auto;
}

#support ul {
        width: inherit;
}

}

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

#features .features-inner{
      flex-direction: column;
}

#features .features-item:nth-child(odd)  .features-inner {
  flex-direction: column-reverse;
}

#achievements .stat{
      flex-direction: column;
      gap: 25px;
          padding: 25px 0;
}

#attestation .attestation-content{
      flex-direction: column;
      gap: 20px;
}

#attestation .attestation-link{
      gap: 10px;
      flex-direction: column;
}

#achievements .achievements-item h3{
  text-align: left;
}

#support ul{
  width: initial;
    flex-direction: column;
}

#support ul li{
  width: 100%;
}

  .flow-image::after{
    height: 435px;
  }

  #overview .problem-list {
    flex-direction: column;
    gap: 40px
}

#overview .problem-content{
        justify-content: center;
        max-width: 400px;
        margin: 0 auto;
}

}

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

  .flow-image .flow-illust-tb{
  display: none;
}

.flow-image .flow-illust-sp{
  display: block;
}

.flow-image::after{
      height: 280px;
}

    .supplement {
      width: 100%;
        margin: 0 auto;
        background: #f9f6f4;
        padding: 35px 0;
    }
    .flow-image::after{
      position: unset;
    }


  /* 図 */
      .flow-arrow {
        transform: rotate(90deg);
    }
  .rec_patent_Illust_01 .illust-group{
        gap: 20px;
        margin: 0 auto;
        flex-direction: column;
        align-items: center;
  }
  .rec_patent_Illust_01 .card-group .wrapper{
    flex-direction: column;
  }
  .rec_patent_Illust_01 .card-group .wrapper::before,
  .rec_patent_Illust_01 .card-group .wrapper::after{
        bottom: 5px;
  }

.rec_patent_Illust_02 .security-flow_02{
      flex-direction: column;
      gap: 10px;
}

.rec_patent_Illust_02 .flow-card{
      gap: 0;
    flex-direction: column;
}

.rec_patent_Illust_02 .flow-col{
  flex-direction: row;
      gap: 20px;
}

.rec_patent_Illust_02 .deta-group{
      flex-direction: column;
}

.rec_patent_Illust_02 .flow-card .left{
  flex-direction: row;
  gap: 20px;
}
.rec_patent_Illust_02 .flow-center {
        display: flex;
        flex-direction: column;
    }

 .rec_patent_Illust_02 .flow-center > p:last-child {
        order: -1;
        padding-right: 0;
    }

    .rec_patent_Illust_02 .flow-card .left .img{
          display: flex;
    align-items: center;
    gap: 20px;
    }

       .rec_patent_Illust_02 .flow-card .left .img p {
        padding: 10px;
        border-radius: 2rem;
    }

.rec_patent_Illust_02 .flow-deta{
      display: flex !important;
    align-items: center;
    gap: 20px;
    }

    .rec_patent_Illust_02 .flow-center > p:first-child{
      padding-right: 0;
    }

}

@media screen and (max-width: 599px) {
  
.container{
         max-width: 90%;
}

#hero .ribbon{
  position: unset;
      float: right;
    margin: 10px;
}

#about{
  padding-top: 0 !important;
}

#about .about-link ul{
      flex-direction: column;
         align-items: flex-start;
    gap: 20px;
}

.supplement ul {
    line-height: 2;
    display: flex;
    flex-direction: column;
    gap: 25px;
}


#overview .problem-item .junior-high-voice br{
  display: none;
}
#overview h2 span{
  display: inline-block;
}


#features .number{
      justify-content: center;
          flex-direction: column;
}

#features .features-item{
      padding: 30px;
}

#security .security-txt h3 br{
  display: none;
}

/* 図 */
.rec_patent_Illust_02 .card-group,
.rec_patent_Illust_02 .flow-deta{
      flex-direction: column;
}

#attestation .logo-image{
      flex-direction: column;
    align-items: center;
}

#attestation .container{
  padding: 35px 25px;
}

#attestation .attestation-list,
#attestation .attestation-link{
  padding-left: 0;
}

#achievements .stats-group {
    padding: 0 30px 20px;
}

#achievements .achievements-item {
    padding: 40px;
}

#contact{
      padding: 50px 20px;
}

footer{
      padding: 0 20px;
}

}