@charset "UTF-8";
<link href="https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap" rel="stylesheet">

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

.bold {
  font-weight: 700;
}

.sp-br {
  display: none;
}

@media screen and (max-width: 768px) {
  .sp-br {
    display: inline;
  }
}

.marker {
  background: linear-gradient(transparent 60%, #fff7a8 60%);
  padding: 0 4px;
  font-weight: 500;
  color: #183f9a;
}

.cta-btn {
  margin-top: 3rem;
  text-align: center;
}

.cta-btn a {
  display: inline-block;
}

.cta-btn a img {
  width: 480px;
  height: auto;
  display: block;
}

.cta-btn a:hover img {
  content: url("/area/img/takasaki/ct_btn_on.png");
}


@media screen and (max-width: 768px) {
  .cta-btn{
    margin-top: 1rem;
    padding: 0 16px;
  }

  .cta-btn a{
    width: 100%;
    max-width: 360px;
    height: 80px;
    background-size: contain;
  }
}

.inner {
  max-width: 1100px;
  margin: 0 auto;
}

.top-bnr{
  display:block;
  margin:0 auto;
  width:100%;
  height:auto;
}

.top-bnr + .top-bnr{
  margin-top:20px;
}

.top-bnr--small{
  max-width:700px;
}

@media screen and (max-width:767px){
  .top-bnr + .top-bnr{
    margin-top:12px;
  }

  .top-bnr--small{
    max-width:100%;
  }
}

section.secStyle {
  margin: 4rem 0;
}

@media screen and (max-width: 768px) {
section.secStyle {
  margin: 2rem 0;
}
}

section .h2-style {
  font-size: 34px;
  text-align: center;
  position: relative;
  padding-bottom: 1rem;
　font-family: "Noto Sans JP", "Noto Sans", sans-serif !important;
  color:#2B4597;
  font-weight: 500;
  letter-spacing: 1px;
  line-height:1.5em;
}

section .h2-style::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 120px;
  height: 2px;
  background: #1f3c88;
  transform: translateX(-50%);
}

section .h2-style span {
  font-size: 0.7em;
  padding-left:2px;
  padding-right:2px;
  display:inline-block;
}

@media screen and (max-width: 768px) {
  section .h2-style{
    font-size: 22px;
    padding-bottom: 0.8rem;
    letter-spacing: 0.5px;
  }
  section .h2-style::after{
    width: 80px;
    height: 2px;
  }
  section .h2-style span{
    font-size: 0.75em;
  }
}

.appeal-block {
  margin-top: 4rem;
  border: 3px solid #29479b;
}

.appeal-block h2 {
  background: #29479b;
  color: #fff;
  text-align: center;
  padding: 20px 10px;
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: 1px;
}

.appeal-list {
  list-style: none;
  margin: 0;
  padding: 40px 50px;
}

.appeal-list li {
  display: flex;
  align-items: center;
  gap: 8px;
}

.appeal-list p {
  position: relative;
  top: -2px;
}

.appeal-list li:not(:last-child) {
  margin-bottom: 32px;
}

.appeal-list .check {
  width: 32px;
  height: auto;
  flex-shrink: 0;
}

.appeal-list p {
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.6;
  color: #333;
}

.appeal-list .marker {
  background: linear-gradient(transparent 60%, #fff7a8 60%);
  padding: 0 4px;
　color: #1f3a93;
}

@media screen and (max-width:767px){
  .appeal-block {
    margin-top: 2.5rem;
    border-width: 2px;
	  margin-left:auto;
	  margin-right:auto;
  }

  .appeal-block h2 {
    font-size: 1.4rem;
    padding: 14px 8px;
  }

  .appeal-list {
    padding: 20px 16px;
  }

  .appeal-list li {
    align-items: flex-start;
    gap: 6px;
	align-items: top;
  }

  .appeal-list p {
    font-size: 1.05rem;
    line-height: 1.7;
    top: 0;
  }

  .appeal-list .check {
    width: 22px;
	margin-top: 5px;
  }

  .appeal-list li:not(:last-child) {
    margin-bottom: 18px;
  }
}

section.message {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 40px 0;
  margin-top: 40px;
  background: #F2FBFF;
}

section.message .inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
  overflow: visible;
}

