@charset "UTF-8";
/* =======================================================
   Responsive (append-only)
   1240 / 1024 / 768 / 640
======================================================= */
/* <=1240px ------------------------------------------- */
@media screen and (max-width: 1240px) {
  body {
    font-size: 1.55rem !important;
    line-height: 1.75;
  }
  #l-header .inner {
    max-width: 100%;
    min-width: 0;
    padding: 22px 20px;
  }
  #l-header .logo img {
    height: 62px;
  }
  #l-header #header_nav ul {
    gap: 18px;
  }
  #slideshow {
    height: auto;
  }
  #slideshow .fv-center-inner {
    max-width: 820px;
  }
  #slideshow .fv-catch {
    font-size: 2.1rem;
    letter-spacing: 0.16em;
  }
  .page-title {
    height: 380px;
  }
  .page-title__en {
    font-size: 4.6rem;
  }
  .breadcrumb__inner {
    padding: 0 20px;
  }
  .footer {
    padding: 72px 0 72px;
  }
  .single01,
  .single03 {
    padding: 88px 0;
  }
  .single02 {
    width: calc(100% - 64px);
    padding: 88px 0;
  }
  .margin-top {
    margin-top: -88px;
  }
  .margin-bottom {
    margin-bottom: -88px;
  }
  .message::before,
  .message::after {
    width: 300px;
    height: 300px;
  }
  .message::before {
    left: 30px;
  }
  .message::after {
    right: 30px;
  }
  .message__inner {
    max-width: 680px;
    padding: 0 18px;
  }
  .service__grid {
    gap: 28px;
  }
  .news__head {
    margin-bottom: 38px;
  }
  .news__list {
    padding: 0 18px;
  }
  .blog__illust img {
    width: 130px;
  }
  .blog__thumb {
    width: 70%;
    display: block;
    margin: 0 auto;
  }
  .blog__head {
    margin-bottom: 38px;
  }
  .blog__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
  }
  .blog__grid--3col {
    grid-template-columns: repeat(3, 1fr);
  }
  .company-origin {
    padding: 88px 0;
  }
  .company-origin__inner {
    padding: 0 32px;
  }
  .company-origin__title {
    font-size: 2.6rem;
    margin-bottom: 28px;
  }
  .company-origin__text p {
    font-size: 1.75rem;
  }
  .company-origin__logo img {
    max-width: 300px;
  }
  .aim__title__big {
    font-size: 2.8rem;
    margin-bottom: 34px;
  }
  .aim__row {
    grid-template-columns: 1fr 220px;
    gap: 32px;
  }
  .aim__eyebrow {
    font-size: 4.4rem;
  }
  .aim__title {
    font-size: 2.1rem;
  }
  .about_message {
    padding: 80px 0;
  }
  .about_message__inner {
    padding: 0 18px;
  }
  .about_message__text p {
    margin-bottom: 26px;
  }
  .self_ri__card {
    padding: 48px 56px;
    gap: 64px;
  }
  .self_ri__logoFrame {
    width: 300px;
  }
  .self_ri__title {
    font-size: 2.3rem;
    margin-bottom: 22px;
  }
}
/* <=1024px ------------------------------------------- */
@media screen and (max-width: 1024px) {
  #l-header .inner {
    max-width: 100%;
    min-width: 0;
    padding: 18px 18px;
    justify-content: flex-start;
  }
  #l-header .logo {
    position: static;
    transform: none;
  }
  #l-header #header_nav {
    display: none;
  }
  #l-header .head-right {
    display: none;
  }
  .menu {
    width: min(88vw, 340px);
    padding: 18px;
  }
  .menu ul {
    margin-top: 64px;
  }
  .hamburger {
    top: 16px;
    right: 16px;
    width: 54px;
    height: 54px;
  }
  #slideshow .fv-center {
    padding: 0 24px;
  }
  #slideshow .fv-center-inner {
    max-width: 720px;
  }
  #slideshow .fv-catch {
    font-size: 2rem;
    letter-spacing: 0.14em;
    padding-left: 0;
    margin-top: 12px;
    line-height: 1.75;
  }
  .page-title {
    height: 340px;
    background-position: center top;
  }
  .page-title__en {
    font-size: 4rem;
    letter-spacing: 0.1em;
  }
  .page-title__ja {
    font-size: 1.5rem;
  }
  .breadcrumb {
    padding: 12px 0;
  }
  .breadcrumb__inner {
    font-size: 1.15rem;
    letter-spacing: 0.06em;
  }
  .footer {
    padding: 64px 0 64px;
  }
  .footer__buttons {
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
  .footer__btn {
    width: min(360px, 92%);
  }
  .footer__info {
    font-size: 1.35rem;
    margin-bottom: 22px;
  }
  .single01,
  .single03 {
    padding: 72px 40px;
  }
  .single02 {
    width: calc(100% - 48px);
    padding: 72px 40px;
  }
  .margin-top {
    margin-top: -72px;
  }
  .margin-bottom {
    margin-bottom: -72px;
  }
  .lsingle,
  .rsingle {
    float: none;
    width: 100%;
  }
  #main,
  #side {
    float: none;
    width: 100%;
  }
  #side {
    position: static;
    top: auto;
    right: auto;
    padding-right: 0;
    margin-top: 28px;
  }
  .column3 {
    grid-template-columns: repeat(2, 1fr);
  }
  /* title
  -------------------------------------------------------------------------*/
  .title {
    font-size: 3rem;
    letter-spacing: 0.1em;
  }
  .sub {
    font-size: 1.6rem;
    margin-bottom: 32px;
  }
  .section_title {
    font-size: 1.7rem;
    padding: 16px 0 14px;
    margin-bottom: 28px;
  }
  .corner_title {
    font-size: 1.5rem;
    padding: 5px 18px;
  }
  .corner_title::before,
  .corner_title::after {
    width: 14px;
  }
  .emphasis_title {
    font-size: 1.7rem;
    margin-bottom: 18px;
  }
  /* table
  -------------------------------------------------------------------------*/
  .table_design01,
  .table_design02 {
    font-size: 1.3rem;
  }
  /* contents
  -------------------------------------------------------------------------*/
  .message {
    padding-bottom: 180px;
  }
  .message::before,
  .message::after {
    width: 220px;
    height: 220px;
    top: auto;
    right: auto;
    left: 50%;
    bottom: 20px;
    transform: none;
  }
  .message::before {
    transform: translateX(-110%);
  }
  .message::after {
    transform: translateX(10%);
  }
  .message__inner {
    max-width: 640px;
    padding: 0 18px;
  }
  .message__label {
    font-size: 3rem;
    letter-spacing: 0.1em;
    margin-bottom: 14px;
  }
  .message__title {
    font-size: 2.2rem;
    margin-bottom: 14px;
  }
  .message__text p {
    margin-bottom: 24px;
  }
  .service__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
  .service__badge {
    top: 12px;
    right: 12px;
    transform: none;
    width: 64px;
    height: 64px;
    font-size: 1.25rem;
  }
  .service__title {
    font-size: 3rem;
    letter-spacing: 0.1em;
  }
  .service__sub {
    font-size: 1.6rem;
  }
  .service__card:nth-child(3) {
    grid-column: 1/-1;
    width: calc(50% - 12px);
    margin-left: auto;
    margin-right: auto;
  }
  .news__head {
    margin-bottom: 32px;
  }
  .news__title {
    font-size: 3rem;
    letter-spacing: 0.1em;
  }
  .news__sub {
    font-size: 1.6rem;
  }
  .news__item {
    padding: 18px 0;
    grid-template-columns: 120px 1fr 40px;
  }
  .news__arrow {
    width: 24px;
    height: 24px;
    font-size: 1.9rem;
  }
  .blog__head {
    margin-bottom: 32px;
  }
  .blog__title {
    font-size: 3rem;
    letter-spacing: 0.1em;
  }
  .blog__sub {
    font-size: 1.6rem;
  }
  .blog__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .blog__grid--3col {
    grid-template-columns: repeat(2, 1fr);
  }
  .blog__body {
    padding: 14px 14px 14px;
  }
  .company-origin {
    padding: 72px 0;
  }
  .company-origin__inner {
    padding: 0 24px;
  }
  .company-origin__title {
    font-size: 2.4rem;
    margin-bottom: 24px;
  }
  .company-origin__text p {
    font-size: 1.65rem;
    line-height: 1.9;
    margin-bottom: 18px;
  }
  .company-origin__logo {
    margin-top: 44px;
  }
  .company-origin__logo img {
    max-width: 280px;
  }
  .aim {
    padding: 32px 0;
  }
  .aim__inner {
    padding: 0 18px;
  }
  .aim__title__big {
    font-size: 2.6rem;
    margin-bottom: 28px;
  }
  .aim__row {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 0;
  }
  .aim__row:nth-of-type(-n+3) {
    padding-bottom: 28px;
  }
  .aim__media {
    order: 2;
  }
  .aim__media img {
    max-width: 420px;
  }
  .aim__eyebrow {
    font-size: 3.8rem;
    letter-spacing: 0.1em;
  }
  .aim__title {
    font-size: 2rem;
    letter-spacing: 0.1em;
    margin-bottom: 12px;
  }
  .aim__desc {
    line-height: 1.9;
  }
  .about_message {
    padding: 68px 0;
    background-position: center top;
  }
  .about_message__inner {
    padding: 0 18px;
  }
  .about_message__eyebrow {
    font-size: 3rem;
    letter-spacing: 0.1em;
    margin-bottom: 6px;
  }
  .about_message__title {
    font-size: 2.2rem;
    letter-spacing: 0.1em;
    margin-bottom: 22px;
  }
  .about_message__text p {
    margin-bottom: 22px;
  }
  .self_ri {
    padding: 0;
  }
  .self_ri__inner {
    padding: 0 20px;
  }
  .self_ri__card {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 40px 36px;
  }
  .self_ri__logo {
    justify-content: center;
  }
  .self_ri__logoFrame {
    width: 280px;
  }
  .self_ri__title {
    font-size: 2.2rem;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
  }
  .company {
    padding: 50px 20px;
  }
  .company__row {
    grid-template-columns: 140px 1fr;
    gap: 24px;
  }
  .company__sub {
    margin-bottom: 32px;
  }
  .profile {
    padding: 60px 20px;
  }
  .profile__inner {
    grid-template-columns: 260px 1fr;
    gap: 48px;
  }
  .profile__visual {
    height: 520px;
  }
  .profile__photo {
    width: 260px;
  }
  .access {
    padding: 0 20px;
  }
  .access__map iframe {
    height: 340px;
  }
  .access__btn {
    margin-bottom: 32px;
  }
  .route-wrap {
    grid-template-columns: 1fr 360px;
    gap: 32px;
  }
  .route {
    margin-bottom: 32px;
  }
  .contact {
    padding: 36px 0;
  }
  .contact__inner {
    padding: 0 20px;
  }
  .contact__row {
    grid-template-columns: 200px 1fr;
    gap: 20px;
  }
  .privacy__inner {
    padding: 32px;
    border-radius: 18px;
  }
  .privacy__body {
    margin-bottom: 26px;
  }
  .new_list {
    padding: 50px 20px 80px;
  }
  .new_list__inner {
    grid-template-columns: 1fr 220px;
    gap: 30px;
  }
  .new_list__main {
    padding: 50px 32px 70px;
  }
  .new_list__title {
    font-size: 3.2rem;
    letter-spacing: 0.12em;
  }
  .new_list__pager {
    margin-top: 40px;
  }
  .new_list__pagerBtn {
    min-width: 130px;
  }
  .article__content {
    margin-top: 32px;
  }
  .article__title {
    font-size: 2rem;
  }
  .group_main {
    width: auto;
    max-width: 800px;
    padding: 0 20px;
  }
  .group__subbox {
    width: auto;
    max-width: 768px;
  }
  .group__cardInner {
    grid-template-columns: 1fr 380px;
  }
  .minibox__image {
    flex: 0 0 220px;
  }
  .mindfulness__head {
    margin-bottom: 34px;
  }
  .mindfulness__title {
    font-size: 2.6rem;
  }
  .mindfulness__layout {
    gap: 28px;
  }
  .mindfulness__photo--sub {
    left: -40px;
    bottom: -40px;
    width: 200px;
  }
  .mindfulness {
    padding: 0 0 34px;
  }
  .mindfulness__inner {
    width: calc(100% - 32px);
  }
  .mindfulness__layout {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .mindfulness__media {
    padding-left: 0;
    max-width: 560px;
    margin: 0 auto;
  }
  /* サブ写真は“はみ出し”を減らして綺麗に見せる */
  .mindfulness__photo--sub {
    left: 12px;
    bottom: 12px;
    width: 180px;
  }
  .course {
    margin-bottom: 80px;
  }
  .course__grid {
    gap: 24px;
  }
  .course__title {
    font-size: 1.9rem;
  }
  .course__body {
    padding: 20px 20px 16px;
  }
  .course__footer {
    padding: 14px 20px 20px;
  }
  .program {
    padding: 26px;
  }
  .program__inner {
    grid-template-columns: 4fr 6fr;
    gap: 28px;
  }
  .program__title {
    font-size: 1.7rem;
  }
}
/* <=768px -------------------------------------------- */
@media screen and (max-width: 768px) {
  body {
    font-size: 1.4rem !important;
    line-height: 1.7;
    letter-spacing: 0.03em;
  }
  #wrapper {
    overflow-x: hidden;
  }
  #l-header .inner {
    padding: 14px 16px;
  }
  #l-header .logo img {
    height: 60px;
  }
  .hamburger {
    top: 14px;
    right: 14px;
    width: 52px;
    height: 52px;
  }
  #slideshow .fv-center {
    padding: 0 18px;
  }
  #slideshow .fv-center-inner {
    max-width: 560px;
  }
  #slideshow .fv-logo img {
    max-width: 240px;
    width: 70%;
    height: auto;
    margin: 0 auto;
  }
  #slideshow .fv-catch {
    font-size: 1.8rem;
    letter-spacing: 0.12em;
    line-height: 1.7;
    margin-top: 10px;
  }
  .page-title {
    height: 280px;
    background-position: center center;
  }
  .page-title__inner {
    padding: 0 18px;
  }
  .page-title__en {
    font-size: 3.2rem;
    letter-spacing: 0.08em;
    margin: 0 auto;
  }
  .page-title__ja {
    font-size: 1.4rem;
    margin-top: 6px;
  }
  .breadcrumb {
    padding: 10px 0;
  }
  .breadcrumb__inner {
    padding: 0 16px;
    gap: 6px;
    flex-wrap: wrap;
    line-height: 1.6;
    font-size: 1.1rem;
  }
  .footer {
    padding: 56px 0 56px;
  }
  .footer__brand {
    gap: 8px;
    margin-bottom: 12px;
  }
  .footer__logo {
    height: 58px;
  }
  .footer__name {
    font-size: 1.5rem;
    letter-spacing: 0.1em;
  }
  .footer__sns {
    gap: 12px;
  }
  .footer__snslink {
    width: 36px;
    height: 36px;
    border-radius: 10px;
  }
  .single01,
  .single03 {
    padding: 60px 30px;
  }
  .single02 {
    width: calc(100% - 32px);
    padding: 60px 30px;
  }
  .margin-top {
    margin-top: -60px;
  }
  .margin-bottom {
    margin-bottom: -60px;
  }
  .column2,
  .column3 {
    gap: 18px;
  }
  /* title
  -------------------------------------------------------------------------*/
  .section_title {
    font-size: 1.6rem;
    padding: 14px 0 12px;
    margin-bottom: 24px;
  }
  .corner_title {
    font-size: 1.4rem;
    padding: 4px 16px;
    margin-bottom: 8px;
  }
  .corner_title::before,
  .corner_title::after {
    width: 12px;
  }
  .emphasis_title {
    font-size: 1.6rem;
    margin-bottom: 16px;
  }
  /* table
  -------------------------------------------------------------------------*/
  .table_design01,
  .table_design02 {
    border: none;
  }
  .table_design01 tr,
  .table_design02 tr {
    display: block;
    margin-bottom: 16px;
  }
  .table_design01 th,
  .table_design01 td,
  .table_design02 th,
  .table_design02 td {
    display: block;
    width: 100%;
    border: none;
    box-sizing: border-box;
  }
  .table_design01 th,
  .table_design02 th {
    text-align: left;
    padding: 0.8em 1em;
    font-weight: 600;
  }
  .table_design01 td,
  .table_design02 td {
    padding: 0.8em 1em 1em;
  }
  /* contents
  -------------------------------------------------------------------------*/
  .message {
    padding-bottom: 120px;
  }
  .message::before,
  .message::after {
    width: 160px;
    height: 160px;
    bottom: 16px;
  }
  .message::before {
    transform: translateX(-105%);
  }
  .message::after {
    transform: translateX(5%);
  }
  .message__inner {
    max-width: 560px;
    padding: 0 16px;
  }
  .message__text p {
    margin-bottom: 20px;
  }
  .message__underline {
    margin: 8px 0 12px;
  }
  .service__grid {
    gap: 20px;
  }
  .service__badge {
    top: 10px;
    right: 10px;
    width: 56px;
    height: 56px;
    font-size: 1.15rem;
  }
  .service__name {
    font-size: 1.4rem;
  }
  .service__thumb {
    height: 130px;
  }
  .news__list {
    max-width: 620px;
    padding: 0 16px;
  }
  .news__item {
    grid-template-columns: 110px 1fr;
    grid-template-areas: "date main";
    -moz-column-gap: 12px;
         column-gap: 12px;
    row-gap: 8px;
    padding: 16px 0;
  }
  .news__date {
    grid-area: date;
    font-size: 1.1rem;
  }
  .news__text {
    grid-area: main;
    padding-right: 34px;
  }
  .news__arrow {
    justify-self: end;
    align-self: center;
    width: 24px;
    height: 24px;
    font-size: 1.9rem;
    position: absolute;
    right: 0;
  }
  .news__item {
    position: relative;
  }
  .news__more {
    padding: 0 16px;
    margin-top: 14px;
  }
  .blog__illust img {
    width: 120px;
  }
  .blog__grid {
    gap: 18px;
  }
  .blog__text {
    font-size: 1.2rem;
  }
  .company-origin {
    padding: 60px 0;
  }
  .company-origin__inner {
    padding: 0 18px;
  }
  .company-origin__title {
    font-size: 2.1rem;
    margin-bottom: 20px;
  }
  .company-origin__text p {
    font-size: 1.5rem;
    line-height: 1.85;
    margin-bottom: 16px;
  }
  .company-origin__logo {
    margin-top: 36px;
  }
  .company-origin__logo img {
    max-width: 250px;
  }
  .aim__title__big {
    font-size: 2.3rem;
    margin-bottom: 22px;
  }
  .aim__row {
    padding: 24px 0;
  }
  .aim__row:nth-of-type(-n+3) {
    padding-bottom: 24px;
  }
  .aim__eyebrow {
    font-size: 3.2rem;
  }
  .aim__title {
    font-size: 1.8rem;
  }
  .aim__media img {
    max-width: 360px;
  }
  .about_message {
    padding: 56px 0;
  }
  .about_message__inner {
    padding: 0 16px;
  }
  .about_message__text p {
    margin-bottom: 18px;
  }
  .self_ri__inner {
    padding: 0 16px;
  }
  .self_ri__card {
    padding: 32px 24px;
    gap: 26px;
  }
  .self_ri__logoFrame {
    width: 240px;
  }
  .self_ri__title {
    font-size: 2rem;
    letter-spacing: 0.08em;
    margin-bottom: 18px;
    text-align: center;
  }
  .self_ri__text p {
    margin-bottom: 16px;
  }
  .company {
    padding: 40px 16px;
  }
  .company__title {
    font-size: 2.8rem;
    letter-spacing: 0.1em;
  }
  .company__sub {
    font-size: 1.6rem;
    margin-bottom: 28px;
  }
  .company__row {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 18px 0;
  }
  .company__dt {
    font-weight: 600;
    color: rgba(0, 0, 0, 0.8);
  }
  .profile {
    padding: 50px 16px;
  }
  .profile__inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .profile__visual {
    position: relative;
    height: auto;
    display: flex;
    justify-content: center;
  }
  .profile__photo {
    position: relative;
    width: 240px;
  }
  .profile__content {
    padding-top: 0;
    text-align: left;
  }
  .profile__name {
    font-size: 1.5rem;
  }
  .profile__role {
    margin-bottom: 18px;
  }
  .access {
    padding: 0 16px;
  }
  .access__map iframe {
    height: 300px;
  }
  .access__btnWrap {
    margin-top: 22px;
  }
  .access__btn {
    min-width: 200px;
    height: 42px;
    padding: 0 28px;
    font-size: 1.3rem;
    margin-bottom: 28px;
  }
  .route-wrap {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .route {
    padding: 0 8px 0 6px;
    margin-bottom: 28px;
  }
  .route li {
    margin: 10px 0 0 26px;
    line-height: 1.6;
  }
  .route > li::before {
    left: -26px;
    top: 1px;
  }
  .route-image {
    max-width: 480px;
    margin: 0 auto 30px;
  }
  .contact {
    padding: 32px 0;
  }
  .contact__inner {
    padding: 0 16px;
  }
  .contact__text {
    margin-bottom: 32px;
  }
  .contact__row {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 12px 0;
  }
  .contact__label {
    padding-top: 0;
  }
  .contact__req {
    height: 16px;
    font-size: 1rem;
  }
  .contact__field input,
  .contact__field textarea,
  .contact__field select {
    padding: 10px 12px;
    font-size: 1.4rem;
  }
  .contact__field textarea {
    min-height: 150px;
  }
  .privacy__inner {
    padding: 28px 24px;
    border-radius: 16px;
  }
  .privacy__heading {
    font-size: 1.5rem;
    padding-bottom: 8px;
    margin-bottom: 8px;
  }
  .privacy__body {
    font-size: 1.35rem;
    line-height: 1.9;
    margin-bottom: 24px;
  }
  .privacy__body p {
    margin-bottom: 10px;
  }
  .new_list {
    padding: 40px 16px 70px;
  }
  .new_list__inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .new_list__main {
    padding: 40px 22px 56px;
  }
  .new_list__title {
    font-size: 2.8rem;
    letter-spacing: 0.1em;
  }
  .new_list__title span {
    margin-top: 8px;
    font-size: 1.3rem;
  }
  .new_list__sideTitle {
    justify-content: center;
  }
  .new_list__archive a {
    text-align: center;
  }
  .new_list__pager {
    margin-top: 34px;
  }
  .new_list__pagerBtn {
    min-width: 120px;
    padding: 10px 16px;
    font-size: 1.2rem;
  }
  .article__content {
    margin-top: 28px;
  }
  .article__date {
    font-size: 1.1rem;
    margin-bottom: 6px;
  }
  .article__title {
    font-size: 1.8rem;
    line-height: 1.5;
  }
  .group {
    padding: 36px 0 60px;
  }
  .group_main {
    margin-bottom: 32px;
  }
  .group_main p {
    text-align: left;
  }
  .group__card {
    padding: 32px 24px;
    margin-bottom: 32px;
  }
  .group__cardInner {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .group__cardTitle {
    font-size: 2rem;
  }
  .group__minibox {
    flex-direction: column;
    padding: 24px;
    gap: 16px;
  }
  .group__minibox.image-left,
  .group__minibox.image-right {
    flex-direction: column;
  }
  .minibox__image {
    flex: none;
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
  }
  .group__subbox {
    width: auto;
    margin: 20px 16px;
    padding: 20px;
  }
  .mindfulness {
    padding: 0 0 34px;
  }
  .mindfulness__inner {
    width: calc(100% - 32px);
  }
  .mindfulness__head {
    margin-bottom: 28px;
  }
  .mindfulness__title {
    font-size: 2.2rem;
  }
  .mindfulness__layout {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .mindfulness__media {
    padding-left: 0;
    max-width: 560px;
    margin: 0 auto;
  }
  .mindfulness__photo--sub {
    left: 12px;
    bottom: 12px;
    width: 180px;
  }
  .course {
    margin-bottom: 70px;
  }
  .course__grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .course__title {
    font-size: 1.8rem;
  }
  .course__text {
    font-size: 1.35rem;
  }
  .course__actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .program {
    padding: 22px;
  }
  .program__inner {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .program__media {
    max-width: 520px;
    margin: 0 auto;
  }
  .program__title {
    text-align: center;
    font-size: 1.6rem;
  }
  .program__text {
    text-align: left;
    font-size: 1.35rem;
    line-height: 1.9;
  }
}
/* <=640px -------------------------------------------- */
@media screen and (max-width: 640px) {
  body {
    font-size: 1.3rem !important;
    line-height: 1.65;
    letter-spacing: 0.02em;
  }
  .spbr {
    display: inline;
  }
  a {
    -webkit-tap-highlight-color: transparent;
  }
  #l-header .inner {
    padding: 12px 14px;
  }
  #l-header .logo img {
    height: 50px;
  }
  .hamburger {
    top: 12px;
    right: 12px;
    width: 50px;
    height: 50px;
  }
  .hamburger span {
    width: 24px;
  }
  .menu ul {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .menu li a {
    font-size: 1.1rem;
    letter-spacing: 0.02em;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 8px 6px;
    text-align: center;
  }
  #slideshow .fv-center {
    padding: 0 14px;
  }
  #slideshow .fv-logo img {
    max-width: 210px;
    width: 60%;
  }
  #slideshow .fv-catch {
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    line-height: 1.65;
  }
  .page-title {
    height: 240px;
  }
  .page-title__inner {
    padding: 0 14px;
  }
  .page-title__en {
    font-size: 2.8rem;
    letter-spacing: 0.07em;
  }
  .page-title__ja {
    font-size: 1.3rem;
  }
  .breadcrumb {
    padding: 8px 0;
  }
  .breadcrumb__inner {
    padding: 0 14px;
    font-size: 1.05rem;
    letter-spacing: 0.05em;
  }
  .footer {
    padding: 48px 0 48px;
  }
  .footer__brand {
    flex-direction: column;
    gap: 8px;
  }
  .footer__logo {
    height: 54px;
  }
  .footer__name {
    font-size: 1.45rem;
  }
  .footer__info {
    font-size: 1.3rem;
    margin-bottom: 18px;
  }
  .footer__copy {
    font-size: 1rem;
  }
  .single01,
  .single03 {
    padding: 48px 20px;
  }
  .single02 {
    width: calc(100% - 28px);
    padding: 48px 20px;
  }
  .margin-top {
    margin-top: -48px;
  }
  .margin-bottom {
    margin-bottom: -48px;
  }
  .column2,
  .column3 {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  /* title
  -------------------------------------------------------------------------*/
  .title {
    font-size: 2.6rem;
  }
  .section_title {
    font-size: 1.5rem;
    padding: 12px 0 10px;
    margin-bottom: 20px;
    border-bottom-width: 1.5px;
  }
  .section_title::before {
    height: 2px;
    background-image: repeating-linear-gradient(to right, #aecda1, #aecda1 1px, transparent 1px, transparent 3px);
  }
  .corner_title {
    font-size: 1.3rem;
    padding: 4px 14px;
  }
  .corner_title::before,
  .corner_title::after {
    width: 10px;
    border-left-width: 1px;
    border-right-width: 1px;
    border-top-width: 1px;
    border-bottom-width: 1px;
  }
  .emphasis_title {
    font-size: 1.5rem;
    margin-bottom: 14px;
    line-height: 1.4;
  }
  /* table
  -------------------------------------------------------------------------*/
  .table_design01,
  .table_design02 {
    font-size: 1.2rem;
  }
  .table_design01 tr,
  .table_design02 tr {
    margin-bottom: 14px;
  }
  .table_design01 th,
  .table_design01 td,
  .table_design02 th,
  .table_design02 td {
    padding: 0.7em 0.9em;
  }
  /* contents
  -------------------------------------------------------------------------*/
  　.message {
    padding-bottom: 100px;
  }
  .message::before,
  .message::after {
    width: 130px;
    height: 130px;
    bottom: 14px;
  }
  .message__inner {
    padding: 0 14px;
  }
  .message__label {
    font-size: 2.6rem;
  }
  .message__title {
    font-size: 1.6rem;
  }
  .message__text p {
    margin-bottom: 18px;
  }
  .service__grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .service__badge {
    top: -10px;
    right: -10px;
    width: 52px;
    height: 52px;
    font-size: 1.1rem;
  }
  .service__card:nth-child(3) {
    grid-column: auto;
    width: 100%;
    margin: 0;
  }
  .service__title {
    font-size: 2.6rem;
    letter-spacing: 0.06em;
  }
  .service__thumb {
    height: 120px;
  }
  .service__btn {
    width: 100%;
    max-width: 260px;
  }
  .news__head {
    margin-bottom: 26px;
  }
  .news__title {
    font-size: 2.6rem;
  }
  .news__list {
    padding: 0 14px;
  }
  .news__item {
    grid-template-columns: 1fr;
    grid-template-areas: "date" "main";
    row-gap: 8px;
    padding: 14px 0;
  }
  .news__date {
    font-size: 1.05rem;
  }
  .news__text {
    padding-right: 38px;
    line-height: 1.6;
  }
  .news__arrow {
    width: 26px;
    height: 26px;
    font-size: 2rem;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .news__more {
    padding: 0 14px;
    margin-top: 12px;
  }
  .news__morelink {
    font-size: 1.15rem;
    letter-spacing: 0.1em;
  }
  .blog__head {
    margin-bottom: 26px;
  }
  .blog__title {
    font-size: 2.6rem;
    letter-spacing: 0.06em;
  }
  .blog__grid,
  .blog__grid--3col {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .blog__card {
    border-radius: 18px;
  }
  .blog__body {
    padding: 14px 14px 16px;
  }
  .blog__text {
    white-space: normal;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
  }
  .blog__morelink {
    font-size: 1.15rem;
    letter-spacing: 0.1em;
  }
  .company-origin {
    padding: 48px 0;
  }
  .company-origin__inner {
    padding: 0 14px;
  }
  .company-origin__title {
    font-size: 1.9rem;
    margin-bottom: 18px;
  }
  .company-origin__text p {
    font-size: 1.4rem;
    line-height: 1.8;
    margin-bottom: 14px;
  }
  .company-origin__logo {
    margin-top: 28px;
  }
  .company-origin__logo img {
    max-width: 220px;
  }
  .aim {
    padding: 28px 0;
  }
  .aim__inner {
    padding: 0 14px;
  }
  .aim__title__big {
    font-size: 2rem;
    margin-bottom: 18px;
  }
  .aim__row {
    gap: 14px;
    padding: 20px 0;
  }
  .aim__row:nth-of-type(-n+3) {
    padding-bottom: 20px;
  }
  .aim__eyebrow {
    font-size: 2.8rem;
    letter-spacing: 0.08em;
  }
  .aim__title {
    font-size: 1.4rem;
    letter-spacing: 0.08em;
    margin-bottom: 10px;
  }
  .aim__desc {
    line-height: 1.8;
  }
  .aim__desc span {
    font-size: 1.1rem;
  }
  .aim__media img {
    max-width: 320px;
  }
  .about_message {
    padding: 48px 0;
    background-position: center;
  }
  .about_message__inner {
    padding: 0 14px;
  }
  .about_message__eyebrow {
    font-size: 2.6rem;
    letter-spacing: 0.06em;
  }
  .about_message__title {
    font-size: 1.6rem;
    letter-spacing: 0.06em;
    margin-bottom: 16px;
  }
  .about_message__text p {
    margin-bottom: 16px;
  }
  .self_ri__inner {
    padding: 0 14px;
  }
  .self_ri__card {
    padding: 26px 18px;
    gap: 22px;
    border-radius: 8px;
  }
  .self_ri__logoFrame {
    width: 200px;
  }
  .self_ri__title {
    font-size: 1.8rem;
    letter-spacing: 0.06em;
    margin-bottom: 16px;
  }
  .self_ri__text {
    font-size: 1.4rem;
    line-height: 1.8;
  }
  .company {
    padding: 36px 14px;
  }
  .company__title {
    font-size: 2.4rem;
    letter-spacing: 0.08em;
  }
  .company__sub {
    font-size: 1.4rem;
    margin-bottom: 24px;
  }
  .company__row {
    padding: 16px 0;
  }
  .company__office {
    font-size: 1.4rem;
  }
  .company__addr {
    font-size: 1.3rem;
    line-height: 1.6;
  }
  .profile {
    padding: 40px 14px;
  }
  .profile__photo {
    width: 200px;
  }
  .profile__label {
    font-size: 1.5rem;
  }
  .profile__text,
  .profile__list {
    font-size: 1.3rem;
    line-height: 1.7;
  }
  .profile__section {
    margin-top: 18px;
  }
  .access {
    padding: 0 14px;
  }
  .access__map {
    border-radius: 4px;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.06);
  }
  .access__map iframe {
    height: 240px;
  }
  .access__btn {
    min-width: 180px;
    height: 40px;
    padding: 0 22px;
    font-size: 1.2rem;
    margin-bottom: 24px;
  }
  .route {
    margin-bottom: 24px;
  }
  .route li {
    margin: 8px 0 0 24px;
    font-size: 1.3rem;
  }
  .route > li::before {
    width: 18px;
    height: 18px;
    font-size: 11px;
    line-height: 18px;
    left: -24px;
  }
  .route-image {
    max-width: 100%;
  }
  .contact {
    padding: 28px 0;
  }
  .contact__inner {
    padding: 0 14px;
  }
  .contact__text p {
    margin-bottom: 16px;
    text-align: left;
  }
  .contact__actions {
    margin-top: 20px;
  }
  .contact__submit {
    min-width: 200px;
    height: 44px;
    padding: 0 28px;
    font-size: 1.3rem;
  }
  .privacy__inner {
    padding: 22px 18px;
    border-radius: 14px;
  }
  .privacy__heading {
    font-size: 1.4rem;
    letter-spacing: 0.04em;
  }
  .privacy__body {
    font-size: 1.3rem;
    line-height: 1.85;
  }
  .privacy__body ul {
    padding-left: 1.1em;
  }
  .new_list {
    padding: 34px 14px 60px;
  }
  .new_list__main {
    padding: 32px 16px 44px;
  }
  .new_list__title {
    font-size: 2.3rem;
    letter-spacing: 0.08em;
  }
  .new_list__title span {
    font-size: 1.2rem;
    letter-spacing: 0.08em;
  }
  .new_list__archive a {
    padding: 10px 14px;
    font-size: 1.15rem;
  }
  .new_list__pager {
    margin-top: 28px;
    gap: 10px;
    flex-direction: column;
    align-items: stretch;
  }
  .new_list__pagerBtn {
    width: 100%;
    min-width: 0;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .article__content {
    margin-top: 24px;
  }
  .article__date {
    font-size: 1.1rem;
  }
  .article__title {
    font-size: 1.6rem;
    line-height: 1.6;
    margin-top: 8px;
  }
  .group {
    padding: 30px 0 50px;
  }
  .group__lead {
    padding: 0 16px;
    margin-bottom: 24px;
    line-height: 1.9;
  }
  .group__card {
    padding: 24px 18px;
  }
  .group__cardTitle {
    font-size: 1.6rem;
    padding-left: 22px;
  }
  .group__cardTitle::before {
    width: 12px;
  }
  .group__minibox h2 {
    font-size: 1.4rem;
  }
  .group__subbox {
    font-size: 1.3rem;
    border-width: 2px;
  }
  .group__list li {
    line-height: 1.8;
  }
  .mindfulness__inner {
    width: calc(100% - 28px);
  }
  .mindfulness__title {
    font-size: 1.9rem;
  }
  .mindfulness__photo--main {
    border-radius: 16px;
  }
  .mindfulness__photo--sub {
    width: 140px;
    border-radius: 16px;
    left: 10px;
    bottom: 10px;
  }
  .mindfulness__card p {
    margin-bottom: 16px;
    line-height: 1.9;
  }
  .course {
    margin-bottom: 60px;
  }
  .course__body {
    padding: 18px 16px 14px;
  }
  .course__footer {
    padding: 14px 16px 18px;
  }
  .course__title {
    font-size: 1.6rem;
    line-height: 1.4;
  }
  .course__text {
    font-size: 1.3rem;
  }
  /* CTAは2列＋1列（中央） */
  .course__actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .course__btn {
    height: 42px;
    font-size: 1.3rem;
  }
  .course__btn--solid {
    grid-column: 1/-1; /* 最重要ボタンを全面に */
  }
  .program {
    padding: 18px 16px;
  }
  .program__media img {
    width: 70%;
    display: block;
    margin: 0 auto;
  }
  .program__title {
    font-size: 1.5rem;
    margin-bottom: 12px;
  }
  .program__text {
    font-size: 1.3rem;
    line-height: 1.85;
  }
}/*# sourceMappingURL=smartphone.css.map */