@charset "utf-8";

.hero{
  position:relative;
  min-height:820px;
  padding:150px 54px 70px;
  display:grid;
  grid-template-columns:1fr minmax(420px,42vw);
  gap:42px;
  align-items:end;
  background:#f5f4ee;
}

.hero::before{
  content:"";
  position:absolute;
  left:54px;
  right:54px;
  bottom:48px;
  height:58%;
  border-radius:44px;
  background:#65d8c7;
  z-index:0;
}

.hero-text,
.hero-card{
  position:relative;
  z-index:1;
}

.hero-text{
  max-width:850px;
  align-self:center;
  padding-left: 20px;
  padding-top:54px;
}

.hero-text span,
.message-inner p,
.board-copy span,
.news-list span,
.culture-copy span{
  display:block;
  font-weight:950;
  letter-spacing:.06em;
}

.hero-text h2{
  margin-top:28px;
  font-size:92px;
  line-height:.98;
  letter-spacing:-.08em;
  font-weight:950;
}

.hero-text p{
  margin-top:28px;
  font-size:22px;
  font-weight:700;
}

.hero-card{
  height:620px;
  border-radius:42px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(0,0,0,.17);
}

.message-section{
  padding:112px 54px 92px;
  background:#fff;
}

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

.message-inner h2{
  max-width:1050px;
  font-size:72px;
  line-height:1.08;
  letter-spacing:-.07em;
  font-weight:950;
}

.message-inner p{
  margin-top:32px;
  max-width:720px;
  font-size:21px;
  line-height:1.65;
  color:#333;
  letter-spacing:-.03em;
}

.card-board{
  padding:106px 54px;
  background:#f5f4ee;
}

.board-head,
.news-head{
  max-width:1480px;
  margin:0 auto 36px;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
}

.board-head h2,
.news-head h2,
.culture-copy h2{
  font-size:52px;
  line-height:1.12;
  letter-spacing:-.06em;
  font-weight:950;
}

.board-head a,
.news-head a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:118px;
  min-height:54px;
  padding:0 24px;
  border:2px solid #111;
  border-radius:999px;
  background:#fff;
  font-size:15px;
  font-weight:900;
}

.board-grid{
  max-width:1480px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}