@media screen and (max-width: 768px){
  section.message{
    width: 100%;
    margin-left: 0;
    margin-right: 0;
	  padding: 32px 0px;
    margin-top: 32px;
  }

  section.message .inner{
    padding: 0 4px;
  }
}

.message h2 span {
  font-size: 0.75em;
  font-weight: inherit;
}

.message-box {
  display: flex;
  gap: 4rem;
  max-width: 1200px;
  margin: 2rem auto;
  padding: 0 10px;
}

@media screen and (max-width: 767px) {
  .message-box {
    display: flex !important;
    flex-direction: column-reverse !important;
  }
}

.message-left {
  flex: 1;
  background: url("/area/img/takasaki/message.png")
              no-repeat bottom left;
  background-size: contain;
  padding: 3rem 2rem 5rem;
}

.message-left p {
  font-family: "Noto Sans JP", "Noto Sans", sans-serif;
  font-size: 20px;
  line-height: 1.8;
  color: #333;
  margin: 0 0 1.2rem;
}

.message-left p:last-child {
  margin-bottom: 0;
}

.message-right {
  flex: 0 0 360px;
}

.message-right img {
  width: 100%;
  height: auto;
  display: block;
}

.message .interview {
  max-width: 1100px;
  margin: 4rem auto 0;
  background: #fff;
  border-radius: 12px;
  padding: 2rem;
　padding-top: 1rem !important;
}

.message .interview-title {
  text-align: center;
  font-size: 26px;
  font-weight: 700;
  color: #2B4597;
  margin-bottom: 3rem;
}

.message .qa {
  display: flex;
  gap: 16px;
  padding: 20px 24px;
  border-radius: 10px;
  margin-bottom: 24px;
}

.message .qa.q {
  background: #f0f0f0;
}

.message .qa.a {
  background: #eaf6fc;
}

.message .qa-label {
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
}

.message .qa-label.q {
  color: #2B4597;
}

.message .qa-label.a {
  color: #e53935;
}

.message .qa p {
  font-size: 20px;
  line-height: 1.8;
  margin: 0;
}


@media screen and (max-width:767px) {
  .message h2{
    font-size:1.5rem;
    line-height:1.4;
  }

  .message-box{
    flex-direction:column;
    gap:2rem;
    margin:1.5rem auto 0;
    padding:0 16px;
  }

  .message-left{
    background:none;
    padding:0;
  }

  .message-left p{
    font-size:1rem;
    line-height:1.7;
    margin-bottom:1rem;
  }

  .message-right{
    flex:none;
    max-width:260px;
    margin: 0rem auto;
  }

  .message .interview{
    margin:2.5rem auto 0;
    padding:1.5rem;
    border-radius:10px;
	  width:94%;
  }

  .message .interview-title{
    font-size:1.25rem;
    margin-bottom:1.5rem;
  }

  .message .qa{
　　 align-items: flex-start;
    gap:8px;
    padding:14px 16px;
    margin-bottom:16px;
  }

  .message .qa-label{
    font-size:1.2rem;
  }

  .message .qa p{
    font-size:1rem;
    line-height:1.7;
  }
}

.interview-title-img {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  color: #2B4597;
  line-height: 1.5;
  margin-bottom: 3rem;
　margin: 0 0 3rem;
　margin-top: -20px !important;
}

.message .interview > h3.interview-title-img{
  margin-top: 0 !important;
}

.interview-title-img .title-deco {
  width: 40px;
  height: auto;
  margin-top: 82px;
}

@media screen and (max-width: 768px) {
    .message .interview {
    padding:1rem;
		padding-top:16px !important;
  }
	
  .interview-title-img {
	  font-size: 18px;
    gap: 2px;
    margin-bottom: 2rem;
	   margin-top: -30px !important;
  }

  .interview-title-img .title-deco{
    width: 22px;
    margin-top: 0;
	margin-top:54px;
  }
}

.feature {
  background: #fff;
}

.feature-row {
  display: flex;
  gap: 48px;
  align-items: center;
  margin-top: 3rem;
}

.feature-row.reverse {
  flex-direction: row-reverse;
}

.feature-img img {
  display: block;
  max-width: 100%;
  border-radius: 4px;
}