.board-item{
  position:relative;
  min-height:420px;
  padding:30px;
  border-radius:36px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.board-item.wide{
  grid-column:span 2;
}

.board-item.mint{background:#9be2d7;}
.board-item.yellow{background:#ffd66b;}
.board-item.green{background:#b7df83;}
.board-item.black{background:#171717;color:#fff;}
.board-item.blue{background:#9fc7ff;}

.board-copy{
  position:relative;
  z-index:2;
}

.board-copy span{
  margin-bottom:12px;
  font-size:14px;
}

.board-copy h3{
  font-size:34px;
  line-height:1.16;
  letter-spacing:-.06em;
  font-weight:950;
}

.board-copy p{
  margin-top:16px;
  max-width:420px;
  font-size:17px;
  color:rgba(0,0,0,.72);
}

.black .board-copy p{
  color:rgba(255,255,255,.72);
}

.board-item img{
  position:absolute;
  right:0;
  bottom:0;
  width:58%;
  height:54%;
  border-top-left-radius:36px;
}

.board-item.wide img{
  width:50%;
  height:72%;
}

.news-section{
  padding:106px 54px;
  background:#fff;
}

.news-list{
  max-width:1480px;
  margin:0 auto;
  display:grid;
  gap:14px;
}

.news-list a{
  display:grid;
  grid-template-columns:150px 1fr 140px;
  align-items:center;
  gap:24px;
  min-height:92px;
  padding:0 30px;
  border-radius:24px;
  background:#f5f4ee;
}

.news-list span{
  font-size:14px;
}

.news-list strong{
  font-size:24px;
  letter-spacing:-.04em;
}

.news-list em{
  font-style:normal;
  color:#555;
  text-align:right;
}

.culture-section{
  padding:0 54px 112px;
  background:#fff;
}

.culture-section{
  display:grid;
  grid-template-columns:.8fr 1.2fr;
  gap:28px;
  align-items:stretch;
}

.culture-copy{
  padding:54px;
  border-radius:38px;
  background:#171717;
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.culture-copy p{
  margin-top:22px;
  font-size:19px;
  color:rgba(255,255,255,.72);
}

.culture-image{
  min-height:520px;
  border-radius:38px;
  overflow:hidden;
}

@media (min-width:1440px){
  .hero-text h2{font-size:104px;}
}

@media (max-width:1439px){
  .hero{padding:132px 38px 62px;min-height:760px;gap:32px;}
  .hero::before{left:38px;right:38px;}
  .hero-text h2{font-size:78px;}
  .hero-card{height:560px;}
  .message-section,.card-board,.news-section{padding-left:38px;padding-right:38px;}
  .message-inner h2{font-size:62px;}
  .board-head h2,.news-head h2,.culture-copy h2{font-size:46px;}
  .board-grid{gap:20px;}
  .board-item{padding:26px;}
  .board-copy h3{font-size:30px;}
  .culture-section{padding-left:38px;padding-right:38px;}
}

@media (max-width:1279px){
  .hero{
    padding:116px 28px 54px;
    min-height:auto;
    grid-template-columns:1fr;
  }
  .hero::before{
    left:28px;
    right:28px;
    bottom:34px;
    height:45%;
  }
  .hero-text{padding-left: 0;}
  .hero-text h2{font-size:64px;}
  .hero-card{height:500px;}
  .message-section,.card-board,.news-section{padding:84px 28px;}
  .message-inner h2{font-size:52px;}
  .board-grid{grid-template-columns:repeat(2,1fr);}
  .board-item.wide{grid-column:span 2;}
  .news-list a{
    grid-template-columns:120px 1fr;
  }
  .news-list em{
    grid-column:2;
    text-align:left;
  }
  .culture-section{
    padding:0 28px 84px;
    grid-template-columns:1fr;
  }
  .culture-image{min-height:420px;}
}

@media (max-width:767px){
  .hero{
    padding:120px 20px 40px;
    gap:28px;
  }
  .hero::before{
    left:20px;
    right:20px;
    bottom:28px;
    height:42%;
    border-radius:28px;
  }
  .hero-text h2{
    font-size:44px;
    line-height:1.05;
  }
  .hero-text p{
    font-size:17px;
  }
  .hero-card{
    height:360px;
    border-radius:28px;
  }
  .message-section,.card-board,.news-section{
    padding:66px 20px;
  }
  .message-inner h2{
    font-size:36px;
  }
  .message-inner p{
    font-size:17px;
  }
  .board-head,.news-head{
    display:block;
    margin-bottom:26px;
  }
  .board-head h2,.news-head h2,.culture-copy h2{
    font-size:34px;
  }
  .board-head a,.news-head a{
    margin-top:18px;
    min-height:50px;
  }
  .board-grid{
    grid-template-columns:1fr;
    gap:18px;
  }
  .board-item,
  .board-item.wide{
    grid-column:auto;
    min-height:380px;
    padding:24px;
    border-radius:28px;
  }
  .board-copy h3{
    font-size:28px;
  }
  .board-item img,
  .board-item.wide img{
    width:68%;
    height:48%;
    border-top-left-radius:28px;
  }
  .news-list a{
    grid-template-columns:1fr;
    min-height:auto;
    padding:24px;
    gap:8px;
  }
  .news-list em{
    grid-column:auto;
  }
  .news-list strong{
    font-size:21px;
  }
  .culture-section{
    padding:0 20px 66px;
    gap:18px;
  }
  .culture-copy{
    padding:32px 24px;
    border-radius:28px;
  }
  .culture-image{
    min-height:300px;
    border-radius:28px;
  }
}

@media (max-width:320px){
  .hero{padding-left:16px;padding-right:16px;}
  .hero::before{left:16px;right:16px;}
  .hero-text h2{font-size:38px;}
  .message-section,.card-board,.news-section{padding-left:16px;padding-right:16px;}
  .message-inner h2{font-size:32px;}
  .board-head h2,.news-head h2,.culture-copy h2{font-size:30px;}
  .culture-section{padding-left:16px;padding-right:16px;}
}