.feature-text p {
  font-size: 20px;
  line-height: 1.8;
  color: #333;
}

.feature-text .label {
  display: inline-block;
  background: #2B4597;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  padding: 6px 14px;
  margin: 16px 0 8px;
}

.feature .h2-style + .feature-row + .h2-style {
  margin-top: 4rem;
}

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

  .feature-row{
    flex-direction:column;
    gap:24px;
    margin-top:2rem;
  }

  .feature-row.reverse{
    flex-direction:column;
  }

  .feature-img{
    width:90%;
  }

  .feature-text p{
    font-size:1rem;
    line-height:1.7;
  }

  .feature-text .label{
    font-size:0.875rem;
    padding:5px 12px;
    margin:12px 0 6px;
  }

  .feature .h2-style + .feature-row + .h2-style{
    margin-top:3rem;
  }
}

.voice-section {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 80px 0;
  background: #f2fbff;
}

.voice-section .inner {
 max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
  overflow: visible;
}

@media screen and (max-width: 768px){
.voice-section {
	 width: 90vw;
	margin-left:0px!important;
    padding: 32px 0;
  }

  .voice-section .inner{
    padding: 0 4px;
  }
}

.voice-lead {
  text-align: center;
  margin-top: 1rem;
  margin-bottom: 3rem;
  color: #333;
}

.voice-slider {
  position: relative;
  padding: 0 80px;
}

.voice-viewport {
  overflow: hidden;
  width: 100%;
}

.voice-card {
  flex: 0 0 calc((100% - 48px) / 3);
  background: #fff;
  border-radius: 16px;
  padding: 1.6rem 1.6rem;
  margin: 0;
}

.voice-card * {
  margin-left: 0;
  margin-right: 0;
}

.voice-track {
  display: flex;
  gap: 24px;
}

.voice-head {
  display: flex;
  align-items: center;
  gap: 0.2rem;
  margin-bottom: 0.6rem;
	height:40px;
}

.voice-head img {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  display: block;
}

.voice-head h3 {
  color: #2B4597;
  text-decoration: none;
　font-weight: 700;
}

.voice-card p {
  line-height: 1.8;
  color: #333;
}

.voice-slider {
  position: relative;
　padding: 0 72px;
}

.voice-slider .arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border: none;
  padding: 0;
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  cursor: pointer;
  z-index: 50;
}

.voice-slider .arrow.prev {
  left: -12px;
  background-image: url("/area/img/takasaki/voice_left.png");
}

.voice-slider .arrow.next {
  right: -12px;
  background-image: url("/area/img/takasaki/voice_right.png");
}

.voice-track {
  transition: transform 0.35s ease;
  will-change: transform;
}

.voice-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 14px;
}

.voice-dots .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ccc;
  border: none;
  padding: 0;
  cursor: pointer;
}

.voice-dots .dot.active {
  background: #2B4597;
}

.voice-card{
  padding: 0;
}

.voice-card a{
  display: block;
  height: 100%;
  padding: 1.6rem;
  background-color: #ffffff;
  border-radius: 16px;
  box-sizing: border-box;
}

@media screen and (max-width: 768px){
  .voice-card a {
    height: auto;
    padding: 1.0rem;
    line-height: 1;
	display: block;
    height: 100%;
  }
}

.voice-card a:hover{
  background-color: #f2f2f2;
}

@media screen and (max-width: 768px){
  .voice-viewport{
    overflow: hidden;
    width: 100%;
  }

  .voice-track{
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
  }

 .voice-slider{
    padding: 0 32px;
  }

  .voice-card{
    flex: 0 0 100%;
    max-width: 100%;
　　padding: 0.5rem 0.8rem;
    border-radius: 14px;
  }

  .voice-slider .arrow{
    width: 22px;
    height: 22px;
  }

　.voice-card p {
	 font-size;16px;
	 margin: 0;
    line-height: 1.6;
}
	
  .voice-slider .arrow.prev{
    left: 8px !important;
  }

  .voice-slider .arrow.next{
    right: 8px !important;
  }
}


.access-section {
  padding: 40px 0;
}

.access-box {
  border: 2px solid #2b4aa0;
  border-radius: 8px;
  padding: 30px;
  margin-top:4rem;
}

.access-map iframe {
  width: 100%;
  height: 300px;
  border: none;
  border-radius: 4px;
}

.access-bottom {
  display: flex;
  gap: 10px;
  margin-top: 30px;
}

.access-slider {
  position: relative;
  width: 50%;
}

.access-viewport {
  overflow: hidden;
}

.access-track {
  display: flex;
  transition: transform 0.4s ease;
}

.access-track img {
  width: 100%;
  flex-shrink: 0;
  border-radius: 6px;
}

.access-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid #2b4aa0;
  cursor: pointer;
}

.access-arrow.prev {
  left: -18px;
}

.access-arrow.next {
  right: -18px;
}

.access-dots {
  text-align: center;
  margin-top: 10px;
}

.access-dots .dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: #ccc;
  border-radius: 50%;
  margin: 0 4px;
}

.access-dots .dot.active {
  background: #2b4aa0;
}

.access-info {
  width: 50%;
  padding:2rem;
}

.access-info p {
  line-height:1.5em;
	padding-left:10px;
	
}

.access-title {
  background: #2b4aa0;
  color: #fff;
  padding: 10px 16px;
  font-weight: bold;
  margin-bottom: 26px;
  font-size:18px;
}

.access-info hr {
  border: none;
  border-top: 1px dashed #aaa;
  margin: 16px 0;
}

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

  .access-section{
    padding: 30px 0;
  }

  .access-box{
    padding: 20px;
    margin-top: 2.5rem;
  }

  .access-map iframe{
    height: 220px;
    border-radius: 4px;
  }

  .access-bottom{
    flex-direction: column;
    gap: 4px;
    margin-top: 20px;
  }

  .access-slider{
    width: 100%;
  }

  .access-track img{
    border-radius: 6px;
  }

  .access-arrow{
    width: 30px;
    height: 30px;
  }

  .access-arrow.prev{
    left: -10px;
  }

  .access-arrow.next{
    right: -10px;
  }

  .access-dots{
    margin-top: 8px;
  }

  .access-info{
    width: 100%;
    padding: 1.5rem 0rem;
  }

  .access-title{
    font-size: 16px;
    padding: 8px 12px;
    margin-bottom: 18px;
  }

  .access-info p{
    font-size: 0.95rem;
    line-height: 1.6;
    padding-left: 0;
  }

  .access-info hr{
    margin: 12px 0;
  }
}

.exam-headline {
  text-align: center;
  margin: 30px 0;
  color: #1f3c88;
}

.exam-headline .headline-main {
  font-size: 40px;
  font-weight: 700;
  line-height: 1.1;
}

.exam-headline .headline-main .emphasis {
  position: relative;
  font-size: 48px;
  font-weight: 800;
  display: inline-block;
}

.exam-headline .headline-main .emphasis::before,
.exam-headline .headline-main .emphasis::after {
  content: "・";
  position: absolute;
  top: -0.8em;
  font-size: 18px;
  color: #1f3c88;
}

.exam-headline .headline-main .emphasis::before {
  left: 20px;
}

.exam-headline .headline-main .emphasis::after {
  right: 40px;
}

.exam-headline .headline-sub {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 32px;
  font-weight: 600;
  line-height: 1.0 !important;
  margin-top: -8px !important;
}

.exam-headline .title-deco {
  height: 42px;
  width: auto;
  display: block;
  margin-top: 30px;
}

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

  .exam-headline {
    margin: 0px 0;
  }

  .exam-headline .headline-main {
    font-size: 18px;
    line-height: 1;
  }

  .exam-headline .headline-main .emphasis {
    font-size: 26px;
  }

  .exam-headline .headline-main .emphasis::before,
  .exam-headline .headline-main .emphasis::after {
    font-size: 14px;
    top: -0.7em;
  }

  .exam-headline .headline-main .emphasis::before {
    left: 14px;
  }

  .exam-headline .headline-main .emphasis::after {
    right: 28px;
  }

  .exam-headline .headline-sub {
    font-size: 18px;
    line-height: 1.5 !important;
    margin-top: -20px !important;
    gap: 6px;
  }

  .exam-headline .title-deco {
    height: 38px;
    margin-top: 26px;
  }
}