@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/
/* =====================================================
   GLOBAL BASE
===================================================== */

/* overscroll対策（iOS下ピコン防止） */
html, body{
  overscroll-behavior-y: none;
}

/* =====================================================
   ROOT TOKENS（唯一の定義元）
===================================================== */
:root{
  /* text */
  --text-main: #2f3e42;
  --text-muted: rgba(47,62,66,.72);

  /* background */
  --light-beige: #f7f5f2;
  --soft-beige:  #f3f1ec;

  /* surfaces */
  --line: rgba(47,62,66,.18);
  --panel: rgba(255,255,255,.82);
  --radius: 16px;

  /* section titles */
  --title-en: 2.2rem;
  --title-ja: 0.95rem;
  --title-gap: 56px;

  /* btn-line */
  --btn-line-color: #3d5155;
  --btn-min: 300px;
  --btn-pad-y: 20px;
  --btn-pad-x: 64px;
  --btn-fs: 15px;
}

/* =====================================================
   Typography
===================================================== */
body{
  font-family: "Zen Kaku Gothic New",
               -apple-system,
               BlinkMacSystemFont,
               sans-serif;
  font-weight: 400;
  line-height: 1.8;
  color: var(--text-main);
}

h1,h2,h3,h4,h5,h6{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  line-height: 1.35;
}

.post_content h2,
.post_content h3,
.post_content h4,
.post_content dt {
  font-weight: 400;
}


/* SP：改行整理（必要なときだけ使うならOK） */
@media (max-width: 767px){
  br{ display: none; }
}

/* =====================================================
   GLOBAL LAYOUT RESET
===================================================== */
.home #content.l-content,
.subpage #content.l-content{
  padding-top: 0 !important;
  margin-bottom: 0 !important;
}

#before_footer_widget,
#before_footer_widget *{
  margin: 0 !important;
  padding: 0 !important;
}

/* =====================================================
   TOP｜COMMON BASE（ONE SOURCE）
===================================================== */
.home .top-section{
  padding: 96px 24px 88px;
}
@media (max-width: 767px){
  .home .top-section{
    padding: 64px 16px;
  }
}

.home .top-container{
  max-width: 1040px;
  margin: 0 auto;
  padding-inline: 16px;
}

/* small base */
.btn-line--sm{
  min-width: 200px;
  padding: 12px 32px;
  font-size: 13px;
}

/* TOP：more buttons */
.home :is(
  .top-news-more,
  .top-about-btn,
  .voice-more,
  .top-message-more,
  .top-journal-btn
) .btn-line.btn-line--sm{
  min-width: 220px;
  padding: 14px 36px;
  font-size: 14px;
  border-color: var(--text-main);
  color: var(--text-main);
  background: transparent;
  box-shadow: none;
}

@media (max-width: 767px){
  .home :is(
    .top-news-more,
    .top-about-btn,
    .voice-more,
    .top-message-more,
    .top-journal-btn
  ) .btn-line.btn-line--sm{
    min-width: 240px;
    padding: 16px 36px;
    font-size: 15px;
    min-height: 44px;
  }
}




/* ===========================
   TOP｜Hero（FV）
   =========================== */

.home .c-pageTitle,
.home .p-articleHead,
.home .c-postTitle{
  display: none !important;
}

.home #content.l-content{
  padding-top: 0 !important;
}

.home #main_content .l-mainContent__inner > .post_content{
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.home .post_content > .japa-hero{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* ===========================
   Hero layout
   =========================== */

.home .japa-hero{
  position: relative;
  height: 92vh;
  min-height: 92vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

/* iOS svh 対応 */
@supports (-webkit-touch-callout: none){
  .home .japa-hero{
    min-height: 92svh;
  }
}

@media (max-width: 767px){
  .home .japa-hero{
    height: 86vh;
  }
}

/* ===========================
   Background
   =========================== */

.home .japa-hero-bg{
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    center / cover no-repeat
    url("/wp-content/uploads/2026/01/top-fs-tn.jpg");
  background-color: var(--bg-soft, #F7F5F2);
}

@media (max-width: 767px){
  .home .japa-hero-bg{
    background-image: url("/wp-content/uploads/2026/01/top-fs-ps-tn2.jpg");
  }
}

/* ===========================
   Copy block
   =========================== */

.home .japa-hero-copy{
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding-left: clamp(16px, 7vw, 96px);
  padding-right: clamp(16px, 7vw, 96px);
}

/* PC */
@media (min-width: 768px){
  .home .japa-hero-copy{
    padding-top: clamp(40px, 6vh, 80px);
  }
}

@media (max-width: 767px){
  .home .japa-hero-copy{
    --fv-lift: -96px;
    transform: translateY(var(--fv-lift));
    padding: clamp(24px, 5vh, 44px) 18px 72px;
  }
}

/* ===========================
   Text
   =========================== */

.home .japa-hero-lead{
  margin: 0 0 18px;
}

.home .japa-hero-lead img{
  display: block;
  width: clamp(320px, 42vw, 460px);
  max-width: 100%;
  height: auto;
}

@media (max-width: 767px){
  .home .japa-hero-lead img{
    width: clamp(260px, 78vw, 360px);
  }
}

.home .japa-hero-sub{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: clamp(16px, 2vw, 22px);
  line-height: 1.9;
  letter-spacing: .06em;
  color: rgba(255,255,255,.92);
  margin: 0 0 28px;
}

.home .japa-hero-accent{
  color: #d6b15a;
}

/* ===========================
   Button（FV専用）
   =========================== */

.home .japa-hero .japa-hero-btn,
.home .japa-hero .japa-hero-btn:visited{
  color: rgba(255,255,255,.98) !important;
  border-color: rgba(255,255,255,.78) !important;
  text-decoration: none !important;
}

.home .japa-hero .japa-hero-btn:hover{
  color: #fff !important;
  border-color: rgba(255,255,255,.98) !important;
}

.home .japa-hero .japa-hero-btn::after{
  background-color: rgba(255,255,255,.9);
}

/* ===============================
   admin-bar
   =============================== */

@media (max-width: 767px){
  .admin-bar .l-header,
  .admin-bar .l-fixHeader{
    top: 46px !important;
    transform: none !important;
    -webkit-transform: none !important;
  }
}



/* ==============================
   TOP｜NEWS
   ============================== */

.home .top-news{
  --news-wrap: 840px;
  --news-pad-x: 16px;

  max-width: var(--news-wrap);
  margin: 0 auto;

  padding-inline: var(--news-pad-x);
  padding-top: 64px;
  padding-bottom: 24px;
}

@media (min-width: 768px){
  .home .top-news{
    padding-top: 88px;
    padding-bottom: 28px;
  }
}

.home .top-news-list{
  max-width: var(--news-wrap);
  margin-left: auto;
  margin-right: auto;
  padding-inline: var(--news-pad-x);

  list-style: none;
  margin: 0;
  padding-top: 0;
  padding-bottom: 0;
  border-top: 1px solid #e3e3e3;
}

.home .top-news-more{
  max-width: var(--news-wrap);
  margin: 40px auto 80px;
  text-align: center;
  padding-inline: 0;
}

.home .top-news-item{
  display: grid;
  grid-template-columns: 110px 130px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid #f0f0f0;
  font-size: var(--fs-small);
}

.home .top-news-date{ color: var(--text-muted); }

.home .top-news-cat{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  font-size: 11px;
  border-radius: 999px;
  border: 1px solid #d3d9d3;
  color: #55615a;
}

.home .top-news-title{
  text-decoration: none;
  color: var(--text-main);
}
.home .top-news-title:hover{ text-decoration: underline; }

/* SP */
@media (max-width: 767px){
  .home .top-news-item{
    font-size: 14px;
    grid-template-columns: 90px 100px 1fr;
    gap: 8px;
    padding: 8px 0;
  }
  .home .top-news-cat{ font-size: 11px; padding: 3px 8px; }
  .home .top-news-title{ font-size: 14px; line-height: 1.75; }
}


/* ===============================
   TOP｜ABOUT（NO PARALLAX / STABLE）
   =============================== */

.home{
  --about-pad-top-pc: 180px;
  --about-pad-bottom-pc: 240px;

  --about-pad-top-pc-lg: 140px;
  --about-pad-bottom-pc-lg: 160px;

  --about-pad-top-sp: 96px;
  --about-pad-bottom-sp: clamp(300px, 52vw, 520px);
}

@media (max-width: 767px){
  .home{
  --about-pad-bottom-sp: clamp(180px, 34vw, 480px);
  }
  .home .top-about .about-text{
    margin-bottom: 12px;
  }
  .home .top-about .top-about-bg{
    background-position: center 110%;
  }
}


/* ===============================
   Layout
   =============================== */

.home .top-about{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);

  text-align: center;

  display: flex;
  flex-direction: column;
  justify-content: flex-start;

  padding: var(--about-pad-top-pc) 16px var(--about-pad-bottom-pc);

  position: relative;
  overflow: hidden;
  background: none;

  min-height: 720px;
}

.home .top-about .top-about-bg{
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;

  background-image: url('/wp-content/uploads/2025/12/about-bg.jpg');
  background-repeat: no-repeat;
  background-position: center bottom;

  background-size: 100% auto;
}

.home .top-about .top-about-inner{
  width: min(760px, 92vw);
  margin-inline: auto;
  position: relative;
  z-index: 1;
}

/* ===============================
   Typography
   =============================== */

.home .top-about .section-title-ja{
  margin-bottom: 10px;
}

.home .top-about .about-catch{
  font-family: "Shippori Mincho", serif;
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  color: #3d5155;
  line-height: 1.6;
  margin: 32px auto 18px;
}

.home .top-about .about-text{
  max-width: 720px;
  width: 100%;
  text-align: center;
  margin: 0 auto 36px;
  font-size: 1rem;
  line-height: 2.1;
  letter-spacing: 0.02em;
  color: #555;
}

@media (min-width: 768px){
  .home .top-about .about-catch .sp-br{ display:none; }
  .home .top-about .about-text br{ display:none; }
}

/* ===============================
   TOP｜ABOUT Button
   =============================== */

.home .top-about .top-about-btn{
  display: flex;
  justify-content: center;
  margin-top: 6px;
}

.home .top-about .top-about-btn .btn-line{
  background: transparent;
  border-color: #2f3e42;
  color: #2f3e42;
  box-shadow: none;
}

@media (min-width: 768px){
  .home .top-about .top-about-btn .btn-line{
    background: rgba(255,255,255,.18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 10px 28px rgba(0,0,0,.10);
  }

  .home .top-about .top-about-btn .btn-line:hover{
    background: rgba(255,255,255,.26);
    border-color: #2f3e42;
    color: #2f3e42;
  }

  @supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))){
    .home .top-about .top-about-btn .btn-line{
      background: rgba(255,255,255,.26);
    }
  }
}

/* ===============================
   PC large
   =============================== */

@media (min-width: 1024px){
  .home .top-about{
    min-height: 800px;
    padding-top: var(--about-pad-top-pc-lg);
    padding-bottom: var(--about-pad-bottom-pc-lg);
  }
}

/* ===============================
   SP
   =============================== */

@media (max-width: 767px){
  .home .top-about{
    padding-top: var(--about-pad-top-sp);
    padding-bottom: var(--about-pad-bottom-sp);
    min-height: auto;
  }

  .home .top-about .top-about-bg{
    background-image: url('/wp-content/uploads/2025/12/about-bg_sp.jpg');
    background-position: center bottom;
    background-size: cover;
  }

  .home .top-about .top-about-inner{
    max-width: 640px;
    margin: 0 auto;
    padding: 0 16px;
  }

  .home .top-about .about-catch{
    font-size: 1.3rem;
    line-height: 1.75;
    margin: 0 auto 10px;
  }

  .home .top-about .about-text{
    max-width: 32em;
    font-size: 1rem;
    line-height: 2.0;
    margin: 0 auto 18px;
    padding: 0 10px;
    word-break: break-word;
  }

  .home .top-about .about-catch .q-open,
  .home .top-about .about-catch .q-close{
    display: none;
  }
}




/* ===========================
   TOP｜Activity Fields
   =========================== */

.home .top-fields{
  --fields-bg: #f7f5f2;
  --fields-gap: 32px;
  --fields-gap-sp: 24px;

  --field-thumb-ratio: 62.5%;
  --field-thumb-bg: #e8ece8;

  --field-ink: #2f3e42;
  --field-link: #3d5155;
  --field-muted: var(--text-muted, rgba(47,62,66,.72));

  --field-line: rgba(61,81,85,.26);
  --field-line-hover: rgba(47,62,66,.70);

  background-color: var(--fields-bg);
}

.home .top-fields.top-section{
  padding-top: 72px;
  padding-bottom: 56px;
}
@media (max-width: 767px){
  .home .top-fields.top-section{
    padding-top: 56px;
    padding-bottom: 40px;
  }
}

/* grid */
.home .top-fields .fields-grid{
  margin-top: 32px;
  display: grid;
  gap: var(--fields-gap);
}

@media (min-width: 1024px){
  .home .top-fields .fields-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (min-width: 768px) and (max-width: 1023px){
  .home .top-fields .fields-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 767px){
  .home .top-fields .fields-grid{
    grid-template-columns: 1fr;
    gap: var(--fields-gap-sp);
    margin-top: 24px;
  }
}

/* card */
.home .top-fields .field-card{
  padding: 20px 20px 26px;
  position: relative;
  background-color: transparent;
  box-shadow: none;
  transform: translateY(0);
  border-radius: 8px;
  transition: background-color .3s ease, box-shadow .3s ease, transform .3s ease;
}

@media (hover:hover) and (pointer:fine){
  .home .top-fields .field-card:hover{
    background-color: rgba(255,255,255,0.70);
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    transform: translateY(-1px);
  }
}

@media (max-width: 767px){
  .home .top-fields .field-card{
    background-color: rgba(255,255,255,0.62);
    box-shadow: 0 10px 30px rgba(0,0,0,0.04);
    transform: none;
  }
}

/* thumb */
.home .top-fields .field-thumb{
  width: 100%;
  padding-top: var(--field-thumb-ratio);
  background: center/cover no-repeat;
  background-color: var(--field-thumb-bg);
  border-radius: 0;
  margin-bottom: 16px;
}

/* bg images */
.home .top-fields .field-living{ background-image: url("/wp-content/uploads/2026/01/field-living.jpg"); }
.home .top-fields .field-education{ background-image: url("/wp-content/uploads/2026/01/field-education.jpg"); }
.home .top-fields .field-corporate{ background-image: url("/wp-content/uploads/2026/01/field-corporate.jpg"); }
.home .top-fields .field-salon{ background-image: url("/wp-content/uploads/2026/01/field-salon.jpg"); }
.home .top-fields .field-personal{ background-image: url("/wp-content/uploads/2026/01/field-personal.jpg"); }

/* title / text */
.home .top-fields .field-title{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 18px;
  letter-spacing: 0.18em;
  margin: 0 0 10px;
  color: var(--field-ink);
}

.home .top-fields .field-text{
  font-size: 14px;
  line-height: 1.9;
  color: var(--field-muted);
  margin: 0 0 16px; 
}

/* ===============================
   more
   =============================== */
.home .top-fields .field-more{
  margin-top: 2px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

.home .top-fields .field-more::before{
  content: "";
  flex-grow: 1;
  height: 1px;
  background-color: var(--field-line);
}

.home .top-fields .field-more-line{
  display: none !important;
}

/* more link */
.home .top-fields .field-more-link{
  position: relative;
  display: inline-block;
  font-family: "Cormorant Garamond", serif;
  font-size: 15px;
  letter-spacing: 0.16em;
  text-transform: lowercase;
  text-decoration: none;
  color: var(--field-link);
  padding-right: 44px;
}

.home .top-fields .field-more-link::after{
  content:"";
  position:absolute;
  top:50%;
  right:0;
  width:32px;
  height:1px;
  background-color: var(--field-line);
  opacity:0.9;
  transform-origin:left center;
  transform: translateY(-50%) scaleX(0);
  transition: transform .35s cubic-bezier(0.4, 0, 0.2, 1),
              background-color .25s ease,
              opacity .25s ease;
}

@media (max-width: 767px){
  .home .top-fields .field-more-link::after{ width: 24px; }
}

@media (hover:hover) and (pointer:fine){
  .home .top-fields .field-card:hover .field-more-link::after{
    transform: translateY(-50%) scaleX(1);
    background-color: var(--field-ink);
    opacity: 1;
  }
  .home .top-fields .field-card:hover .field-more::before{
    background-color: var(--field-line-hover);
  }
}

@media (max-width: 767px){
  .home .top-fields .field-more-link::after{
    transform: translateY(-50%) scaleX(1);
    background-color: rgba(47,62,66,.70);
  }
  .home .top-fields .field-more::before{
    background-color: rgba(61,81,85,.34);
  }
}

/* SP type */
@media (max-width: 767px){
  .home .top-fields .field-title{ font-size: 1.1rem; }
  .home .top-fields .field-text{
    font-size: 1rem;
    line-height: 1.9;
  }
}




/* ===========================
   TOP｜Our Strengths（FINAL / replace）
   =========================== */

.home .top-strengths{
  --st-bg: #e6e4df;

  --st-ink-main: #2f3e42;
  --st-ink-accent: #336464;
  --st-ink-muted: rgba(61,81,85,.85);

  --st-card-bg: #ffffff;

  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background: var(--st-bg);
}

.home .top-strengths.top-section{
  padding-top: 0;
  padding-bottom: 0;
}

/* container */
.home .top-strengths .top-container{
  max-width: 1040px;
  margin: 0 auto;
  padding: 88px 16px 96px;
}

.home .top-strengths .section-title-ja{
  margin-bottom: 52px;
}

/* intro */
.home .top-strengths .strengths-intro{
  text-align: center;
  margin: 0 0 56px;
}
.home .top-strengths .strengths-catch{
  font-family: "Shippori Mincho", serif;
  font-size: 1.25rem;
  letter-spacing: .14em;
  line-height: 1.6;
  margin: 0 0 12px;
  color: var(--st-ink-main);
}
.home .top-strengths .strengths-lead{
  margin: 0 auto;
  max-width: 760px;
  font-size: 1rem;
  line-height: 2.0;
  color: var(--st-ink-muted);
}

/* list */
.home .top-strengths .strengths-list{
  display: grid;
  gap: 42px;
}

.home .top-strengths .strength-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.home .top-strengths .strength-row.is-reverse .strength-card{ order: 2; }
.home .top-strengths .strength-row.is-reverse .strength-media{ order: 1; }

/* card */
.home .top-strengths .strength-card{
  background: var(--st-card-bg);
  padding: 44px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* media */
.home .top-strengths .strength-media{
  min-height: 100%;
}
.home .top-strengths .strength-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* head */
.home .top-strengths .strength-head{
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 0 0 22px;
}

.home .top-strengths .strength-icon{
  width: 68px;
  height: 68px;
  border-radius: 999px;
  background: var(--st-ink-main);
  color: #fff;
  display: grid;
  place-items: center;
  flex: 0 0 68px;
}

.home .top-strengths .strength-icon svg{
  width: 28px;
  height: 28px;
  color: #fff;
}

/* text */
.home .top-strengths .strength-title{
  margin: 0;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: .14em;
  line-height: 1.25;
  color: var(--st-ink-main);
}

.home .top-strengths .strength-sub{
  margin: 0 0 12px;
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: .08em;
  color: var(--st-ink-accent);
}

.home .top-strengths .strength-desc{
  margin: 0;
  font-size: 1rem;
  line-height: 2.0;
  color: var(--st-ink-muted);
}

.home .top-strengths .top-about-btn{
  margin-top: 40px;
  text-align: center;
}

/* ---------- responsive ---------- */
@media (max-width: 1023px){
  .home .top-strengths .top-container{
    padding: 72px 16px 80px;
  }
}

@media (max-width: 767px){
  .home .top-strengths .top-container{
    padding: 56px 16px 64px;
  }

  .home .top-strengths .section-title-ja{
    margin-bottom: 24px;
  }

  .home .top-strengths .strengths-intro{
    margin-bottom: 28px;
  }

  .home .top-strengths .strength-row{
    grid-template-columns: 1fr;
  }

  .home .top-strengths .strength-media{ order: 1; }

  .home .top-strengths .strength-card{
    order: 2;
    padding: 22px 18px 24px;

    background: rgba(255,255,255,0.92);
  }

  .home .top-strengths .strength-head{
    margin-bottom: 16px;
    gap: 12px;
  }

  .home .top-strengths .strength-icon{
    width: 56px;
    height: 56px;
    flex: 0 0 56px;
  }

  .home .top-strengths .strength-icon svg{
    width: 24px;
    height: 24px;
  }

  .home .top-strengths .strength-title{
    font-size: 1.35rem;
    letter-spacing: .12em;
  }

  .home .top-strengths .strength-sub{
    font-size: 1rem;
  }

  .home .top-strengths .strength-desc{
    font-size: 1rem;
  }

  .home .top-strengths .top-about-btn{
    margin-top: 28px;
  }
}


/* ===========================
   TOP｜VOICE
   =========================== */

.home .voiceGrid{
  --voice-ink: var(--text-main, #2f3e42);
  --voice-ink-strong: rgba(47,62,66,.92);
  --voice-ink-muted: rgba(47,62,66,.62);
  --voice-line: rgba(47,62,66,.28);

  margin-top: 32px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

/* SP：1カラム */
@media (max-width: 767px){
  .home .voiceGrid{
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* ---------------------------
   Card
--------------------------- */

.home .voiceCard{
  background: rgba(230,228,223,0.70);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  padding: 26px 28px 24px;
  box-shadow: 0 10px 26px rgba(0,0,0,0.04);
}

@media (max-width: 767px){
  .home .voiceCard{
    padding: 20px 18px 18px;
    background: rgba(230,228,223,0.82);
  }
}

/* ---------------------------
   Quote
--------------------------- */

.home .voiceIcon{
  font-family: "Cormorant Garamond", serif;
  font-size: 34px;
  line-height: 1;
  letter-spacing: .08em;
  color: var(--voice-ink);
  opacity: .85;
  margin-bottom: 14px;
}

.home .voiceIcon::before{
  content: "“";
  display: inline-block;
  transform: translateY(-2px);
}

/* ---------------------------
   Text
--------------------------- */

.home .voiceText{
  margin: 0 0 18px;
  font-size: 1rem;
  line-height: 1.9;
  color: var(--voice-ink-strong);
}

.home .voiceRule{
  height: 1px;
  background: var(--voice-line);
  margin: 18px 0 16px;
}

.home .voiceName{
  margin: 0 0 6px;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: .06em;
  color: var(--voice-ink-strong);
}

.home .voiceMeta{
  margin: 0;
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: .06em;
  color: var(--voice-ink-muted);
}

.home .voice-more{
  margin-top: 32px;
  text-align: center;
}

@media (max-width: 767px){
  .home .voice-more{
    margin-top: 24px;
  }
}

.home .voiceChips{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 12px;
}

.home .voiceChip{
  display: inline-block;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: .06em;
  line-height: 1.2;
  color: var(--voice-ink-strong);
  background: rgba(255,255,255,.38);
  border: 1px solid rgba(47,62,66,.18);
  white-space: nowrap;
}

.home .voiceIcon{
  opacity: .75;
}

.home .voiceText.is-clamp{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-line-clamp: 3;
}

@media (max-width: 767px){
  .home .voiceText.is-clamp{
    -webkit-line-clamp: 4;
  }
}

.home .voiceMeta{
  font-weight: 700;
}


/* ===========================
   TOP｜MESSAGE
   =========================== */

.home .top-message{
  --msg-pad-top: 48px;
  --msg-card-gap: 48px;
  --msg-card-pad: 56px;

  --msg-photo-size: 250px;

  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);

  background: url("/wp-content/uploads/2026/01/top-message-bg.jpg")
    center / cover no-repeat;

  padding-top: var(--msg-pad-top);
}

.home .top-message-card{
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: var(--msg-card-gap);
  align-items: center;

  background: rgba(255,255,255,0.8);
  padding: var(--msg-card-pad);
  margin: 0 auto;

  box-shadow: 0 16px 40px rgba(0,0,0,0.06);
}

.home .top-message-photo{
  justify-self: end;
  width: var(--msg-photo-size);
  height: var(--msg-photo-size);
  border-radius: 50%;
  overflow: hidden;
  background: #e6ebe3;
}

.home .top-message-photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home .top-message-sign{
  margin-top: 24px;
  text-align: right;
}

.home .top-message-more{
  margin-top: 40px;
  text-align: center;
}

/* SP */
@media (max-width: 1023px){
  .home .top-message{
    --msg-card-gap: 28px;
    --msg-card-pad: 40px 28px;
  }

  .home .top-message-card{
    grid-template-columns: 1fr;
  }

  .home .top-message-photo{
    justify-self: center;
  }

  .home .top-message-text,
  .home .top-message-sign{
    text-align: center;
  }
}


/* ===========================
   TOP｜Aroma Journal Slider（FINAL）
   =========================== */

.home .top-journal{

  /* spacing */
  --tj-gap-title-to-slider: 28px;
  --tj-gap-slider-to-btn: 28px;

  /* wrapper */
  --aj-wrap: 960px;

  /* card */
  --aj-card-radius: 8px;
  --aj-card-pad-top: 28px;
  --aj-card-pad-x: 16px;
  --aj-card-pad-btm: 18px;
  --aj-card-minh: 360px;
  --aj-card-gap: 14px;
  --aj-card-shadow: 0 14px 40px rgba(0,0,0,0.10);

  /* typography */
  --aj-title-size: 20px;
  --aj-sub-size: 14px;
  --aj-date-size: 12px;
  --aj-theme-size: 12px;

  /* nav */
  --aj-nav-size: 44px;
  --aj-nav-bg: rgba(255,255,255,0.65);
  --aj-nav-border: rgba(0,0,0,0.22);
  --aj-nav-shadow: 0 4px 14px rgba(0,0,0,0.12);
  --aj-nav-blur: 4px;
  --aj-nav-ink: rgba(0,0,0,0.75);
  --aj-nav-hover: #3d5155;
  --aj-nav-hover-ink: #f7f5f2;

  /* thumb */
  --aj-thumb-ratio: 4 / 3;
  --aj-thumb-empty: #e9ece7;

  position: relative;
}

/* title */
.home .top-journal .section-title-ja{
  margin-bottom: 0;
}

/* wrap */
.home .top-journal .aj-wrap{
  width: 100%;
  max-width: var(--aj-wrap);
  margin: 0 auto;
}

/* slidesPerView:auto */
.home .top-journal .swiper-slide.aj-card{
  width: clamp(280px, 78vw, 380px);
}
@media (min-width: 768px){
  .home .top-journal .swiper-slide.aj-card{
    width: 340px;
  }
}
@media (min-width: 1024px){
  .home .top-journal .swiper-slide.aj-card{
    width: 360px;
  }
}


/* ===========================
   SP
   =========================== */
@media (max-width: 767px){
  .home .top-journal .top-container{
    padding-inline: 0;
  }

  .home .top-journal .section-title-en,
  .home .top-journal .section-title-ja{
    padding-inline: 16px;
  }

  .home .top-journal .aj-wrap{
    padding-inline: 16px;
    max-width: none;
  }
}

/* ---------------------------
   Card
--------------------------- */

.home .top-journal .aj-card{
  display: block;
  text-decoration: none;
  color: inherit;
}

.home .top-journal .aj-cardInner{
  background: #fff;
  border-radius: var(--aj-card-radius);
  padding: var(--aj-card-pad-top)
           var(--aj-card-pad-x)
           var(--aj-card-pad-btm);

  box-shadow: var(--aj-card-shadow);
  overflow: hidden;

  min-height: var(--aj-card-minh);
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: var(--aj-card-gap);
}

/* hover */
@media (hover:hover) and (pointer:fine){
  .home .top-journal .aj-card:hover .aj-cardInner{
    transform: translateY(-2px);
    box-shadow: 0 20px 54px rgba(0,0,0,.12);
  }
}

/* ---------------------------
   Text
--------------------------- */

.home .top-journal .aj-theme{
  font-size: var(--aj-theme-size);
  letter-spacing: .08em;
  font-weight: 600;
  opacity: .85;
  margin: 0 0 10px;
}

.home .top-journal .aj-title{
  font-size: var(--aj-title-size);
  letter-spacing: .08em;
  font-weight: 600;
  margin: 0 0 6px;
}

.home .top-journal .aj-sub{
  margin: 0;
  font-size: var(--aj-sub-size);
  line-height: 1.9;
  opacity: .9;

  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.home .top-journal .aj-date{
  text-align: right;
  font-size: var(--aj-date-size);
  font-weight: 700;
  letter-spacing: .04em;
}

/* ---------------------------
   Thumb
--------------------------- */

.home .top-journal .aj-thumb{
  width: 100%;
  aspect-ratio: var(--aj-thumb-ratio);
  background: center/cover no-repeat;
}

.home .top-journal .aj-thumb--empty{
  background: var(--aj-thumb-empty);
}

/* ---------------------------
   Swiper
--------------------------- */

.home .top-journal .top-journal-slider{
  margin-top: var(--tj-gap-title-to-slider);
}

.home .top-journal .aj-swiper{
  position: relative;
  overflow: visible;
  width: 100%;
}

.home .top-journal .swiper{
  width: 100%;
}

/* nav */
.home .top-journal .aj-prev,
.home .top-journal .aj-next{
  position: absolute;
  top: 58%;
  z-index: 60;

  width: var(--aj-nav-size);
  height: var(--aj-nav-size);
  border-radius: 999px;

  background: var(--aj-nav-bg);
  border: 1px solid var(--aj-nav-border);
  box-shadow: var(--aj-nav-shadow);
  backdrop-filter: blur(var(--aj-nav-blur));

  display: flex;
  align-items: center;
  justify-content: center;

  color: var(--aj-nav-ink);
  cursor: pointer;
}

.home .top-journal .aj-prev{ left: 12px; }
.home .top-journal .aj-next{ right: 12px; }

@media (hover:hover) and (pointer:fine){
  .home .top-journal .aj-prev:hover,
  .home .top-journal .aj-next:hover{
    background: var(--aj-nav-hover);
    border-color: var(--aj-nav-hover);
    color: var(--aj-nav-hover-ink);
    transform: translateY(-1px);
  }
}

.home .top-journal .aj-prev.swiper-button-disabled,
.home .top-journal .aj-next.swiper-button-disabled{
  opacity: 0.35;
  pointer-events: none;
}

/* ---------------------------
   CTA
--------------------------- */

.home .top-journal .top-journal-btn{
  display: flex;
  justify-content: center;
  margin-top: var(--tj-gap-slider-to-btn);
}

/* ---------------------------
   SP typography & height調整
--------------------------- */

@media (max-width: 767px){
  .home .top-journal{
    --aj-title-size: 18px;
    --aj-date-size: 13px;
    --aj-theme-size: 13px;
    --aj-sub-size: 15px;
    --aj-card-minh: 380px;
  }

  .home .top-journal .aj-title{
    line-height: 1.6;
    letter-spacing: .04em;
  }
}



/* =========================
   TOP｜CTA（FINAL / REPLACE）
   ========================= */
.home .top-cta .top-container{ margin-bottom: 0; }
.home .top-cta{
  /* spacing */
  --cta-pad-y: 84px;
  --cta-pad-x: 16px;

  /* background */
  --cta-bg-img: url("/wp-content/uploads/2025/12/AdobeStock_366414708.jpeg");
  --cta-bg-pos: center;
  --cta-bg-size: cover;

  /* panel */
  --cta-panel-maxw: 1040px;
  --cta-panel-pad-y: 56px;
  --cta-panel-pad-x: 48px;
  --cta-panel-bg: rgba(255,255,255,.78);
  --cta-panel-blur: 3px;
  --cta-panel-shadow: 0 18px 50px rgba(0,0,0,.10);

  /* sheen（PC only） */
  --cta-sheen-left: -220px;
  --cta-sheen-w: 360px;
  --cta-sheen-skew: -14deg;
  --cta-sheen-bg: rgba(255,255,255,.35);

  /* text */
  --cta-lead-size: 30px;
  --cta-lead-lh: 1.4;
  --cta-lead-ls: .06em;
  --cta-lead-color: #3d5155;
  --cta-lead-mb: 24px;

  --cta-text-size: 18px;
  --cta-text-lh: 1.8;
  --cta-text-ls: .02em;
  --cta-text-color: #565656;

  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: var(--cta-pad-y) var(--cta-pad-x);
  background: var(--cta-bg-img) var(--cta-bg-pos) / var(--cta-bg-size) no-repeat;
  position: relative;
  overflow: hidden;
}

/* panel */
.home .top-cta .top-cta-inner{
  position: relative;
  max-width: var(--cta-panel-maxw);
  margin: 0 auto;
  text-align: center;
  background: var(--cta-panel-bg);
  backdrop-filter: blur(var(--cta-panel-blur));
  -webkit-backdrop-filter: blur(var(--cta-panel-blur));
  padding: var(--cta-panel-pad-y) var(--cta-panel-pad-x);
  box-shadow: var(--cta-panel-shadow);
}

/* sheen（PC only） */
.home .top-cta .top-cta-inner::before{
  content:"";
  position: absolute;
  left: var(--cta-sheen-left);
  top: 0;
  width: var(--cta-sheen-w);
  height: 100%;
  background: var(--cta-sheen-bg);
  transform: skewX(var(--cta-sheen-skew));
  pointer-events: none;
}

/* text */
.home .top-cta-lead{
  font-family: "Shippori Mincho", serif;
  font-size: var(--cta-lead-size);
  line-height: var(--cta-lead-lh);
  letter-spacing: var(--cta-lead-ls);
  color: var(--cta-lead-color);
  margin: 0 0 var(--cta-lead-mb);
}

.home .top-cta-text{
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: var(--cta-text-size);
  line-height: var(--cta-text-lh);
  letter-spacing: var(--cta-text-ls);
  color: var(--cta-text-color);
  margin: 0;
}

/* =========================
   SP（readability優先）
   ========================= */
@media (max-width: 768px){
  .home .top-cta{
    --cta-pad-y: 56px;
    --cta-pad-x: 12px;

    --cta-panel-pad-y: 32px;
    --cta-panel-pad-x: 24px;

    --cta-lead-size: 24px;
    --cta-lead-lh: 1.5;

    --cta-text-size: 16px;
    --cta-text-lh: 1.9;
  }

  .home .top-cta .top-cta-inner::before{
    display: none;
  }

  .home .top-cta .top-cta-inner{
    background: rgba(255,255,255,.92);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}

/* =========================
   reserve / contact spacing
   ========================= */
.home .top-section.top-reserve-contact{
  margin-top: 0;
  padding-top: 48px;
}
@media (max-width: 767px){
  .home .top-section.top-reserve-contact{
    padding-top: 32px;
    padding-bottom: 48px;
  }
}
.home .post_content > .top-cta{
  margin-bottom: 0 !important;
}


/* =======================================
   TOP｜09 RESERVE & CONTACT
======================================= */

.home .top-section.top-reserve-contact{
  --rc-bg: #e6e4df;
  --rc-pad-top: 96px;
  --rc-pad-btm: 120px;
  --rc-pad-x: 16px;

  --rc-maxw: 1040px;
  --rc-gap: 120px;
  --rc-divider: #d3cfc6;

  --rc-head-mb: 36px;
  --rc-btn-gap: 18px;

  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background-color: var(--rc-bg);
  padding: var(--rc-pad-top) var(--rc-pad-x) var(--rc-pad-btm);
  margin-top: 0;
}

/* 2カラム枠 */
.home .top-section.top-reserve-contact .cta-split{
  max-width: var(--rc-maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: var(--rc-gap);
  align-items: flex-start;
  position: relative;
}

.home .top-section.top-reserve-contact .cta-split::before{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  background-color: var(--rc-divider);
}

.home .top-section.top-reserve-contact .cta-split-head{
  text-align: center;
  margin-bottom: var(--rc-head-mb);
}

.home .top-section.top-reserve-contact .cta-split-head .section-title-ja{
  margin-bottom: 0;
}


.home .top-section.top-reserve-contact .cta-split-links{
  text-align: center;
  display: grid;
  row-gap: var(--rc-btn-gap);
  justify-items: center;
}

.home .top-section.top-reserve-contact .cta-split-btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-width: 320px;
  padding: 18px 48px;

  font-size: 0.9375rem;
  letter-spacing: 0.12em;
  text-decoration: none;

  border: 1px solid var(--text-main, #2f3e42);
  color: var(--text-main, #2f3e42);
  background: transparent;
  border-radius: 0;
  cursor: pointer;
  overflow: visible;

  transition: color 0.25s ease,
              border-color 0.25s ease,
              transform 0.25s ease,
              box-shadow 0.25s ease,
              background-color 0.25s ease;
}

.home .top-section.top-reserve-contact .cta-split-btn::after{
  content: "";
  position: absolute;
  top: 50%;
  left: calc(100% - 10px);
  transform: translateY(-50%);
  width: 0;
  height: 1px;
  background-color: currentColor;
  opacity: 0;
  transform-origin: left center;
  transition: width 0.35s ease, opacity 0.3s ease;
}

.home .top-section.top-reserve-contact .cta-split-btn:hover::after{
  width: 40px;
  opacity: 1;
}

.home .top-section.top-reserve-contact .cta-split-btn:hover{
  background-color: rgba(255, 255, 255, 0.4);
  box-shadow: 0 6px 20px rgba(0,0,0,0.08);
  transform: translateX(2px);
}

/* SP */
@media (max-width: 767px){
  .home .top-section.top-reserve-contact{
    --rc-pad-top: 64px;
    --rc-pad-btm: 72px;
  }

  .home .top-section.top-reserve-contact .cta-split{
    grid-template-columns: 1fr;
    row-gap: 64px;
  }

  .home .top-section.top-reserve-contact .cta-split::before{
    display: none;
  }

  .home .top-section.top-reserve-contact .cta-split-btn{
    width: 100%;
    max-width: 360px;
    min-width: 0;
  }
}

/* =======================================
   GLOBAL FOOTER（JAPA）｜FINAL
======================================= */
.home #main_content .l-mainContent__inner > .post_content{
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.japa-footer{
  font-family: "Zen Kaku Gothic New", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  color: #3d5155;
}

.japa-footer-main{
  background-color: #f7f5f2;
  padding: 72px 16px 80px;
}

.japa-footer-inner{
  width: min(1120px, 92vw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
  align-items: start;
}

.japa-footer-brand{
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.japa-footer-logo img{
  display: block;
  max-width: 150px;
  height: auto;
}

.japa-footer-tagline{
  margin: 0;
  font-family: "Shippori Mincho", serif;
  font-size: 15px;
  line-height: 2.0;
  letter-spacing: 0.12em;
  color: rgba(61,81,85,0.86);
}

.japa-footer-nav{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: 28px;
  row-gap: 18px;
}

.japa-footer-col{
  font-size: 13px;
}

.japa-footer-heading{
  margin: 0 0 12px;
  position: relative;
  padding-bottom: 10px;
  font-family: "Shippori Mincho", serif;
  font-size: 15px;
  letter-spacing: 0.18em;
  color: rgba(61,81,85,0.92);
}

.japa-footer-heading::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width: 28px;
  height: 1px;
  background: rgba(61,81,85,0.22);
}

.japa-footer-heading--mt{
  margin-top: 24px;
}

.japa-footer-col ul{
  list-style: none;
  margin: 0 0 8px;
  padding: 0;
}

.japa-footer-col li{
  margin: 0;
}
.japa-footer-col li + li{
  margin-top: 8px;
}

.japa-footer-col a{
  display: inline-block;
  max-width: 100%;
  text-decoration: none;
  color: rgba(61,81,85,0.76);
  font-size: 13px;
  letter-spacing: 0.03em;
  border-bottom: 1px solid transparent;
  padding: 2px 0;
  transition: color .2s ease, border-color .2s ease, transform .2s ease;
  word-break: keep-all;
}
.japa-footer-col:nth-child(3) a{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.japa-footer-col a:hover{
  color: rgba(61,81,85,1);
  border-bottom-color: rgba(61,81,85,0.26);
  transform: translateY(-1px);
}

.japa-footer-col:nth-child(3) a{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.japa-footer-bottom{
  background-color: #3d5155;
  color: rgba(245,245,245,0.88);
  padding: 18px 16px;
}

.japa-footer-bottom-inner{
  width: min(1120px, 92vw);
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 24px;
  font-size: 12px;
}

.japa-footer-copy{
  white-space: normal;
}

.japa-footer-copy,
.japa-footer-bottom-links a{
  line-height: 1.8;
}

.japa-footer-bottom-links{
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: flex-end;
}

.japa-footer-bottom-links a{
  color: rgba(245,245,245,0.88);
  text-decoration: none;
  letter-spacing: 0.08em;
  border-bottom: 1px solid transparent;
  transition: border-color .2s ease, color .2s ease;
}

.japa-footer-bottom-links a:hover{
  color: rgba(245,245,245,1);
  border-bottom-color: rgba(245,245,245,0.35);
}

/* ===============================
   Responsive
=============================== */
@media (max-width: 1023px){
  .japa-footer-inner{
    grid-template-columns: 1fr;
    row-gap: 40px;
  }
  .japa-footer-nav{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: 32px;
  }
}

/* ===============================
   SP
=============================== */
@media (max-width: 767px){

  .home .l-content{
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  .top-section.top-reserve-contact{
    padding-bottom: 40px;
  }
}

/* =========================================
   SUBPAGE BASE (Common)
   Scope: .subpage
========================================= */

.subpage{
  font-family: "Zen Kaku Gothic New", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  line-height: 1.8;
  color: var(--text-main);
  --swl-list-padding--left: 0;

  --sub-pad-sp: 64px;
  --sub-pad-pc: 80px;
  --sub-container: 1040px;

  --title-en: 34px;
  --title-ja: 14px;
  --title-gap: 44px;

  --sub-hero-inner: 980px;
}

/* Section spacing */
.subpage .subpage-section{
  padding: var(--sub-pad-sp) 16px;
}
@media (min-width: 768px){
  .subpage .subpage-section{
    padding: var(--sub-pad-pc) 24px;
  }
}

.subpage .subpage-container{
  max-width: var(--sub-container);
  margin: 0 auto;
}

/* Mobile tune */
@media (max-width: 767px){
  .subpage{ font-size: 15px; }

  .subpage{
    --title-en: 26px;
    --title-ja: 13px;
    --title-gap: 40px;
  }
}

/* ==============================
   Hero
============================== */

.subpage .subpage-hero{
  position: relative;
  overflow: hidden;

  min-height: clamp(360px, 46vh, 520px);

  display: flex;
  align-items: center;
  justify-content: center;

  padding: clamp(72px, 10vh, 110px) 16px;

  color: #fff;
  background: none;
}

.subpage .subpage-hero .subpage-hero-bg{
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  z-index: 0;
}

.subpage .subpage-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(to bottom, rgba(0,0,0,.35), rgba(0,0,0,.58));
  z-index: 1;
}

.subpage .subpage-hero-inner{
  position: relative;
  z-index: 2;
  max-width: var(--sub-hero-inner);
  margin: 0 auto;
  text-align: center;
  transform: translateY(-8px);
}

/* Hero texts */
.subpage .subpage-hero-label{
  display: inline-block;
  font-family: "Cormorant Garamond", serif;
  font-size: 12px;
  letter-spacing: 0.22em;
  margin-bottom: 10px;
  opacity: .9;
}

.subpage .subpage-hero-title{
  font-family: "Shippori Mincho", serif;
  font-size: 34px;
  letter-spacing: 0.12em;
  margin: 0 0 14px;
  line-height: 1.25;
}

.subpage .subpage-hero-catch{
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  letter-spacing: 0.10em;
  margin: 0 0 18px;
  opacity: .95;
}

.subpage .subpage-hero-lead{
  font-size: 14px;
  line-height: 2.0;
  margin: 0 auto 26px;
  max-width: 860px;
  opacity: .9;
}

.subpage .subpage-hero-cta{
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

.subpage .subpage-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  padding: 14px 22px;
  border-radius: 999px;
  text-decoration: none;
  letter-spacing: 0.08em;
  font-size: 13px;
  transition: transform .2s ease, box-shadow .25s ease, background-color .25s ease, border-color .25s ease;
}
.subpage .subpage-btn.-primary{
  background: #3d5155;
  color: #fff;
  border: 1px solid #3d5155;
  box-shadow: 0 10px 22px rgba(0,0,0,0.08);
}
.subpage .subpage-btn.-ghost{
  background: rgba(255,255,255,0.75);
  color: #3d5155;
  border: 1px solid #d6dad9;
  box-shadow: 0 10px 22px rgba(0,0,0,0.04);
  backdrop-filter: blur(6px);
}
@media (hover:hover) and (pointer:fine){
  .subpage .subpage-btn:hover{ transform: translateY(-2px); }
}

@media (max-width: 767px){
  .subpage .subpage-hero{ padding: 88px 16px 70px; }

  .subpage .subpage-hero-title{ font-size: 28px; }
  .subpage .subpage-hero-catch{ font-size: 17px; }
  .subpage .subpage-hero-lead{ font-size: 13px; }

  .subpage .subpage-btn{
    min-width: 0;
    width: 100%;
    max-width: 360px;
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .subpage .subpage-btn{ transition: none !important; }
}

.page .c-pageTitle{
  display: none !important;
}

/* ==========================
   Buttons
============================== */

a.btn-line,
a.btn-line:visited,
.wp-block-button__link.btn-line{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-width: 300px;
  padding: 20px 64px;

  font-size: 15px;
  line-height: 1.2;
  letter-spacing: .12em;

  text-decoration: none;
  border: 1px solid var(--text-main);
  color: var(--text-main);
  background: transparent;

  border-radius: 0;
  cursor: pointer;

  box-sizing: border-box;
  overflow: visible;

  transition: color .25s ease,
              border-color .25s ease,
              transform .25s ease,
              box-shadow .25s ease,
              background-color .25s ease;
}


/* ==========================
   Final CTA
========================== */

.subpage .final-cta{
  padding: clamp(72px, 10vh, 120px) 16px;
}

.subpage .cta-box--final{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;

  background: rgba(255,255,255,.82);
  border: 1px solid rgba(61,81,85,.18);
  border-radius: 16px;
  padding: clamp(40px, 6vw, 72px);
}

.subpage .cta-box-body{
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.subpage .cta-box-lead{
  font-family: "Shippori Mincho", serif;
  font-size: 24px;
  line-height: 1.6;
  letter-spacing: .08em;
  color: var(--ink, var(--text-main));
}

.subpage .cta-box-sub{
  font-size: 14px;
  line-height: 2;
  color: var(--muted, var(--text-muted));
}

.subpage .cta-box-buttons{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  width: min(520px, 100%);
  margin-top: 12px;
}

.subpage .cta-box-buttons .btn-line{
  width: 100%;
  min-width: 0;
  padding: 18px 40px;
  justify-content: center;
  white-space: nowrap;
}

/* media */
.subpage .cta-box-media{
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 14px;
  background: center / cover no-repeat;
  background-image: url("/wp-content/uploads/2026/01/course-img0008.jpg");
}

/* SP */
@media (max-width: 767px){
  .subpage .cta-box--final{
    grid-template-columns: 1fr;
    gap: 36px;
	max-width: 600px;
    text-align: center;
	margin: 0 auto;
	padding: 40px 24px;
  }

  .subpage .cta-box-buttons{
    grid-template-columns: 1fr;
    width: 100%;
    justify-items: center;
  }

  .subpage .cta-box-buttons .btn-line{
    width: 100%;
    max-width: 360px;
    padding: 16px 24px;
  }
}

.subpage .final-cta .btn-line{
  min-width: 0;
  width: 100%;
}


/* =========================================
   NEXT STEP
========================================= */

.subpage .next-step{
  text-align: center;
  padding: 56px 16px 72px;
}

/* grid */
.subpage .next-step .next-step-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  max-width: 980px;
  margin: 18px auto 0;

  border-top: 1px solid rgba(61,81,85,.18);
  border-bottom: 1px solid rgba(61,81,85,.18);
}

/* link card */
.subpage .next-step .next-step-link{
  display: grid;
  place-items: center;
  padding: 18px 10px;

  text-decoration: none;
  color: var(--ink, var(--text-main, #2f3e42));

  letter-spacing: .08em;
  font-size: 13px;
  line-height: 1.6;

  position: relative;
}

.subpage .next-step .next-step-link + .next-step-link{
  border-left: 1px solid rgba(61,81,85,.18);
}

/* hover */
@media (hover:hover) and (pointer:fine){
  .subpage .next-step .next-step-link:hover{
    background: rgba(255,255,255,.45);
  }
}

/* focus */
.subpage .next-step .next-step-link:focus-visible{
  outline: 2px solid rgba(58,107,102,.35);
  outline-offset: -2px;
  background: rgba(58,107,102,.06);
}

/* title */
.subpage .next-step .next-step-title{
  margin: 0;
  font-weight: 600;
}

/* text */
.subpage .next-step .next-step-text{
  margin: 6px 0 0;
  font-size: 12px;
  color: rgba(47,62,66,.70);
  letter-spacing: 0;
  max-width: 22em;
}

/* =========================================
   SP
========================================= */
@media (max-width: 767px){
  .subpage .next-step .next-step-grid{
    grid-template-columns: 1fr;
  }

  .subpage .next-step .next-step-link + .next-step-link{
    border-left: 0;
    border-top: 1px solid rgba(61,81,85,.18);
  }

  .subpage .next-step .next-step-link{
    padding: 18px 14px;
  }
}




/* =========================================
   PAGE｜ABOUT
   Scope: .page-about
========================================= */

.page-about{
  --about-line: rgba(0,0,0,.10);
  --about-radius: 16px;
}

.page-about .subpage-section{
  padding-left: 16px;
  padding-right: 16px;
}
@media (min-width: 768px){
  .page-about .subpage-section{
    padding-left: 24px;
    padding-right: 24px;
  }
}

/* =========================
   PHILOSOPHY
========================= */

.page-about .about-philosophy-statement{
  max-width: 720px;
  margin: 0 auto 24px;
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  line-height: 1.9;
  text-align: center;
  letter-spacing: .06em;
}
@media (max-width: 767px){
  .page-about .about-philosophy-statement{
    font-size: 16px;
    margin-bottom: 18px;
  }
}

.page-about .about-philosophy-text{
  max-width: 680px;
  margin: 0 auto;
  font-size: 14px;
  line-height: 2.0;
  color: var(--text-muted);
}

.page-about .about-keywords{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  max-width: 900px;
  margin: 32px auto 0;
}
@media (min-width: 768px){
  .page-about .about-keywords{ grid-template-columns: repeat(3, 1fr); }
}

.page-about .about-keyword-card{
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--about-radius);
  padding: 20px 18px 18px;
  text-align: center;
}
.page-about .about-keyword-card h3{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 18px;
  margin: 0 0 8px;
  letter-spacing: .18em;
}
.page-about .about-keyword-card p{
  font-size: 14px;
  color: var(--text-muted);
  margin: 0;
  line-height: 1.85;
}

/* =========================
   ABOUT｜Core Sections
========================= */

.page-about .about-core-hero{
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 768px){
  .page-about .about-core-hero{
    grid-template-columns: 0.9fr 1.1fr;
    gap: 26px;
    align-items: start;
  }
}

.page-about .about-core-hero-media{
  border-radius: var(--about-radius);
  overflow: hidden;
  min-height: clamp(180px, 24vw, 260px);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: saturate(.95) contrast(.98);
}

.page-about .about-core-hero-body{ min-width: 0; }

.page-about .about-core-lead{
  margin: 0 0 14px;
  line-height: 2.0;
}
@media (max-width: 767px){
.page-about .about-core-lead br{
    display: none;
  }
}

.page-about .about-core-cards{
  list-style: none;
  margin: 16px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 768px){
  .page-about .about-core-cards{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
  }
}

.page-about .about-core-card{
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  padding: 14px 14px 12px;
}
@media (max-width: 767px){
  .page-about .about-core-card{ padding: 16px 14px 14px; }
}

.page-about .about-core-card-title{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 15px;
  margin: 0 0 8px;
  letter-spacing: .10em;
  line-height: 1.5;
}
.page-about .about-core-card-text{
  margin: 0;
  font-size: 13.5px;
  color: var(--text-muted);
  line-height: 1.9;
  letter-spacing: .02em;
}

.page-about .about-core-note{
  margin-top: 18px;
  padding-left: 14px;
  border-left: 1px solid rgba(0,0,0,.12);
  color: var(--text-muted);
  font-size: 14px;
  line-height: 1.9;
}

.page-about .about-core-cards--media{ margin-top: 18px; }
.page-about .about-core-cards--media .about-core-card{
  padding: 0;
  overflow: hidden;
  background: #fff;
}

.page-about .about-core-card-media{
  width: 100%;
  padding-top: 58%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: saturate(.95) contrast(.98);
}

.page-about .about-core-cards--media .about-core-card-title,
.page-about .about-core-cards--media .about-core-card-text{
  padding-left: 14px;
  padding-right: 14px;
}
.page-about .about-core-cards--media .about-core-card-title{ padding-top: 12px; }
.page-about .about-core-cards--media .about-core-card-text{ padding-bottom: 14px; }

.page-about .about-season-grid{
  margin: 18px 0 12px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
@media (min-width: 768px){
  .page-about .about-season-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.page-about .about-season-tile{
  margin: 0;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.55);
}

.page-about .about-season-photo{
  width: 100%;
  padding-top: 70%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: saturate(0.95);
}
.page-about .about-season-tile figcaption{ padding: 12px 12px 10px; }
.page-about .about-season-name{
  margin: 0 0 6px;
  font-size: 12px;
  letter-spacing: .18em;
  color: var(--text-muted);
}
.page-about .about-season-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.75;
}

/* =========================
   MESSAGE
========================= */

.page-about .about-message{ background:#fff; }

.page-about .about-message-inner{
  display: flex;
  flex-direction: column;
  gap: 28px;
  align-items: stretch;
}
@media (min-width: 768px){
  .page-about .about-message-inner{
    flex-direction: row;
    align-items: center;
    gap: 48px;
  }
}

.page-about .about-message-photo{
  flex: 0 0 auto;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  margin: 0 auto;
  background:
    url("/wp-content/uploads/2025/12/shoko_mori.jpg") center/cover no-repeat,
    #e3e8e1;
}
@media (min-width: 768px){
  .page-about .about-message-photo{
    margin: 0;
    width: 220px;
    height: 220px;
  }
}

.page-about .about-message-body p + p{ margin-top: 12px; }

.page-about .about-message-sign{
  margin-top: 24px;
  text-align: right;
  font-size: 14px;
  color: var(--text-muted);
}
.page-about .about-message-sign span{
  font-size: 16px;
  font-weight: 600;
  color: var(--text-main);
}

/* ===============================
   ABOUT｜Directors Message（card & photo placeholder）
   scope: .about-directors
   =============================== */

.about-directors .directors-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 28px;
}

@media (max-width: 1023px){
  .about-directors .directors-grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.about-directors .director-card{
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(61,81,85,.14);
  box-shadow: 0 14px 38px rgba(0,0,0,.06);
  border-radius: 10px;
  padding: 22px 22px 20px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: transform .25s ease, box-shadow .25s ease, background-color .25s ease;
}

@media (hover:hover) and (pointer:fine){
  .about-directors .director-card:hover{
    transform: translateY(-2px);
    box-shadow: 0 18px 46px rgba(0,0,0,.08);
    background: rgba(255,255,255,.86);
  }
}

.about-directors .director-head{
  display: grid;
  grid-template-columns: 84px 1fr;
  gap: 14px;
  align-items: center;
  margin-bottom: 14px;
}

.about-directors .director-photo{
  width: 84px;
  height: 84px;
  border-radius: 999px;
  border: 1px solid rgba(61,81,85,.18);
  background-color: rgba(230,228,223,.55);
  overflow: hidden;
  position: relative;
}

.about-directors .director-photo[style*="background-image"]{
  background: center/cover no-repeat;
}

.about-directors .director-photo:not([style*="background-image"])::before{
  content:"";
  position:absolute;
  inset: 0;
  background:
    radial-gradient(circle at 35% 30%, rgba(255,255,255,.75), rgba(255,255,255,0) 55%),
    linear-gradient(to bottom, rgba(61,81,85,.10), rgba(61,81,85,0));
}

.about-directors .director-photo:not([style*="background-image"])::after{
  content:"";
  position:absolute;
  left: 50%;
  top: 54%;
  width: 34px;
  height: 34px;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  box-shadow:
    0 -16px 0 0 rgba(61,81,85,.28) inset;
  opacity: .75;
}

.about-directors .director-role{
  margin: 0 0 4px;
  font-size: 0.72rem;
  letter-spacing: .14em;
  color: rgba(61,81,85,.75);
}

.about-directors .director-name{
  margin: 0 0 6px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 1.25rem;
  letter-spacing: .10em;
  line-height: 1.45;
  color: #2f3e42;
}

.about-directors .director-title{
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.6;
  color: rgba(47,62,66,.72);
}

.about-directors .director-body{
  border-top: 1px solid rgba(61,81,85,.12);
  padding-top: 14px;
}

.about-directors .director-body p{
  margin: 0 0 10px;
  font-size: 1rem;
  line-height: 1.95;
  color: rgba(47,62,66,.82);
}

.about-directors .director-body p:last-child{
  margin-bottom: 0;
}

/* SP */
@media (max-width: 767px){
  .about-directors .director-card{
    padding: 18px 16px 16px;
    border-radius: 8px;
  }

  .about-directors .director-head{
    grid-template-columns: 72px 1fr;
  }

  .about-directors .director-photo{
    width: 72px;
    height: 72px;
  }

  .about-directors .director-name{
    font-size: 1.1rem;
  }

  .about-directors .director-body p{
    font-size: 0.92rem;
    line-height: 1.9;
  }
}



/* =========================
   OUTLINE
========================= */

.page-about .about-outline-inner{
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 32px;
}
@media (min-width: 768px){
  .page-about .about-outline-inner{
    flex-direction: row;
    align-items: stretch;
    gap: 32px;
  }
}

.page-about .about-outline-table{
  border-top: 1px solid #eaeaea;
  border-bottom: 1px solid #eaeaea;
}
.page-about .about-outline-table > div{
  display: grid;
  grid-template-columns: 120px 1fr;
  padding: 10px;
  border-top: 1px solid #eaeaea;
}
.page-about .about-outline-table > div:first-child{ border-top: none; }
.page-about .about-outline-table dt{
  font-size: 13px;
  color: var(--text-muted);
}
.page-about .about-outline-table dd{ font-size: 14px; }

.page-about .about-outline-photo{
  flex: 1;
  min-height: clamp(200px, 22vw, 280px);
  border-radius: var(--about-radius);
  background: url("/wp-content/uploads/2026/01/about-img013.jpg") center/cover no-repeat;
}

/* =========================
   TIMELINE
========================= */

.page-about .timeline-grouped{
  list-style: none;
  margin: 24px 0 0;
  padding: 0;
}

.page-about .timeline-group{
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 20px;
  padding-bottom: 36px;
}
@media (max-width: 767px){
  .page-about .timeline-group{
    grid-template-columns: 64px 1fr;
    gap: 16px;
    padding-bottom: 28px;
  }
}

.page-about .timeline-group-year{
  font-family: "Zen Kaku Gothic New", system-ui, sans-serif;
  font-weight: 700;
  font-size: 20px;
  letter-spacing: .08em;
  text-align: right;
  color: var(--text-main);
  padding-top: 4px;
}

.page-about .timeline-list{
  --tl-x: 20px;
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}

.page-about .timeline-item{
  position: relative;
  padding-left: 56px;
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 16px;
  padding-bottom: 20px;
}

.page-about .timeline-item::after{
  content:"";
  position: absolute;
  left: var(--tl-x);
  top: 0;
  bottom: 0;
  width: 1px;
  background: rgba(0,0,0,.18);
}
.page-about .timeline-item:last-child::after{ bottom: 8px; }

.page-about .timeline-dot{
  position: absolute;
  left: var(--tl-x);
  top: 9px;
  transform: translateX(-50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid rgba(67,63,55,.9);
  z-index: 2;
}

.page-about .timeline-month{
  margin: 0;
  font-family: "Zen Kaku Gothic New", system-ui, sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .08em;
  color: var(--text-main);
  text-align: right;
  white-space: nowrap;
  padding-top: 1px;
}

.page-about .timeline-content h3{
  font-family: "Shippori Mincho", serif;
  font-size: 15px;
  margin: 0 0 4px;
}
.page-about .timeline-content p{
  font-size: 14px;
  line-height: 1.9;
  color: var(--text-muted);
  margin: 0;
}

@media (max-width: 767px){
  .page-about .timeline-list{ --tl-x: 14px; }
  .page-about .timeline-item{
    padding-left: 44px;
    grid-template-columns: 36px 1fr;
    gap: 12px;
    padding-bottom: 16px;
  }
  .page-about .timeline-content p{ font-size: 13px; }
}

/* =========================
   ACTIVITIES
========================= */

.page-about .about-activities{ background: var(--light-beige); }

.page-about .about-card-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width: 768px){
  .page-about .about-card-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

.page-about .about-card{
  background:#fff;
  border-radius: var(--about-radius);
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
  transition: transform .2s ease, box-shadow .2s ease;
}
@media (hover:hover) and (pointer:fine){
  .page-about .about-card:hover{
    transform: translateY(-3px);
    box-shadow: 0 8px 18px rgba(0,0,0,.06);
  }
}

.page-about .about-card-thumb{
  width: 100%;
  padding-top: 62.5%;
  background: center/cover no-repeat;
  background-color: #e6ebe3;
}

.page-about .about-card-body{ padding: 18px 20px 20px; }
.page-about .about-card-body h3{
  font-size: 16px;
  margin: 0 0 8px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
}
.page-about .about-card-body p{
  font-size: 14px;
  color: var(--text-muted);
  margin: 0;
}

/* =========================
   CERTIFICATION SYSTEM
========================= */

.page-about .about-cert{ background: var(--soft-beige); }

.page-about .about-bottom-cta{
  display: grid;
  gap: 24px;
  padding: 42px 34px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(61,81,85,.18);
  box-shadow: 0 16px 44px rgba(0,0,0,.06);
  position: relative;
  overflow: hidden;
}
@media (min-width: 1024px){
  .page-about .about-bottom-cta{
    grid-template-columns: 1.2fr .8fr;
    align-items: center;
  }
}
.page-about .about-bottom-cta-body{ text-align: left; max-width: 42em; }
.page-about .about-bottom-cta-lead{
  margin: 0 0 10px;
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  letter-spacing: .08em;
  line-height: 1.75;
}
.page-about .about-bottom-cta-sub{
  margin: 0 0 18px;
  font-size: 13.5px;
  line-height: 2.0;
  color: rgba(47,62,66,.78);
}
.page-about .about-bottom-cta-buttons{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.page-about .about-bottom-cta-media{
  width: 100%;
  height: 210px;
  background: center/cover no-repeat;
  border: 1px solid rgba(61,81,85,.18);
  box-shadow: 0 12px 34px rgba(0,0,0,.08);
}
.page-about .about-bottom-cta--cert .about-bottom-cta-media{
  background-image: url("/wp-content/uploads/2026/01/course-img0007.jpg");
}

@media (max-width: 767px){
  .page-about .about-bottom-cta{
    text-align: center;
    padding: 36px 18px;
  }
  .page-about .about-bottom-cta-body{ text-align: center; }
  .page-about .about-bottom-cta-buttons{ justify-content: center; }
}

  font-size: 18px;
  line-height: 1.9;
  text-align: center;
  letter-spacing: .06em;
}
@media (max-width: 767px){
  .page-about .about-philosophy-statement{
    font-size: 16px;
    margin-bottom: 18px;
  }
}

.page-about .about-philosophy-text{
  max-width: 680px;
  margin: 0 auto;
  font-size: 14px;
  line-height: 2.0;
  color: var(--text-muted);
}

.page-about .about-keywords{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  max-width: 900px;
  margin: 32px auto 0;
}
@media (min-width: 768px){
  .page-about .about-keywords{ grid-template-columns: repeat(3, 1fr); }
}

.page-about .about-keyword-card{
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--about-radius);
  padding: 20px 18px 18px;
  text-align: center;
}
.page-about .about-keyword-card h3{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 18px;
  margin: 0 0 8px;
  letter-spacing: .18em;
}
.page-about .about-keyword-card p{
  font-size: 14px;
  color: var(--text-muted);
  margin: 0;
  line-height: 1.85;
}

/* =========================
   MESSAGE
========================= */

.page-about .about-message{ background:#fff; }

.page-about .about-message-inner{
  display: flex;
  flex-direction: column;
  gap: 28px;
  align-items: stretch;
}
@media (min-width: 768px){
  .page-about .about-message-inner{
    flex-direction: row;
    align-items: center;
    gap: 48px;
  }
}

.page-about .about-message-photo{
  flex: 0 0 auto;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  margin: 0 auto;
  background:
    url("/wp-content/uploads/2025/12/shoko_mori.jpg") center/cover no-repeat,
    #e3e8e1;
}
@media (min-width: 768px){
  .page-about .about-message-photo{
    margin: 0;
    width: 220px;
    height: 220px;
  }
}

.page-about .about-message-body p + p{ margin-top: 12px; }

.page-about .about-message-sign{
  margin-top: 24px;
  text-align: right;
  font-size: 14px;
  color: var(--text-muted);
}
.page-about .about-message-sign span{
  font-size: 16px;
  font-weight: 600;
  color: var(--text-main);
}

/* =========================
   OUTLINE
========================= */

.page-about .about-outline-inner{
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 32px;
}
@media (min-width: 768px){
  .page-about .about-outline-inner{
    flex-direction: row;
    align-items: stretch;
    gap: 32px;
  }
}

.page-about .about-outline-table{
  border-top: 1px solid #eaeaea;
  border-bottom: 1px solid #eaeaea;
}
.page-about .about-outline-table > div{
  display: grid;
  grid-template-columns: 120px 1fr;
  padding: 10px;
  border-top: 1px solid #eaeaea;
}
.page-about .about-outline-table > div:first-child{ border-top: none; }
.page-about .about-outline-table dt{
  font-size: 13px;
  color: var(--text-muted);
}
.page-about .about-outline-table dd{ font-size: 14px; }

.page-about .about-outline-photo{
  flex: 1;
  min-height: 260px;
  border-radius: var(--about-radius);
  background: url("/wp-content/uploads/2026/01/about-img013.jpg") center/cover no-repeat;
}

/* =========================
   TIMELINE
========================= */

.page-about .timeline-grouped{
  list-style: none;
  margin: 24px 0 0;
  padding: 0;
}

.page-about .timeline-group{
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 20px;
  padding-bottom: 36px;
}
@media (max-width: 767px){
  .page-about .timeline-group{
    grid-template-columns: 64px 1fr;
    gap: 16px;
    padding-bottom: 28px;
  }
}

.page-about .timeline-group-year{
  font-family: "Zen Kaku Gothic New", system-ui, sans-serif;
  font-weight: 700;
  font-size: 20px;
  letter-spacing: .08em;
  text-align: right;
  color: var(--text-main);
  padding-top: 4px;
}

.page-about .timeline-list{
  --tl-x: 20px;
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}

.page-about .timeline-item{
  position: relative;
  padding-left: 56px;
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 16px;
  padding-bottom: 20px;
}

.page-about .timeline-item::after{
  content:"";
  position: absolute;
  left: var(--tl-x);
  top: 0;
  bottom: 0;
  width: 1px;
  background: rgba(0,0,0,.18);
}

.page-about .timeline-item:last-child::after{ bottom: 8px; }

.page-about .timeline-dot{
  position: absolute;
  left: var(--tl-x);
  top: 9px;
  transform: translateX(-50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid rgba(67,63,55,.9);
  z-index: 2;
}

.page-about .timeline-month{
  margin: 0;
  font-family: "Zen Kaku Gothic New", system-ui, sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .08em;
  color: var(--text-main);
  text-align: right;
  white-space: nowrap;
  padding-top: 1px;
}

.page-about .timeline-content h3{
  font-family: "Shippori Mincho", serif;
  font-size: 15px;
  margin: 0 0 4px;
}
.page-about .timeline-content p{
  font-size: 14px;
  line-height: 1.9;
  color: var(--text-muted);
  margin: 0;
}

@media (max-width: 767px){
  .page-about .timeline-list{ --tl-x: 14px; }
  .page-about .timeline-item{
    padding-left: 44px;
    grid-template-columns: 36px 1fr;
    gap: 12px;
    padding-bottom: 16px;
  }
  .page-about .timeline-content p{ font-size: 13px; }
}

/* =========================
   ACTIVITIES
========================= */

.page-about .about-activities{
  background: var(--light-beige);
}

.page-about .about-card-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width: 768px){
  .page-about .about-card-grid{ grid-template-columns: repeat(2, 1fr); }
}

.page-about .about-card{
  background:#fff;
  border-radius: var(--about-radius);
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
  transition: transform .2s ease, box-shadow .2s ease;
}
@media (hover:hover) and (pointer:fine){
  .page-about .about-card:hover{
    transform: translateY(-3px);
    box-shadow: 0 8px 18px rgba(0,0,0,.06);
  }
}

.page-about .about-card-thumb{
  width: 100%;
  padding-top: 62.5%;
  background: center/cover no-repeat;
  background-color: #e6ebe3;
}

.page-about .about-card-body{ padding: 18px 20px 20px; }
.page-about .about-card-body h3{
  font-size: 16px;
  margin: 0 0 8px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
}
.page-about .about-card-body p{
  font-size: 14px;
  color: var(--text-muted);
  margin: 0;
}

/* =========================
   CERTIFICATION SYSTEM
========================= */

.page-about .about-cert{
  background: var(--soft-beige);
}
.page-about .about-bottom-cta{
  display: grid;
  gap: 24px;
  padding: 42px 34px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(61,81,85,.18);
  box-shadow: 0 16px 44px rgba(0,0,0,.06);
  position: relative;
  overflow: hidden;
}
@media (min-width: 1024px){
  .page-about .about-bottom-cta{
    grid-template-columns: 1.2fr .8fr;
    align-items: center;
  }
}
.page-about .about-bottom-cta-body{ text-align: left; max-width: 42em; }
.page-about .about-bottom-cta-lead{
  margin: 0 0 10px;
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  letter-spacing: .08em;
  line-height: 1.75;
}
.page-about .about-bottom-cta-sub{
  margin: 0 0 18px;
  font-size: 13.5px;
  line-height: 2.0;
  color: rgba(47,62,66,.78);
}
.page-about .about-bottom-cta-buttons{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.page-about .about-bottom-cta-media{
  width: 100%;
  height: 210px;
  background: center/cover no-repeat;
  border: 1px solid rgba(61,81,85,.18);
  box-shadow: 0 12px 34px rgba(0,0,0,.08);
}
.page-about .about-bottom-cta--cert .about-bottom-cta-media{
  background-image: url("/wp-content/uploads/2026/01/course-img0007.jpg");
}

@media (max-width: 767px){
  .page-about .about-bottom-cta{
    text-align: center;
    padding: 36px 18px;
  }
  .page-about .about-bottom-cta-body{ text-align: center; }
  .page-about .about-bottom-cta-buttons{ justify-content: center; }
}

/* =========================
   ABOUT｜Media blocks (stable)
========================= */

.page-about .about-core-hero-media,
.page-about .about-core-card-media,
.page-about .about-season-photo,
.page-about .about-card-thumb,
.page-about .about-outline-photo,
.page-about .about-bottom-cta-media{
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: block;
}

.page-about .about-core-hero-media{
  min-height: clamp(180px, 24vw, 260px);
  border-radius: 16px;
}

.page-about .about-core-card-media{
  padding-top: 58%;
}

.page-about .about-season-photo{
  padding-top: 70%;
}

.page-about .about-card-thumb{
  padding-top: 62.5%; /* 16:10 */
}

.page-about .about-outline-photo{
  min-height: clamp(200px, 22vw, 280px);
}

.page-about .about-bottom-cta-media{
  height: 210px;
}

/* ABOUT｜image rhythm control */

.page-about .about-season-photo{
  padding-top: 62%;
}
@media (min-width: 768px){
  .page-about .about-season-photo{
    padding-top: 70%;
  }
}


.page-about .about-core-cards--media{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
}
@media (min-width: 768px){
  .page-about .about-core-cards--media{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
  }
}


/* =====================================================
   COURSES PAGE (Replace All)
   Scope: .courses-page
===================================================== */

/* section padding */
.courses-page .courses-section,
.courses-page .courses-lineup{
  padding: 80px 16px;
}

/* inner width */
.courses-page .courses-section-inner,
.courses-page .courses-lineup-inner{
  max-width: 1040px;
  margin: 0 auto;
}

/* =====================================================
   COURSES PAGE（Replace All）
   Scope: .courses-page
===================================================== */

/* Base tokens */
.courses-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --line-strong: rgba(61,81,85,.45);
  --bg-soft: #f7f6f2;
  --bg-panel: rgba(255,255,255,.88);
  --shadow: 0 14px 40px rgba(0,0,0,.06);
  color: var(--ink);
}

/* Section padding */
.courses-page .courses-section,
.courses-page .courses-lineup{
  padding: 80px 16px;
}

/* Inner width */
.courses-page .courses-section-inner,
.courses-page .courses-lineup-inner{
  max-width: 1040px;
  margin: 0 auto;
}

/* =====================================================
   Typography
===================================================== */
.courses-page .courses-step-title,
.courses-page .courses-abc-title,
.courses-page .ov-title{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .06em;
  line-height: 1.45;
  color: rgba(47,62,66,.95);
}
.courses-page .courses-step-title{ font-size: 20px !important; margin: 0 0 10px !important; }
.courses-page .courses-abc-title{ font-size: 18px !important; margin: 6px 0 0 !important; }
.courses-page .ov-title{ font-size: 16px !important; margin: 0 !important; }

@media (max-width: 767px){
  .courses-page .courses-step-title{ font-size: 18px !important; }
  .courses-page .courses-abc-title{ font-size: 16.5px !important; }
  .courses-page .ov-title{ font-size: 15.5px !important; }
}

/* =====================================================
  02｜OVERVIEW
===================================================== */
.courses-page .courses-lineup{
  background: var(--bg-soft);
}

.courses-page .courses-overview{
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 1180px){
  .courses-page .courses-overview{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 767px){
  .courses-page .courses-overview{
    grid-template-columns: 1fr;
  }
}

.courses-page .ov-card[href="#step-concierge"]{
  border-color: rgba(61,81,85,.26);
}
.courses-page .ov-card[href="#step-concierge"] .ov-meta{
  font-weight: 700;
}

.courses-page .ov-card{
  text-decoration: none;
  color: inherit;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 0;
  padding: 22px 22px 20px;
  display: grid;
  gap: 8px;
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
}

.courses-page .ov-card::after{
  content:"";
  position:absolute;
  left: 18px;
  right: 18px;
  bottom: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
  opacity: .45;
  transform: translateY(6px);
  transition: opacity .25s ease, transform .25s ease;
}

.courses-page .ov-step{
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  font-size: 12px;
  color: rgba(47,62,66,.70);
}
.courses-page .ov-sub{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.9;
  color: rgba(47,62,66,.78);
}
.courses-page .ov-meta{
  margin: 2px 0 0;
  font-size: 12.5px;
  letter-spacing: .06em;
  color: rgba(61,81,85,.72);
  padding-right: 30px;
  position: relative;
}
.courses-page .ov-meta::after{
  content:"";
  position:absolute;
  top: 50%;
  right: 0;
  width: 22px;
  height: 1px;
  background: rgba(61,81,85,.55);
  transform: translateY(-50%) scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
}

@media (hover:hover) and (pointer:fine){
  .courses-page .ov-card:hover{
    background: rgba(255,255,255,.92);
    transform: translateY(-1px);
  }
  .courses-page .ov-card:hover::after{
    opacity: .9;
    transform: translateY(0);
  }
  .courses-page .ov-card:hover .ov-meta::after{
    transform: translateY(-50%) scaleX(1);
  }
}

/* =====================================================
  Thumbnails（shared）
===================================================== */
.courses-page .courses-thumb{
  margin: 0;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 0;
  background: #eee;
  border: 1px solid rgba(61,81,85,.14);
}
.courses-page .courses-thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* =====================================================
  STEP1 / STEP3 : PC left image + right text
===================================================== */
.courses-page .course-row{
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 32px;
  align-items: center;
  padding: 24px;
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.14);
  border-radius: 0;
  box-shadow: var(--shadow);
  margin-top: 24px;
}
.courses-page .course-row:first-of-type{ margin-top: 18px; }
.courses-page .course-row-body{ min-width: 0; }

@media (max-width: 767px){
  .courses-page .course-row{
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 18px;
  }
}

.courses-page .courses-step-tagline{
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.9;
  color: rgba(47,62,66,.78);
}

/* STEP1 details */
.courses-page .courses-step-layout{
  margin: 10px 0 0;
  display: grid;
  grid-template-columns: 120px 1fr;
  column-gap: 16px;
  row-gap: 10px;
  align-items: start;
}
@media (max-width: 767px){
  .courses-page .courses-step-layout{
    grid-template-columns: 1fr;
    row-gap: 6px;
  }
}

.courses-page .courses-step-layout dt{
  margin: 0;
  font-size: 12.5px;
  letter-spacing: .12em;
  font-weight: 700;
  color: rgba(47,62,66,.92);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.courses-page .courses-step-layout dt::before{
  content:"";
  width: 18px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .9;
}
.courses-page .courses-step-layout dd{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: rgba(47,62,66,.72);
}

.courses-page .courses-step-note{
  margin: 14px 0 0;
  font-size: 13.5px;
  line-height: 1.9;
  color: rgba(47,62,66,.72);
}
.courses-page .courses-step-link{ margin: 16px 0 0; text-align: center; }

/* =====================================================
  STEP2 : ABC cards
===================================================== */
.courses-page .courses-intro{
  margin: 14px 0 22px;
  color: rgba(47,62,66,.80);
  line-height: 1.95;
  font-size: 13.5px;
}

.courses-page .courses-abc-grid{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
@media (max-width: 1023px){
  .courses-page .courses-abc-grid{ grid-template-columns: 1fr; }
}

.courses-page .courses-abc-card{
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.14);
  border-radius: 0;
  box-shadow: var(--shadow);
  overflow: hidden;
  padding: 18px;
  display: grid;
  gap: 10px;
}

.courses-page .courses-abc-lead{
  margin: 0;
  font-size: 13.5px;
  color: rgba(47,62,66,.80);
  line-height: 1.9;
}
.courses-page .courses-abc-list{
  margin: 6px 0 0;
  padding-left: 18px;
  color: rgba(47,62,66,.84);
}
.courses-page .courses-abc-list li{
  margin-bottom: 6px;
  line-height: 1.85;
  font-size: 13.5px;
}
.courses-page .courses-abc-note{
  margin: 0;
  font-size: 12.5px;
  color: rgba(47,62,66,.70);
}
.courses-page .courses-abc-link{ margin: 8px 0 0; }

@media (min-width: 1024px){
  .courses-page .courses-abc-grid{ align-items: stretch; }
  .courses-page .courses-abc-card{
    display: flex;
    flex-direction: column;
    height: 100%;
  }
  .courses-page .courses-abc-card .courses-thumb{ margin-bottom: 14px; }
  .courses-page .courses-abc-link{ margin-top: auto; padding-top: 16px; }
}

/* =====================================================
  FLOW
===================================================== */
.courses-page .courses-flow-list{
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.courses-page .courses-flow-item{
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 18px;
  border: 1px solid rgba(61,81,85,.14);
  border-radius: 0;
  background: var(--bg-panel);
  box-shadow: var(--shadow);
}
.courses-page .courses-flow-num{
  min-width: 44px;
  font-family: "Cormorant Garamond", serif;
  font-size: 30px;
  letter-spacing: .06em;
  line-height: 1;
  color: rgba(61,81,85,.78);
}
.courses-page .courses-flow-label{
  margin: 0 0 6px;
  font-weight: 700;
  letter-spacing: .06em;
}
.courses-page .courses-flow-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: rgba(47,62,66,.80);
}

/* =====================================================
  SUPPORT（Link block）
===================================================== */
.courses-page #support{
  background: var(--bg-soft);
}

.courses-page #support .courses-support-lead,
.courses-page #support .courses-support-link{
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.courses-page #support .courses-support-lead{
  margin: 16px auto 0;
  padding: 22px 22px 20px;
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.14);
  border-radius: 0;
  box-shadow: var(--shadow);
  color: rgba(47,62,66,.82);
  line-height: 1.95;
  position: relative;
}

.courses-page #support .courses-support-lead::before{
  content:"";
  position:absolute;
  left: 50%;
  top: 18px;
  width: 72px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .7;
  transform: translateX(-50%);
}

.courses-page #support .courses-support-link{
  margin: 14px auto 0;
}

.courses-page #support .courses-support-link .btn-line{
  display: inline-flex;
}

/* SP */
@media (max-width: 767px){
  .courses-page #support .courses-support-lead{
    padding: 18px 16px 16px;
  }
  .courses-page #support .courses-support-lead::before{
    top: 16px;
  }
}

/* =====================================================
  CTA（#reserve）
===================================================== */
.courses-page #reserve{
  background:
    radial-gradient(900px 420px at 18% 15%, rgba(61,81,85,.10), transparent 60%),
    radial-gradient(820px 380px at 85% 22%, rgba(107,132,124,.10), transparent 62%),
    linear-gradient(180deg, rgba(247,246,242,.95) 0%, #ffffff 70%);
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  .courses-page .ov-card::after,
  .courses-page .ov-meta::after{
    transition: none !important;
  }
}


/* =====================================================
  EXAM PAGE（Replace All）
  Scope: .subpage .exam-page
===================================================== */

/* Base tokens / layout */
.exam-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --muted2: rgba(47,62,66,.80);
  --line: rgba(61,81,85,.16);
  --line2: rgba(61,81,85,.28);
  --bg-soft: #f7f6f2;
  --bg-panel: rgba(255,255,255,.88);
  --shadow: 0 14px 40px rgba(0,0,0,.06);

  --cta-img: url("/wp-content/uploads/2026/01/course-img0008.jpg");

  color: var(--ink);
}

/* Section padding / inner width */
.exam-page .exam-section{
  padding: 80px 16px;
}
.exam-page .exam-inner{
  max-width: 1040px;
  margin: 0 auto;
}

/* soft section */
.exam-page .exam-soft{
  background: var(--bg-soft);
}

/* =========================
  Title typography
========================= */
.exam-page .exam-point-title,
.exam-page .exam-reason-title,
.exam-page .courses-step-title{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .06em;
  line-height: 1.45;
  color: rgba(47,62,66,.95);
}

.exam-page .exam-point-title{ font-size: 18px !important; margin: 0 0 10px !important; }
.exam-page .exam-reason-title{ font-size: 17px !important; margin: 0 0 10px !important; }
.exam-page .courses-step-title{ font-size: 20px !important; margin: 0 0 10px !important; }

@media (max-width: 767px){
  .exam-page .exam-point-title{ font-size: 16.5px !important; }
  .exam-page .exam-reason-title{ font-size: 16px !important; }
  .exam-page .courses-step-title{ font-size: 18px !important; }
}

/* =====================================================
  01｜Hero（Entry style）
===================================================== */
.exam-page .entry-hero{
  position: relative;
  overflow: hidden;
  color: #fff;
  isolation: isolate;

  min-height: 420px;
  padding: 120px 16px 92px;
  display: grid;
  align-items: end;
}
@media (max-width: 767px){
  .exam-page .entry-hero{
    min-height: 360px;
    padding: 96px 16px 72px;
  }
}

.exam-page .entry-hero-bg{
  position: absolute;
  inset: 0;
  background: center / cover no-repeat;
  z-index: 0;
  filter: brightness(.78) saturate(.92) contrast(1.03);
}

.exam-page .entry-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background: #000;
  opacity: .26;
  z-index: 1;
}

.exam-page .subpage-hero-inner{
  position: relative;
  z-index: 2;
}

.exam-page .subpage-hero-label,
.exam-page .subpage-hero-title{ color: #fff !important; }

.exam-page .subpage-hero-catch{ color: rgba(255,255,255,.95) !important; }
.exam-page .subpage-hero-lead{ color: rgba(255,255,255,.92) !important; }

/* =====================================================
  02｜WHAT YOU GET
===================================================== */
.exam-page .exam-points{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0,1fr));
  margin-top: 22px;
}
@media (max-width: 1023px){
  .exam-page .exam-points{ grid-template-columns: 1fr; }
}

.exam-page .exam-point{
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 0;
  box-shadow: var(--shadow);
  padding: 22px 20px;
  position: relative;
  overflow: hidden;
}
.exam-page .exam-point::before{
  content:"";
  position:absolute;
  left: 18px;
  top: 18px;
  width: 56px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .55;
}
.exam-page .exam-point-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--muted);
}

/* =====================================================
  03｜BEGINNER FRIENDLY
===================================================== */
.exam-page .exam-reasons{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0,1fr));
  margin-top: 22px;
}
@media (max-width: 1023px){
  .exam-page .exam-reasons{ grid-template-columns: 1fr; }
}

.exam-page .exam-reason{
  background: rgba(255,255,255,.86);
  border: 1px solid var(--line);
  border-radius: 0;
  box-shadow: var(--shadow);
  padding: 22px 20px;
}
.exam-page .exam-reason-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--muted);
}

/* =====================================================
  04｜LEVELS
===================================================== */
.exam-page .exam-levels{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 18px;
  align-items: center;
  margin: 32px 0 14px;
}

.exam-page .exam-level{
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.18);
  border-radius: 0;
  box-shadow: var(--shadow);
  padding: 18px 18px 16px;
  text-align: center;
}

.exam-page .exam-level-label{
  margin: 0 0 6px;
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  letter-spacing: .08em;
  line-height: 1.15;
  color: rgba(47,62,66,.95);
}
.exam-page .exam-level-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.9;
  color: var(--muted);
}

.exam-page .exam-level-arrow{
  width: 56px;
  height: 1px;
  background: rgba(61,81,85,.35);
  position: relative;
}
.exam-page .exam-level-arrow::after{
  content:"";
  position:absolute;
  right: -2px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-right: 1px solid rgba(61,81,85,.50);
  border-top: 1px solid rgba(61,81,85,.50);
  transform: translateY(-50%) rotate(45deg);
}

.exam-page .exam-level-note{
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 13.5px;
  line-height: 1.95;
}

@media (max-width: 767px){
  .exam-page .exam-levels{
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .exam-page .exam-level-arrow{
    width: 64px;
    margin: 2px auto 6px;
  }
  .exam-page .exam-level-label{
    font-size: 22px;
  }
}

/* =====================================================
  05｜COURSES
===================================================== */
.exam-page .courses-thumb{
  margin: 0;
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 0;
  border: 1px solid rgba(61,81,85,.14);
  background: #eee;
}
.exam-page .courses-thumb img{
  width: 100%;
  height: 100%;
  display:block;
  object-fit: cover;
}

.exam-page .course-row{
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 32px;
  align-items: center;
  padding: 24px;
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.14);
  border-radius: 0;
  box-shadow: var(--shadow);
  margin-top: 24px;
}
.exam-page .course-row:first-of-type{ margin-top: 18px; }
.exam-page .course-row-body{ min-width: 0; }

@media (max-width: 767px){
  .exam-page .course-row{
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 18px;
  }
}

.exam-page .courses-step-tagline{
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.9;
  color: var(--muted);
}

.exam-page .courses-step-layout{
  margin: 10px 0 0;
  display: grid;
  grid-template-columns: 120px 1fr;
  column-gap: 16px;
  row-gap: 10px;
  align-items: start;
}
@media (max-width: 767px){
  .exam-page .courses-step-layout{
    grid-template-columns: 1fr;
    row-gap: 6px;
  }
}

.exam-page .courses-step-layout dt{
  margin: 0;
  font-size: 12.5px;
  letter-spacing: .12em;
  font-weight: 700;
  color: rgba(47,62,66,.92);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.exam-page .courses-step-layout dt::before{
  content:"";
  width: 18px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .9;
}
.exam-page .courses-step-layout dd{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--muted);
}

.exam-page .courses-step-note{
  margin: 14px 0 0;
  font-size: 13.5px;
  line-height: 1.9;
  color: var(--muted);
}

/* =====================================================
  06｜NEXT STEP（REPLACE / SP tappable）
===================================================== */

.exam-page .exam-next-text{
  margin: 18px 0 0;
  font-size: 13.5px;
  line-height: 2.0;
  color: var(--muted);
  max-width: 52em;
}

/* list */
.exam-page .exam-next-list{
  list-style: none;
  margin: 20px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

/* SP */
@media (max-width: 1023px){
  .exam-page .exam-next-list{
    grid-template-columns: 1fr;
  }
}

/* card */
.exam-page .exam-next-list li{
  position: relative;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(61,81,85,.22);
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
  padding: 18px 18px 16px;
  transition: transform .25s ease, box-shadow .25s ease, background-color .25s ease;
}

/* link full tap */
.exam-page .exam-next-list li a{
  text-decoration: none;
  color: inherit;
  display: grid;
  gap: 8px;
  height: 100%;
}

/* title */
.exam-page .exam-next-list li strong{
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  font-size: 17px;
  color: rgba(61,81,85,.9);
  font-weight: 500;
}

/* desc */
.exam-page .exam-next-list li span{
  font-size: 13.5px;
  line-height: 1.9;
  color: rgba(47,62,66,.92);
}

.exam-page .exam-next-list li::after{
  content: "→";
  position: absolute;
  right: 18px;
  bottom: 14px;
  font-size: 16px;
  color: rgba(61,81,85,.6);
  transition: transform .25s ease, opacity .25s ease;
}

/* hover（PC） */
@media (hover:hover) and (pointer:fine){
  .exam-page .exam-next-list li:hover{
    background: #fff;
    transform: translateY(-2px);
    box-shadow: 0 16px 38px rgba(0,0,0,.08);
  }
  .exam-page .exam-next-list li:hover::after{
    transform: translateX(4px);
    opacity: 1;
  }
}

/* tap（SP） */
.exam-page .exam-next-list li:active{
  transform: translateY(1px);
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
}

/* note */
.exam-page .exam-next-note{
  margin: 16px 0 0;
  font-size: 12.5px;
  line-height: 1.9;
  color: rgba(47,62,66,.70);
}

/* =====================================================
  07｜CTA
===================================================== */
.exam-page #reserve{
  background:
    radial-gradient(900px 420px at 18% 15%, rgba(61,81,85,.10), transparent 60%),
    radial-gradient(820px 380px at 85% 22%, rgba(107,132,124,.10), transparent 62%),
    linear-gradient(180deg, rgba(247,246,242,.95) 0%, #ffffff 70%);
}

.exam-page .courses-bottom-cta{
  text-align: left;
  padding: 42px 34px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(61,81,85,.18);
  border-radius: 0;
  box-shadow: 0 16px 44px rgba(0,0,0,.06);
  position: relative;
  overflow: hidden;
}

.exam-page .courses-bottom-cta::before{
  content:"";
  position:absolute;
  left: 28px;
  top: 28px;
  width: 72px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .7;
}

.exam-page .courses-bottom-cta-lead{
  margin: 0 0 10px;
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  letter-spacing: .08em;
  line-height: 1.75;
  color: rgba(47,62,66,.95);
}

.exam-page .courses-bottom-cta-sub{
  margin: 0 0 18px;
  font-size: 13.5px;
  line-height: 2.0;
  color: var(--muted);
  max-width: 42em;
}

.exam-page .courses-bottom-cta-buttons{
  display: flex;
  gap: 12px;
  justify-content: flex-start;
  flex-wrap: wrap;
}

@media (min-width: 1024px){
  .exam-page .courses-bottom-cta{
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 22px;
    align-items: center;
  }
  .exam-page .courses-bottom-cta > *{ grid-column: 1; }

  .exam-page .courses-bottom-cta::after{
    content:"";
    grid-column: 2;
    width: 100%;
    height: 210px;
    border-radius: 0;
    border: 1px solid rgba(61,81,85,.18);
    background:
      linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.18)),
      var(--cta-img);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    box-shadow: 0 12px 34px rgba(0,0,0,.08);
  }
}

@media (max-width: 767px){
  .exam-page .courses-bottom-cta{
    text-align: center;
    padding: 36px 18px;
  }
  .exam-page .courses-bottom-cta::before{
    left: 50%;
    transform: translateX(-50%);
  }
  .exam-page .courses-bottom-cta-sub{
    margin-left: auto;
    margin-right: auto;
  }
  .exam-page .courses-bottom-cta-buttons{
    justify-content: center;
  }
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  .exam-page .exam-next-list li::after{
    transition: none !important;
  }
}

/* =====================================================
  COURSE PAGES｜A/B/C/INSTRUCTOR（Replace All）
  Scope: .course-page
===================================================== */

/* =========================
  Base tokens
========================= */
.course-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --muted2: rgba(47,62,66,.80);
  --line: rgba(61,81,85,.16);
  --line2: rgba(61,81,85,.28);
  --bg-soft: #f7f6f2;
  --bg-panel: rgba(255,255,255,.88);
  --shadow: 0 14px 40px rgba(0,0,0,.06);
  color: var(--ink);
}

/* Section / inner */
.course-page .course-section{
  padding: 80px 16px;
}
.course-page .course-inner{
  max-width: 1040px;
  margin: 0 auto;
}

/* soft section */
.course-page .course-soft{
  background: var(--bg-soft);
}

/* Text */
.course-page .course-lead{
  margin: 18px 0 0;
  font-size: 13.5px;
  line-height: 2.0;
  color: var(--muted);
  max-width: 54em;
}

/* Titles */
.course-page .exam-point-title,
.course-page .exam-reason-title,
.course-page .courses-step-title,
.course-page .price-title{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .06em;
  line-height: 1.45;
  color: rgba(47,62,66,.95);
}

.course-page .exam-point-title{ font-size: 18px !important; margin: 0 0 10px !important; }
.course-page .exam-reason-title{ font-size: 17px !important; margin: 0 0 10px !important; }
.course-page .courses-step-title{ font-size: 20px !important; margin: 0 0 10px !important; }
.course-page .price-title{ font-size: 18px !important; margin: 0 0 10px !important; }

@media (max-width: 767px){
  .course-page .exam-point-title{ font-size: 16.5px !important; }
  .course-page .exam-reason-title{ font-size: 16px !important; }
  .course-page .courses-step-title{ font-size: 18px !important; }
}

/* OVERVIEW CARD */
.course-page .overview-card{
  margin-top: 18px;
  background: rgba(255,255,255,.88);
  border: none;
  box-shadow: none;
  padding: 28px 32px 28px 36px;
  position: relative;
}

.course-page .overview-card::before{
  content:"";
  position:absolute;
  left: 20px;
  top: 28px;
  bottom: 28px;
  width: 1px;
  background: rgba(47,62,66,.15);
}

.course-page .course-overview-dl{
  margin: 14px 0 0;
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 10px;
}

.course-page .course-overview-dl dt{
  margin: 0;
  font-size: 12px;
  letter-spacing: .14em;
  font-weight: 700;
  color: rgba(47,62,66,.86);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.course-page .course-overview-dl dt::before{
  content:"";
  width: 18px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .9;
}
.course-page .course-overview-dl dd{
  margin: -6px 0 0;
  font-size: 13.5px;
  line-height: 1.9;
  color: var(--muted);
}
.course-page .overview-card .exam-point-text{
  margin: 14px 0 0;
  max-width: 52em;
  color: rgba(47,62,66,.7);
}

/* =====================================================
  FEATURES（exam-points）
===================================================== */
.course-page .exam-points{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0,1fr));
  margin-top: 22px;
}
@media (max-width: 1023px){
  .course-page .exam-points{ grid-template-columns: 1fr; }
}

.course-page .exam-point{
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 0;
  box-shadow: var(--shadow);
  padding: 22px 20px;
  position: relative;
  overflow: hidden;
}
.course-page .exam-point::before{
  content:"";
  position:absolute;
  left: 18px;
  top: 18px;
  width: 56px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .55;
}
.course-page .exam-point-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--muted);
}

/* =====================================================
  FOR WHO（exam-reasons）
===================================================== */
.course-page .exam-reasons{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0,1fr));
  margin-top: 22px;
}
@media (max-width: 1023px){
  .course-page .exam-reasons{ grid-template-columns: 1fr; }
}

.course-page .exam-reason{
  background: rgba(255,255,255,.86);
  border: 1px solid var(--line);
  border-radius: 0;
  box-shadow: var(--shadow);
  padding: 22px 20px;
}
.course-page .exam-reason-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--muted);
}

/* =====================================================
  CURRICULUM（course-row）
===================================================== */
.course-page .courses-thumb{
  margin: 0;
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 0;
  border: 1px solid rgba(61,81,85,.14);
  background: #eee;
}
.course-page .courses-thumb img{
  width: 100%;
  height: 100%;
  display:block;
  object-fit: cover;
}

.course-page .course-row{
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 32px;
  align-items: center;
  padding: 24px;
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.14);
  border-radius: 0;
  box-shadow: var(--shadow);
  margin-top: 24px;
}
.course-page .course-row:first-of-type{ margin-top: 18px; }
.course-page .course-row-body{ min-width: 0; }

@media (max-width: 767px){
  .course-page .course-row{
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 18px;
  }
}

.course-page .courses-step-tagline{
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.9;
  color: var(--muted);
}

.course-page .courses-step-layout{
  margin: 10px 0 0;
  display: grid;
  grid-template-columns: 120px 1fr;
  column-gap: 16px;
  row-gap: 10px;
  align-items: start;
}
@media (max-width: 767px){
  .course-page .courses-step-layout{
    grid-template-columns: 1fr;
    row-gap: 6px;
  }
}

.course-page .courses-step-layout dt{
  margin: 0;
  font-size: 13.5px;
  letter-spacing: .12em;
  font-weight: 700;
  color: rgba(47,62,66,.92);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.course-page .courses-step-layout dt::before{
  content:"";
  width: 18px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .9;
}
.course-page .courses-step-layout dd{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--muted);
}

.course-page .courses-step-note{
  margin: 14px 0 0;
  font-size: 13.5px;
  line-height: 1.9;
  color: var(--muted);
}

/* =====================================================
  PRICE
===================================================== */
.course-page .price-box{
  background: var(--bg-panel);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  padding: 22px 20px;
  margin-top: 22px;
  position: relative;
}
.course-page .price-box::before{
  content:"";
  position:absolute;
  left: 18px;
  top: 18px;
  width: 56px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .55;
}
.course-page .price-amount{
  margin: 2px 0 10px;
  font-size: 22px;
  letter-spacing: .04em;
  color: rgba(47,62,66,.95);
}
.course-page .price-meta{
  margin: 0;
  padding-left: 1.1em;
  color: var(--muted);
  font-size: 13.5px;
  line-height: 1.95;
}

/* =====================================================
  NEXT STEP
===================================================== */
.course-page .exam-next-list{
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 1023px){
  .course-page .exam-next-list{ grid-template-columns: 1fr; }
}

.course-page .exam-next-list li{
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 0;
  box-shadow: var(--shadow);
  padding: 16px 16px 14px;
  display: grid;
  gap: 8px;
}

.course-page .exam-next-list li a{
  text-decoration: none;
  color: inherit;
  display: grid;
  gap: 8px;
  height: 100%;
}

.course-page .exam-next-list li strong{
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  font-size: 18px;
  color: rgba(61,81,85,.85);
  font-weight: 500;
}

.course-page .exam-next-list li span{
  font-size: 13.5px;
  line-height: 1.9;
  color: rgba(47,62,66,.92);
}

.course-page .exam-next-list li::after{
  content:"";
  width: 26px;
  height: 1px;
  background: rgba(61,81,85,.45);
  justify-self: end;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
  margin-top: 2px;
}
@media (hover:hover) and (pointer:fine){
  .course-page .exam-next-list li:hover{
    background: rgba(255,255,255,.92);
    transform: translateY(-1px);
  }
  .course-page .exam-next-list li:hover::after{
    transform: scaleX(1);
  }
}

/* =====================================================
  CTA（course用）
===================================================== */
.course-page #reserve{
  background:
    radial-gradient(900px 420px at 18% 15%, rgba(61,81,85,.10), transparent 60%),
    radial-gradient(820px 380px at 85% 22%, rgba(107,132,124,.10), transparent 62%),
    linear-gradient(180deg, rgba(247,246,242,.95) 0%, #ffffff 70%);
}

.course-page .courses-bottom-cta{
  text-align: left;
  padding: 42px 34px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(61,81,85,.18);
  border-radius: 0;
  box-shadow: 0 16px 44px rgba(0,0,0,.06);
  position: relative;
  overflow: hidden;
}
.course-page .courses-bottom-cta::before{
  content:"";
  position:absolute;
  left: 28px;
  top: 28px;
  width: 72px;
  height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .7;
}

.course-page .courses-bottom-cta-lead{
  margin: 0 0 10px;
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  letter-spacing: .08em;
  line-height: 1.75;
  color: rgba(47,62,66,.95);
}
.course-page .courses-bottom-cta-sub{
  margin: 0 0 18px;
  font-size: 13.5px;
  line-height: 2.0;
  color: var(--muted);
  max-width: 42em;
}
.course-page .courses-bottom-cta-buttons{
  display: flex;
  gap: 12px;
  justify-content: flex-start;
  flex-wrap: wrap;
}

@media (min-width: 1024px){
  .course-page .courses-bottom-cta{
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 22px;
    align-items: center;
  }
  .course-page .courses-bottom-cta > *{ grid-column: 1; }
  .course-page .courses-bottom-cta::after{
    content:"";
    grid-column: 2;
    width: 100%;
    height: 210px;
    border-radius: 0;
    border: 1px solid rgba(61,81,85,.18);
    background:
      linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.18)),
      var(--cta-img, none);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    box-shadow: 0 12px 34px rgba(0,0,0,.08);
  }
}

@media (max-width: 767px){
  .course-page .courses-bottom-cta{
    text-align: center;
    padding: 36px 18px;
  }
  .course-page .courses-bottom-cta::before{
    left: 50%;
    transform: translateX(-50%);
  }
  .course-page .courses-bottom-cta-sub{
    margin-left: auto;
    margin-right: auto;
  }
  .course-page .courses-bottom-cta-buttons{
    justify-content: center;
  }
}

/* =====================================================
  BENEFITS
===================================================== */

.course-page:not(.course-instructor-page) .benefits-lead{
  margin: 18px 0 0;
  max-width: 56em;
  font-size: 13.5px;
  line-height: 2.0;
  color: var(--muted);
}

.course-page:not(.course-instructor-page) .benefits-pillars{
  list-style: none;
  margin: 22px 0 0;
  padding: 0;
  border-top: 1px solid rgba(61,81,85,.12);
}

.course-page:not(.course-instructor-page) .benefit-pillar{
  padding: 18px 0 20px;
  border-bottom: 1px solid rgba(61,81,85,.12);
}

.course-page:not(.course-instructor-page) .benefit-kicker{
  margin: 0 0 6px;
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  font-size: 12px;
  color: rgba(61,81,85,.72);
}

.course-page:not(.course-instructor-page) .benefit-title{
  margin: 0 0 10px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .06em;
  line-height: 1.5;
  color: rgba(47,62,66,.95);
  font-size: 18px;
}

.course-page:not(.course-instructor-page) .benefit-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--muted);
  max-width: 56em;
}

.course-page:not(.course-instructor-page) .benefit-sub{
  margin: 12px 0 0;
  padding-left: 18px;
  color: rgba(47,62,66,.82);
  font-size: 13.5px;
  line-height: 1.9;
}
.course-page:not(.course-instructor-page) .benefit-sub li{ margin: 4px 0; }

.course-page.course-instructor-page #benefits .benefits-head{
  margin-top: 16px;
  max-width: 56em;
}

.course-page.course-instructor-page #benefits .benefits-lead{
  margin: 0;
  font-size: 13.5px;
  line-height: 2.0;
  color: rgba(47,62,66,.76);
}

.course-page.course-instructor-page #benefits .benefits-pillars{
  list-style: none;
  margin: 32px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 20px;
  border: none;
}

@media (max-width: 1023px){
  .course-page.course-instructor-page #benefits .benefits-pillars{
    grid-template-columns: 1fr;
  }
}

.course-page.course-instructor-page #benefits .benefit-pillar{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(61,81,85,.18);
  padding: 28px 24px 26px;
  box-shadow: 0 12px 28px rgba(0,0,0,.06);
}

.course-page.course-instructor-page #benefits .benefit-kicker{
  margin: 0 0 6px;
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  font-size: 12px;
  color: rgba(61,81,85,.65);
}

.course-page.course-instructor-page #benefits .benefit-title{
  margin: 0 0 12px;
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  letter-spacing: .06em;
  line-height: 1.5;
  color: rgba(47,62,66,.95);
}

.course-page.course-instructor-page #benefits .benefit-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: rgba(47,62,66,.78);
}

.course-page.course-instructor-page #benefits .benefit-sub{
  margin: 14px 0 0;
  padding-left: 0;
  list-style: none;
}
.course-page.course-instructor-page #benefits .benefit-sub li{
  font-size: 13px;
  line-height: 1.8;
  color: rgba(47,62,66,.82);
  padding-left: 1.2em;
  position: relative;
}
.course-page.course-instructor-page #benefits .benefit-sub li::before{
  content: "–";
  position: absolute;
  left: 0;
  color: rgba(61,81,85,.6);
}

/* =====================================================
  CONCIERGE PAGE（Diff only / REPLACE - CLEAN）
  Scope: .course-page.course-concierge-page
===================================================== */

/* Hero bg */
.course-page.course-concierge-page .subpage-hero-bg{
  filter: brightness(.82) saturate(.92) contrast(1.03);
}

/* -----------------------------------------------------
  ROADMAP
----------------------------------------------------- */
.course-page.course-concierge-page .concierge-roadmap{
  margin-top: 22px;
  display: grid;
  gap: 14px;
}

.course-page.course-concierge-page .rm-step{
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 14px 40px rgba(0,0,0,.06);
  padding: 18px 18px 16px;
}

.course-page.course-concierge-page .rm-num{
  margin: 0 0 8px;
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  font-size: 12px;
  color: rgba(61,81,85,.72);
}

.course-page.course-concierge-page .rm-title{
  margin: 0 0 8px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .06em;
  line-height: 1.5;
  color: rgba(47,62,66,.95);
  font-size: 18px;
}

.course-page.course-concierge-page .rm-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.95;
  color: rgba(47,62,66,.78);
}

.course-page.course-concierge-page .rm-line{
  height: 18px;
  width: 1px;
  background: rgba(61,81,85,.22);
  margin-left: 20px;
}

/* -----------------------------------------------------
  STEP GRID
----------------------------------------------------- */
.course-page.course-concierge-page .concierge-stepgrid{
  margin-top: 18px;
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 1023px){
  .course-page.course-concierge-page .concierge-stepgrid{
    grid-template-columns: 1fr;
  }
}

/* mini row */
.course-page.course-concierge-page .course-row--mini{
  grid-template-columns: 1fr;
  align-items: start;
}

/* bullets */
.course-page.course-concierge-page .concierge-bullets{
  margin: 12px 0 0;
  padding-left: 18px;
  color: rgba(47,62,66,.82);
  font-size: 13.5px;
  line-height: 1.9;
}

.course-page.course-concierge-page .concierge-bullets li{
  margin: 6px 0;
}

.course-page.course-concierge-page .concierge-bullets strong{
  font-weight: 700;
  color: rgba(47,62,66,.92);
}

/* note under banner */
.course-page.course-concierge-page .concierge-note{
  margin: 12px 0 0;
  font-size: 12.5px;
  line-height: 1.9;
  color: rgba(47,62,66,.70);
}

/* -----------------------------------------------------
  ONLINE PROGRAM｜Image Banner（SP/PC picture対応）
----------------------------------------------------- */
.course-page.course-concierge-page .op-banner--image{
  position: relative;
  display: block;
  text-decoration: none;
  color: inherit;

  background: rgba(255,255,255,.88);
  border: 1px solid rgba(61,81,85,.18);
  box-shadow: 0 14px 40px rgba(0,0,0,.06);
  overflow: hidden;
}

.course-page.course-concierge-page .op-banner--image picture,
.course-page.course-concierge-page .op-banner--image img{
  display: block;
  width: 100%;
  height: auto;
}

.course-page.course-concierge-page .op-banner-external{
  position: absolute;
  right: 16px;
  bottom: 14px;
  font-size: 16px;
  line-height: 1;
  color: rgba(61,81,85,.65);
  transition: transform .25s ease, opacity .25s ease;
}

.course-page.course-concierge-page .op-banner--image::before{
  content:"";
  position:absolute;
  right: 34px;
  bottom: 18px;
  width: 22px;
  height: 1px;
  background: rgba(61,81,85,.45);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .25s ease;
}

@media (hover:hover) and (pointer:fine){
  .course-page.course-concierge-page .op-banner--image:hover{
    background: rgba(255,255,255,.92);
    transform: translateY(-1px);
    box-shadow: 0 18px 48px rgba(0,0,0,.08);
  }
  .course-page.course-concierge-page .op-banner--image:hover::before{
    transform: scaleX(1);
  }
  .course-page.course-concierge-page .op-banner--image:hover .op-banner-external{
    transform: translate(2px,-2px);
    opacity: 1;
  }
}

.course-page.course-concierge-page .op-banner--image:active{
  transform: translateY(1px);
  box-shadow: 0 10px 28px rgba(0,0,0,.08);
}

/* -----------------------------------------------------
  NEXT STEP
----------------------------------------------------- */

.course-page.course-concierge-page .exam-next-list li a{
  position: relative;
  display: grid;
  gap: 8px;
  height: 100%;
  text-decoration: none;
  color: inherit;
}

.course-page.course-concierge-page .exam-next-list li{
  position: relative;
}

.course-page.course-concierge-page .exam-next-list li a.is-external{
  padding-right: 34px;
}

.course-page.course-concierge-page .exam-next-list li a.is-external::after{
  content:"↗";
  position:absolute;
  right: 14px;
  bottom: 12px;
  font-size: 14px;
  line-height: 1;
  color: rgba(61,81,85,.6);
  transition: transform .25s ease, opacity .25s ease;
  z-index: 2;
}

.course-page.course-concierge-page .exam-next-list li a.is-external::before{
  display: none !important;
}

.course-page.course-concierge-page .exam-next-list li:has(a.is-external)::after{
  display: none !important;
}

.course-page.course-concierge-page .exam-next-list li.is-external::after{
  display: none !important;
}

@media (hover:hover) and (pointer:fine){
  .course-page.course-concierge-page .exam-next-list li:hover a.is-external::after{
    transform: translate(2px,-2px);
    opacity: 1;
  }
}


/* =====================================================
  PAGE｜CAREER & CASE
  Scope: .page-career
===================================================== */

.page-career{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --line-strong: rgba(61,81,85,.55);
  --bg-soft: #f7f6f2;
  --panel: rgba(255,255,255,.88);
  --shadow: 0 14px 40px rgba(0,0,0,.06);
  --radius: 16px;
  color: var(--ink);
}

.page-career .career-hero{
  background:
    radial-gradient(900px 520px at 18% 25%, rgba(107,132,124,.14), transparent 58%),
    radial-gradient(820px 460px at 85% 20%, rgba(61,81,85,.10), transparent 60%),
    linear-gradient(180deg, #f7f6f2 0%, #ffffff 70%);
}

/* =========================================
   02｜Career Fields（details）
========================================= */

.page-career .career-fields{ background: var(--bg-soft); }

.page-career .career-fields-intro{
  text-align: center;
  margin-bottom: 32px;
}
.page-career .career-fields-heading{
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  letter-spacing: .08em;
  margin: 0 0 10px;
}
.page-career .career-fields-lead{
  font-size: 14px;
  line-height: 1.9;
  color: rgba(47,62,66,.75);
  margin: 0;
}

.page-career .career-fields-grid{
  display: grid;
  gap: 18px;
  max-width: 960px;
  margin: 0 auto;
}

.page-career .career-field{
  background: var(--panel);
  border: 1px solid var(--line);
  box-shadow: 0 12px 30px rgba(0,0,0,.05);
  border-radius: var(--radius);
  overflow: hidden;
}

/* summary */
.page-career .career-fieldSummary{
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 20px;
  padding: 18px 22px;
  cursor: pointer;
  list-style: none;
}
.page-career .career-fieldSummary::-webkit-details-marker{ display:none; }

/* thumb */
.page-career .career-fieldThumb{
  width: 100%;
  aspect-ratio: 4 / 3;
  background: center/cover no-repeat;
  border-radius: 12px;
  transition: opacity .25s ease, max-height .25s ease;
}

/* head */
.page-career .career-fieldHead{
  display: grid;
  align-content: center;
  gap: 6px;
}
.page-career .career-fieldTitle{
  font-family: "Shippori Mincho", serif;
  font-size: 16px;
  letter-spacing: .08em;
  margin: 0;
}
.page-career .career-fieldText{
  font-size: 13px;
  line-height: 1.8;
  color: rgba(47,62,66,.75);
  margin: 0;
}
.page-career .career-fieldToggle{
  font-size: 12px;
  letter-spacing: .12em;
  color: rgba(61,81,85,.9);
  justify-self: flex-end;
  margin-top: 6px;
}

/* detail */
.page-career .career-fieldDetail{
  padding: 18px 26px 24px;
  border-top: 1px solid rgba(61,81,85,.14);
  font-size: 14px;
  line-height: 1.9;
}
.page-career .career-fieldDetail ul{
  padding-left: 1.2em;
  margin: 12px 0;
}
.page-career .career-fieldDetail li{ margin-bottom: 6px; }
.page-career .career-fieldFit{
  margin-top: 14px;
  font-size: 13px;
  color: rgba(47,62,66,.8);
}

.page-career .career-field[open] .career-fieldThumb{
  opacity: 0;
  max-height: 0;
}
.page-career .career-field[open] .career-fieldSummary{
  grid-template-columns: 1fr;
  padding: 14px 22px 10px;
  gap: 6px;
}
.page-career .career-field[open] .career-fieldToggle{ display:none; }

/* SP */
@media (max-width: 767px){
  .page-career .career-fieldSummary{ grid-template-columns: 1fr; }
  .page-career .career-fieldThumb{ aspect-ratio: 16 / 9; }
}

/* =========================================
   03｜Real Stories
========================================= */

.page-career .career-storyGrid{
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 1023px){
  .page-career .career-storyGrid{ grid-template-columns: 1fr; }
}

.page-career .career-storyCard{
  background:#fff;
  border: 1px solid rgba(61,81,85,.16);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: 0 12px 34px rgba(0,0,0,.06);
  position: relative;
}
.page-career .career-storyCard::before{
  content:"";
  position:absolute;
  left: 18px; top: 18px;
  width: 56px; height: 1px;
  background: rgba(61,81,85,.45);
  opacity: .6;
}

.page-career .career-storyHead{
  display:grid;
  grid-template-columns: 56px 1fr;
  gap: 12px;
  align-items:center;
  margin-bottom: 12px;
}
.page-career .career-storyAvatar{
  width: 56px; height: 56px;
  border-radius: 999px;
  background: center/cover no-repeat;
  border: 1px solid rgba(61,81,85,.18);
}
.page-career .career-storyName{
  margin: 0;
  font-weight: 800;
  letter-spacing: .06em;
  font-size: 14px;
}
.page-career .career-storyRole{
  margin: 2px 0 0;
  font-size: 12px;
  color: var(--muted);
  letter-spacing: .04em;
}
.page-career .career-storyTitle{
  margin: 0 0 8px;
  font-weight: 700;
  letter-spacing: .06em;
  font-size: 13.5px;
}
.page-career .career-storyQuote{
  margin: 0;
  color: rgba(47,62,66,.86);
  line-height: 1.9;
  font-size: 13px;
  position: relative;
  padding-left: 16px;
}
.page-career .career-storyQuote::before{
  content:"“";
  position:absolute;
  left: 0;
  top: -2px;
  font-family: "Cormorant Garamond", serif;
  font-size: 22px;
  color: rgba(61,81,85,.35);
}

/* =========================================
   04｜Transformation
========================================= */

.page-career .career-transform{ background: var(--bg-soft); }

.page-career .career-transformGrid{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
@media (max-width: 1023px){
  .page-career .career-transformGrid{ grid-template-columns: 1fr; }
}

.page-career .career-transformCard{
  background:#fff;
  border: 1px solid rgba(61,81,85,.16);
  border-radius: var(--radius);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  overflow: hidden;
}

.page-career .career-ba{
  display:grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 767px){
  .page-career .career-ba{ grid-template-columns: 1fr; }
}

.page-career .career-baCol{ padding: 18px 18px 20px; }
.page-career .career-baBefore{
  background: #f3f4f4;
  border-right: 1px solid rgba(61,81,85,.12);
}
@media (max-width: 767px){
  .page-career .career-baBefore{
    border-right:none;
    border-bottom: 1px solid rgba(61,81,85,.12);
  }
}
.page-career .career-baAfter{ background:#fff; position: relative; }
.page-career .career-baAfter::before{
  content:"";
  position:absolute;
  left:0; top:0;
  height:100%; width:2px;
  background: rgba(61,81,85,.45);
  opacity: .6;
}
@media (max-width: 767px){
  .page-career .career-baAfter::before{
    width:100%; height:2px;
  }
}

.page-career .career-baLabel{
  margin: 0 0 8px;
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  font-size: 12px;
  color: rgba(61,81,85,.78);
}
.page-career .career-baText{
  margin: 0;
  line-height: 1.9;
  font-size: 13px;
  color: rgba(47,62,66,.88);
}

/* =========================================
   05｜Support
========================================= */

.page-career .career-supportGrid{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(4, minmax(0,1fr));
}
@media (max-width: 1023px){
  .page-career .career-supportGrid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 767px){
  .page-career .career-supportGrid{ grid-template-columns: 1fr; }
}

.page-career .career-supportItem{
  background:#fff;
  border: 1px solid rgba(61,81,85,.16);
  border-radius: var(--radius);
  padding: 20px 18px 22px;
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
}
.page-career .career-supportIcon{
  width: 44px; height: 44px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  letter-spacing: .08em;
  color:#fff;
  background: rgba(61,81,85,.92);
  margin-bottom: 12px;
}
.page-career .career-supportTitle{
  margin: 0 0 8px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .08em;
  font-size: 15px;
}
.page-career .career-supportText{
  margin: 0;
  font-size: 13px;
  line-height: 1.9;
  color: var(--muted);
}

.page-career .career-supportGrid{
  margin-bottom: 28px;
}

.page-career .career-centerBtn{
  text-align: center;
  margin-top: 0;
}

.page-career .career-centerBtn .btn-line{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 32px;
  line-height: 1.6;
}


/* =========================================
   06｜Message
========================================= */

.page-career .about-message{ background:#fff; }
.page-career .about-message-inner{
  display:flex;
  flex-direction:column;
  gap:28px;
  align-items:stretch;
}
@media (min-width: 768px){
  .page-career .about-message-inner{
    flex-direction:row;
    align-items:center;
    gap:48px;
  }
}
.page-career .about-message-photo{
  flex:0 0 auto;
  width:160px;
  height:160px;
  border-radius:50%;
  margin:0 auto;
  background:
    url("/wp-content/uploads/2026/02/hitomi_nakatani.jpg") center/cover no-repeat,
    #e3e8e1;
}
@media (min-width: 768px){
  .page-career .about-message-photo{
    margin:0;
    width:220px;
    height:220px;
  }
}
.page-career .about-message-text{ flex:1; min-width:0; }
.page-career .about-message-body p + p{ margin-top:12px; }
.page-career .about-message-sign{
  margin-top:24px;
  display:block;
  width:100%;
  text-align:right;
  font-size:14px;
  color:var(--text-muted);
}
.page-career .about-message-sign span{
  font-size:16px;
  font-weight:600;
  color:var(--text-main);
}

.page-career-support{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --panel: rgba(255,255,255,.82);
  --shadow: 0 16px 44px rgba(0,0,0,.06);
  --radius: 14px;
  color: var(--ink);
}

/* =========================
   Support Intro
========================= */

.page-career-support .support-intro{
  padding-top: 36px;
  padding-bottom: 24px;
}

.page-career-support .support-intro-lead{
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  letter-spacing: .08em;
  text-align: center;
  margin-bottom: 14px;
}

.page-career-support .support-intro-text{
  max-width: 60em;
  margin: 0 auto;
  font-size: 14px;
  line-height: 2.05;
  color: var(--muted);
  text-align: center;
}


/* =========================
   Support System（4 cards）
========================= */
.page-career-support .support-system{
  padding-top: 44px;
}

.page-career-support .support-grid{
  margin-top: 22px;
  display: grid;
  gap: 16px;
}
@media (min-width: 768px){
  .page-career-support .support-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
  }
}
@media (min-width: 1024px){
  .page-career-support .support-grid{ gap: 20px; }
}

.page-career-support .support-card{
  position: relative;
  padding: 22px 20px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.page-career-support .support-number{
  margin: 0 0 10px;
  font-family: "Cormorant Garamond", serif;
  font-size: 24px;
  letter-spacing: .10em;
  color: rgba(47,62,66,.55);
}
.page-career-support .support-title{
  margin: 0 0 10px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 16px;
  letter-spacing: .06em;
  line-height: 1.6;
  color: var(--ink);
}
.page-career-support .support-text{
  margin: 0;
  font-size: 13.5px;
  line-height: 2.0;
  color: var(--muted);
}

.page-career-support .support-card::before{
  content: "";
  position: absolute;
  inset: -40% -20% auto auto;
  width: 240px;
  height: 240px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(107,132,124,.14), transparent 62%);
  pointer-events: none;
}

/* =========================
   Why Support
========================= */
.page-career-support .support-why{
  padding-top: 64px;
}
.page-career-support .support-why-body{
  margin-top: 18px;
  padding: 22px 20px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.70);
}
.page-career-support .support-why-body p{
  margin: 0;
  font-size: 14px;
  line-height: 2.0;
  color: var(--muted);
}
.page-career-support .support-why-body p + p{ margin-top: 12px; }

/* =========================
   Practical Support（list）
========================= */
.page-career-support .support-practical{
  padding-top: 64px;
}
.page-career-support .support-practical-list{
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}
@media (min-width: 768px){
  .page-career-support .support-practical-list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 14px;
  }
}
.page-career-support .support-practical-list li{
  position: relative;
  padding: 14px 14px 14px 44px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255,255,255,.78);
  color: rgba(47,62,66,.86);
  line-height: 1.9;
  font-size: 13.5px;
}
.page-career-support .support-practical-list li::before{
  content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(107,132,124,.18);
  border: 1px solid rgba(61,81,85,.18);
}
.page-career-support .support-practical-note{
  margin: 16px 0 0;
  max-width: 52em;
  font-size: 13.5px;
  line-height: 2.0;
  color: var(--muted);
}

.page-career-support .final-cta .cta-box--final{
  border-radius: var(--radius, 16px);
  box-shadow: 0 16px 44px rgba(0,0,0,.06);
}

.page-career-support .final-cta .cta-box--final{
  padding: clamp(44px, 6vw, 72px);
}



/* =====================================================
  PAGE｜Voice & Success Stories
  Scope: .voice-page
===================================================== */

.voice-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --line-strong: rgba(61,81,85,.55);
  --bg-soft: #f7f6f2;
  --bg-panel: rgba(255,255,255,.86);
  --shadow: 0 14px 40px rgba(0,0,0,.06);
  --radius: 16px;
  color: var(--ink);
}

/* =====================================================
  02｜WHO（タグ）
===================================================== */

.voice-page .voice-whoLead{
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.9;
}

/* タグ（共通） */
.voice-page .voice-tags{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

/* 小さめ（カード内） */
.voice-page .voice-tags.-mini{
  gap: 6px;
  margin-top: 6px;
}

.voice-page .voice-tagChip{
  display: inline-block;
  padding: 5px 12px;
  font-size: 11px;
  letter-spacing: .06em;
  border-radius: 999px;
  background: rgba(61,81,85,.06);
  border: 1px solid rgba(61,81,85,.12);
  color: rgba(47,62,66,.86);
  line-height: 1.2;
  white-space: nowrap;
  box-shadow: none;
  cursor: default;
  user-select: none;
}

.voice-page .voice-tags.-mini .voice-tagChip{
  padding: 4px 10px;
  font-size: 10.5px;
}

/* =====================================================
  03/04｜GRID 共通
===================================================== */

.voice-page .voice-roles,
.voice-page .voice-survey{
  background: var(--bg-soft);
}

.voice-page .voice-voicesGrid{
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 12px;
}

@media (max-width: 1023px){
  .voice-page .voice-voicesGrid{
    grid-template-columns: 1fr;
  }
}

/* =====================================================
  CARD
===================================================== */

.voice-page .voice-card{
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 22px;
  border-radius: var(--radius);
}

.voice-page .voice-cardHead{
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
}

.voice-page .voice-avatar{
  width: 58px;
  height: 58px;
  border-radius: 999px;
  background: center/cover no-repeat;
  border: 1px solid rgba(61,81,85,.18);
}

/* 写真なしの人型アイコン */
.voice-page .voice-avatar.-icon{
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background: rgba(61,81,85,.10);
  position: relative;
  border: 1px solid rgba(61,81,85,.14);
}

.voice-page .voice-avatar.-icon::before{
  content:"";
  position:absolute;
  top: 12px;
  left: 50%;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(61,81,85,.55);
  transform: translateX(-50%);
}

.voice-page .voice-avatar.-icon::after{
  content:"";
  position:absolute;
  top: 26px;
  left: 50%;
  width: 22px;
  height: 14px;
  border-radius: 12px 12px 6px 6px;
  background: rgba(61,81,85,.45);
  transform: translateX(-50%);
}

.voice-page .voice-name{
  margin: 0;
  font-weight: 800;
  letter-spacing: .06em;
  font-size: 14px;
}

/* =====================================================
  TEXT
===================================================== */

.voice-page .voice-point{
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(61,81,85,.14);
}

.voice-page .voice-pointLabel{
  margin: 0 0 6px;
  font-weight: 700;
  letter-spacing: .06em;
  font-size: 12.5px;
}

.voice-page .voice-pointText{
  margin: 0;
  color: var(--muted);
  line-height: 1.9;
  font-size: 13px;
}

/* ❗途中で消える問題の解決：クランプは抜粋専用に限定 */
.voice-page .is-clamp2{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-line-clamp: 2;
}

/* =====================================================
  BTN（将来用）
===================================================== */

.voice-page .btn-mini{
  display: block;
  width: fit-content;
  margin: 14px auto 0;
  padding: 10px 18px;
  font-size: 13px;
  letter-spacing: .08em;
  line-height: 1.2;
  text-decoration: none;
  color: var(--ink);
  border: 1px solid var(--line-strong);
  background: transparent;
  border-radius: 999px;
}

@media (hover:hover) and (pointer:fine){
  .voice-page .btn-mini:hover{
    background: rgba(255,255,255,.32);
    box-shadow: 0 8px 26px rgba(0,0,0,.08);
    transform: translateX(2px);
  }
}

/* =====================================================
  TRANSFORMATION（そのまま）
===================================================== */

.voice-page .voice-gallery{
  background: var(--bg-soft);
}

.voice-page .voice-galleryGrid{
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr;
  margin-top: 12px;
}

.voice-page .voice-galleryCard{
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  overflow: hidden;
  border-radius: var(--radius);
}

.voice-page .voice-galleryCols{
  display: grid;
  grid-template-columns: 1fr 1fr;
}

@media (max-width: 767px){
  .voice-page .voice-galleryCols{
    grid-template-columns: 1fr;
  }
}

.voice-page .voice-galleryCol{
  padding: 16px;
}

.voice-page .voice-galleryBefore{
  background: rgba(243,244,244,.92);
  border-right: 1px solid rgba(61,81,85,.12);
}

@media (max-width: 767px){
  .voice-page .voice-galleryBefore{
    border-right: none;
    border-bottom: 1px solid rgba(61,81,85,.12);
  }
}

.voice-page .voice-galleryAfter{
  background: rgba(255,255,255,.92);
  position: relative;
}

.voice-page .voice-galleryAfter::before{
  content:"";
  position:absolute;
  left: 0;
  top: 0;
  width: 2px;
  height: 100%;
  background: rgba(61,81,85,.45);
  opacity: .55;
}

@media (max-width: 767px){
  .voice-page .voice-galleryAfter::before{
    width: 100%;
    height: 2px;
  }
}

.voice-page .voice-galleryPhoto{
  width: 100%;
  height: 190px;
  background: center/cover no-repeat;
  border: 1px solid rgba(61,81,85,.14);
  margin-bottom: 10px;
  border-radius: 12px;
}

@media (min-width: 1024px){
  .voice-page .voice-galleryPhoto{
    height: 200px;
  }
}

.voice-page .voice-galleryCap{
  margin: 0 0 6px;
  line-height: 1.9;
  font-size: 13px;
  color: rgba(47,62,66,.88);
}

.voice-page .voice-hand{
  margin: 0;
  font-family: "Shippori Mincho", serif;
  font-size: 13px;
  letter-spacing: .06em;
  color: rgba(61,81,85,.70);
}




/* =====================================================
  SINGLE｜Interview（JAPA / Clean）
  Scope: .page-interview-single
===================================================== */

.page-interview-single{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --panel: rgba(255,255,255,.74);
  --panel2: rgba(255,255,255,.62);
  --shadow: 0 18px 44px rgba(0,0,0,.06);
  --radius: 18px;
  --accent: rgba(54,100,100,.22);
}

body:has(.page-interview-single) #top_title_area,
body:has(.page-interview-single) .l-topTitleArea{
  display: none !important;
}

.page-interview-single .subpage-hero{
  min-height: 260px;
  padding: 72px 16px 64px;
}

.page-interview-single .subpage-hero-bg{
  background-image: url("/wp-content/uploads/2026/01/interview-hero.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

@media (max-width: 768px){
  .page-interview-single .entry-hero-bg{
    background-attachment: scroll;
  }
}

.page-interview-single .subpage-container{ max-width: 880px; }

.page-interview-single .iv-single-content{
  max-width: 760px;
  margin: 0 auto;
  color: var(--ink);
  line-height: 1.95;
}

.page-interview-single .iv-profile{
  display:flex;
  gap: 14px;
  align-items:center;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow);
  margin: 0 0 18px;
  overflow: hidden;
}

.page-interview-single .iv-avatar{
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(61,81,85,.22);
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
  flex: 0 0 auto;
}

.page-interview-single .iv-name{
  margin: 0 0 4px;
  font-weight: 700;
  letter-spacing: .01em;
}

.page-interview-single .iv-type{
  margin: 0;
  color: var(--muted);
  font-size: .92rem;
}

/* BEFORE / AFTER */
.page-interview-single .iv-ba{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 18px 0 18px;
}
@media (min-width: 860px){
  .page-interview-single .iv-ba{
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
}

.page-interview-single .iv-panel{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel2);
  box-shadow: 0 14px 34px rgba(0,0,0,.05);
  padding: 18px 20px 20px;
  position: relative;
  overflow: hidden;
}

.page-interview-single .iv-panel::after{
  content:"";
  position:absolute;
  left: 18px;
  top: 18px;
  width: 30px;
  height: 1px;
  background: var(--accent);
}

.page-interview-single .iv-panel-kicker{
  margin: 0 0 12px;
  font-weight: 700;
  letter-spacing: .14em;
  font-size: .72rem;
  color: var(--muted);
}

.page-interview-single .iv-panel-text{
  margin: 0;
}

.page-interview-single .iv-after{
  background: rgba(255,255,255,.78);
}

.page-interview-single .iv-key{
  margin: 8px 0 0;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 2px);
  background: rgba(255,255,255,.80);
  box-shadow: var(--shadow);
}

.page-interview-single .iv-key-kicker{
  margin: 0 0 6px;
  font-weight: 700;
  letter-spacing: .16em;
  font-size: .72rem;
  color: var(--muted);
}

.page-interview-single .iv-key-title{
  margin: 0 0 10px;
  font-weight: 700;
}

.page-interview-single .iv-key-text{
  margin: 0;
}

.page-interview-single .iv-cta-back{
  margin-top: 56px;
  display:flex;
  justify-content:center;
}


/* =====================================================
  ARCHIVE｜Interview（JAPA / Clean）
  Scope: .page-interview-archive
===================================================== */

.page-interview-archive{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --panel: rgba(255,255,255,.76);
  --shadow: 0 18px 44px rgba(0,0,0,.06);
  --radius: 16px;
  --accent: rgba(54,100,100,.22);
}

.page-interview-archive .subpage-container{
  max-width: 980px;
}

.page-interview-archive .iv-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 900px){
  .page-interview-archive .iv-grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }
}

.page-interview-archive .subpage-hero{
  min-height: 260px;
  padding: 72px 16px 64px;
}

.page-interview-archive .subpage-hero-bg{
  background-image: url("/wp-content/uploads/2026/01/interview-hero.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

@media (max-width: 768px){
  .page-interview-archive .entry-hero-bg{
    background-attachment: scroll;
  }
}


/* Card */
.page-interview-archive .iv-card{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease;
}

.page-interview-archive .iv-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 26px 56px rgba(0,0,0,.08);
}

.page-interview-archive .iv-card-link{
  display: flex;
  gap: 14px;
  padding: 14px 16px;
  text-decoration: none;
  color: inherit;
  align-items: flex-start;
}

.page-interview-archive .iv-avatar{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(61,81,85,.22);
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
  flex: 0 0 auto;
}

.page-interview-archive .iv-avatar.is-empty{
  background: linear-gradient(135deg, rgba(54,100,100,.18), rgba(54,100,100,.06));
  box-shadow: none;
}

/* Text */
.page-interview-archive .iv-body{
  min-width: 0;
}

.page-interview-archive .iv-name{
  margin: 0 0 3px;
  font-weight: 700;
  letter-spacing: .01em;
  color: var(--ink);
}

.page-interview-archive .iv-type{
  margin: 0 0 8px;
  color: var(--muted);
  font-size: .9rem;
}

.page-interview-archive .iv-result{
  margin: 0;
  line-height: 1.75;
  color: rgba(47,62,66,.86);
  font-size: .92rem;
}

/* More */
.page-interview-archive .iv-more{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-weight: 700;
  letter-spacing: .02em;
  color: var(--ink);
}

.page-interview-archive .iv-more::after{
  content:"";
  width: 24px;
  height: 1px;
  background: var(--accent);
  transition: width .22s ease;
}

.page-interview-archive .iv-card:hover .iv-more::after{
  width: 40px;
}

/* Pagination / Empty */
.page-interview-archive .iv-pagination{
  margin-top: 30px;
  text-align: center;
}

.page-interview-archive .iv-empty{
  text-align: center;
  color: var(--muted);
}




/* =====================================================
  PAGE｜MEMBER
  Scope: .member-page
===================================================== */

.member-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.22);
  --bg-soft: #f7f6f2;
  --bg-panel: rgba(255,255,255,.86);
  --shadow: 0 14px 40px rgba(0,0,0,.06);
  color: var(--ink);
}

/* ==============================
  02｜Overview
============================== */

.member-page .member-leadBox{
  margin-top: 18px;
  padding: 24px;
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
}
.member-page .member-leadText{
  margin:0 0 18px;
  color: rgba(47,62,66,.88);
  line-height: 2.0;
}

.member-page .member-path{
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap:wrap;
  justify-content:center;
  padding: 12px 6px;
  border-top: 1px solid rgba(61,81,85,.14);
  border-bottom: 1px solid rgba(61,81,85,.14);
}
.member-page .member-pathItem{
  text-align:center;
  min-width: 130px;
  padding: 10px 8px;
}
.member-page .member-pathEn{
  margin:0 0 4px;
  font-family:"Cormorant Garamond", serif;
  letter-spacing:.16em;
  font-size: 12px;
  color: rgba(61,81,85,.80);
}
.member-page .member-pathJa{
  margin:0;
  font-family:"Shippori Mincho", serif;
  letter-spacing:.10em;
  font-size: 13px;
  color: rgba(47,62,66,.90);
}
.member-page .member-pathLine{
  height:1px;
  width: 46px;
  background: rgba(61,81,85,.40);
  opacity:.6;
}
@media (max-width: 767px){
  .member-page .member-pathLine{ width: 24px; }
  .member-page .member-pathItem{ min-width: 120px; }
}
.member-page .member-pathNote{
  margin: 12px 0 0;
  text-align:center;
  color: var(--muted);
  font-size: 13px;
  letter-spacing:.06em;
}

/* ==============================
  03｜Benefits
============================== */

.member-page .member-benefits{ background: var(--bg-soft); }

.member-page .member-stepsGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
}
@media (max-width: 1023px){
  .member-page .member-stepsGrid{ grid-template-columns: 1fr; }
}
.member-page .member-stepCard{
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 22px;
}
.member-page .member-stepKicker{
  margin:0 0 8px;
  font-family:"Cormorant Garamond", serif;
  letter-spacing:.20em;
  font-size: 12px;
  color: rgba(61,81,85,.78);
}
.member-page .member-stepTitle{
  margin:0 0 12px;
  font-family:"Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing:.10em;
  font-size: 18px;
}
.member-page .member-list{
  margin:0;
  padding-left: 1.1em;
  color: rgba(47,62,66,.86);
  line-height: 1.95;
  font-size: 13.5px;
}

/* ==============================
  04｜Plans
============================== */

.member-page .member-planGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
  margin-top: 14px;
}
@media (max-width: 1023px){
  .member-page .member-planGrid{ grid-template-columns: 1fr; }
}
.member-page .member-planCard{
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 22px;
  position:relative;
}
.member-page .member-planCard::after{
  content:"";
  position:absolute;
  left: 16px;
  right: 16px;
  bottom: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(61,81,85,.55), transparent);
  opacity: .55;
}
.member-page .member-planCard--mid{
  border-color: rgba(61,81,85,.28);
  box-shadow: 0 18px 46px rgba(0,0,0,.07);
  transform: translateY(-2px);
}
@media (max-width: 1023px){
  .member-page .member-planCard--mid{ transform:none; }
}
.member-page .member-planName{
  margin:0 0 6px;
  font-weight: 800;
  letter-spacing:.08em;
  font-size: 14px;
}
.member-page .member-planTarget{
  margin:0 0 14px;
  color: var(--muted);
  font-size: 12.5px;
  letter-spacing:.04em;
}
.member-page .member-planPrice{
  margin:0 0 10px;
  color: rgba(47,62,66,.92);
  font-size: 13px;
}
.member-page .member-planPrice span{
  font-family:"Cormorant Garamond", serif;
  font-size: 34px;
  letter-spacing:.04em;
  margin-left: 6px;
}
.member-page .member-planDesc{
  margin:0;
  color: rgba(47,62,66,.80);
  line-height: 1.95;
  font-size: 13.5px;
}
.member-page .member-planNote{
  margin-top: 18px;
  color: var(--muted);
  font-size: 12.5px;
  letter-spacing:.06em;
  text-align:center;
}
.member-page .member-planNote p{ margin: 6px 0 0; }

/* ==============================
  05｜Support（チェックリスト）
============================== */

.member-page .member-support{ background: var(--bg-soft); }

.member-page .member-supportBox{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  margin-top: 14px;
}
@media (max-width: 1023px){
  .member-page .member-supportBox{ grid-template-columns: 1fr; }
}

.member-page .member-supportText{
  background: var(--bg-panel);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 22px;
}

.member-page .member-checklist{
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
  color: rgba(47,62,66,.86);
  line-height: 1.9;
  font-size: 13.5px;
}
.member-page .member-checklist li{
  position: relative;
  padding-left: 1.8em;
}
.member-page .member-checklist li::before{
  content:"✓";
  position: absolute;
  left: 0;
  top: .05em;
  width: 1.4em;
  height: 1.4em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(61,81,85,.20);
  border-radius: 999px;
  color: rgba(61,81,85,.80);
  background: rgba(255,255,255,.55);
  font-weight: 700;
  font-size: 12px;
}

.member-page .member-supportMedia{
  min-height: 260px;
  background:center/cover no-repeat;
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
}

/* ==============================
  06｜Flow
============================== */

.member-page .member-flow{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
  margin-top: 14px;
}
@media (max-width: 1023px){
  .member-page .member-flow{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 767px){
  .member-page .member-flow{ grid-template-columns: 1fr; }
}

.member-page .member-flowItem{
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 18px;
  position:relative;
}
.member-page .member-flowItem::before{
  content:"";
  position:absolute;
  left: 16px;
  right: 16px;
  top: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(61,81,85,.55), transparent);
  opacity: .45;
}
.member-page .member-flowNum{
  margin:0 0 8px;
  font-family:"Cormorant Garamond", serif;
  font-size: 28px;
  letter-spacing:.06em;
  color: rgba(61,81,85,.78);
}
.member-page .member-flowTitle{
  margin:0 0 6px;
  font-family:"Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing:.10em;
  font-size: 15px;
}
.member-page .member-flowText{
  margin:0;
  color: var(--muted);
  line-height: 1.9;
  font-size: 13px;
}


/* ==============================
  08｜FAQ
============================== */

.member-page .member-faq{
  background: var(--bg-soft);
}

.member-page .member-faq .faq-list{
  max-width: 860px;
  margin: 14px auto 0;
  background: rgba(255,255,255,.88);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  border-radius: 10px;
  overflow: hidden;
}

/* Item */
.member-page .member-faq .faq-item{
  border-bottom: 1px solid rgba(61,81,85,.12);
}
.member-page .member-faq .faq-item:last-child{
  border-bottom: none;
}

/* Q */
.member-page .member-faq .faq-q{
  cursor: pointer;
  position: relative;
  padding: 18px 54px 18px 18px;
  line-height: 1.7;
  font-weight: 600;
  color: rgba(47,62,66,.92);
  letter-spacing: .02em;
  user-select: none;
  list-style: none;
}
.member-page .member-faq .faq-q::-webkit-details-marker{ display:none; }

@media (hover:hover) and (pointer:fine){
  .member-page .member-faq .faq-item summary:hover{
    background: rgba(247,246,242,.70);
  }
}

.member-page .member-faq .faq-q::after{
  content: "+";
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;

  display: flex;
  align-items: center;
  justify-content: center;

  line-height: 1;
  padding-bottom: 1px;

  border: 1px solid rgba(61,81,85,.20);
  border-radius: 999px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 18px;
  color: rgba(61,81,85,.75);
  background: rgba(255,255,255,.55);
}

.member-page .member-faq .faq-item[open] summary{
  background: rgba(247,246,242,.80);
}
.member-page .member-faq .faq-item[open] .faq-q::after{
  content: "−";
  border-color: rgba(61,81,85,.28);
  color: rgba(61,81,85,.85);
}

/* A */
.member-page .member-faq .faq-a{
  padding: 0 18px 18px 54px;
  font-size: 13.5px;
  line-height: 1.95;
  color: rgba(47,62,66,.72);
}
.member-page .member-faq .faq-a p{ margin: 0; }

/* footer buttons */
.member-page .member-faq .faq-foot{
  max-width: 860px;
  margin: 22px auto 0;
  text-align: center;
}
.member-page .member-faq .faq-footBtns{
  margin-top: 10px;
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* =====================================
   Member｜FAQ footer buttons
===================================== */

.member-page .member-faq .faq-footBtns{
  margin-top: 24px;
}

.member-page .member-faq .btn-line{
  background: transparent;
  box-shadow: none;
}

@media (hover:hover) and (pointer:fine){
  .member-page .member-faq .btn-line:hover{
    background-color: rgba(255,255,255,.25);
    box-shadow: 0 4px 14px rgba(0,0,0,.06);
    transform: translateX(2px);
  }
}

.member-page .member-faq .faq-list{
  margin-bottom: 40px;
}

@media (min-width: 768px){
  .member-page .member-faq .faq-list{
    margin-bottom: 56px;
  }
}

/* =====================================================
  PAGE｜Qualification（FULL REPLACE）
  Scope: .subpage.page-qualification
===================================================== */

.subpage.page-qualification{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --panel: rgba(255,255,255,.92);
  --soft: rgba(232,236,232,.55);
  --radius: 12px;

  color: var(--ink);
}

.subpage.page-qualification .subpage-section{ padding: 64px 16px; }
.subpage.page-qualification .subpage-container{ max-width: 960px; margin: 0 auto; }

/* =====================================================
  Text
===================================================== */

.page-qualification .qualification-text{
  margin: 0;
  color: var(--muted);
  line-height: 1.9;
}

.page-qualification .qualification-note{
  margin: 16px 0 0;
  color: var(--muted);
  line-height: 1.9;
  font-size: 16px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
}

.page-qualification .qualification-note.-emphasis{
  margin: 0 24px 24px;
  padding: 0 16px 16px;
  border-left: 1px solid rgba(47,62,66,.18);
  color: var(--ink);
}

/* =====================================================
  Media layout
  HTML: .qual-media -right / -left
===================================================== */

.page-qualification .qual-media{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 28px;
  align-items: start;
}

.page-qualification .qual-media.-right{ grid-template-columns: 1fr auto; }
.page-qualification .qual-media.-left{  grid-template-columns: auto 1fr; }

.page-qualification .qual-photo{
  margin: 0;
  width: clamp(260px, 28vw, 420px);
  aspect-ratio: 4 / 5;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 12px 34px rgba(0,0,0,.06);
  background: var(--soft);
}

.page-qualification .qual-photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.page-qualification .qualification-philosophy .qual-photo{
  aspect-ratio: 16 / 10;
}

.page-qualification .qual-body{
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

/* =====================================================
  Lists（HTML: .qualification-list）
===================================================== */

.page-qualification .qualification-list{
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.page-qualification .qualification-list li{
  position: relative;
  padding-left: 26px;
  line-height: 1.9;
  color: var(--ink);
}

.page-qualification .qualification-list li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0.9em;
  transform: translateY(-50%);
  font-size: 0.85em;
  color: rgba(47,62,66,.55);
}

/* =====================================================
  POSITION（HTML: .qualification-box）
===================================================== */

.page-qualification .qualification-box{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: 0 10px 28px rgba(0,0,0,.05);
}

.page-qualification .qualification-box .qualification-note.-emphasis{
  margin: 24px 0 0;
  padding: 20px 24px;
  background: rgba(232,236,232,.5);
  border: none;
  border-radius: 12px;

  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.9;
  letter-spacing: .02em;
  color: var(--ink);
}

/* =====================================================
  STEP（HTML: .qualification-steps / .qualification-stepCard）
===================================================== */

.page-qualification .qualification-steps{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 16px;
}

.page-qualification .qualification-stepCard{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px;
  box-shadow: 0 10px 30px rgba(0,0,0,.04);
}

.page-qualification .qualification-step-title{
  margin: 0 0 10px;
  font-size: 1.05rem;
  line-height: 1.45;
  letter-spacing: .02em;
  color: var(--ink);
}

.page-qualification .qualification-step-text{
  margin: 0;
  color: var(--muted);
  line-height: 2;
  font-size: 0.98rem;
}

.page-qualification .qualification-step .qualification-note{ margin-top: 18px; }

/* =====================================================
  CTA（HTML: .qualification-cta）
===================================================== */

.page-qualification .qualification-cta{
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  width: min(520px, 100%);
}

.page-qualification .qualification-cta .btn-line{
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  text-align: center;
}

/* =====================================================
  Responsive
===================================================== */

@media (max-width: 960px){
  .page-qualification .qual-media,
  .page-qualification .qual-media.-left,
  .page-qualification .qual-media.-right{
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .page-qualification .qual-photo{
    width: 100%;
    aspect-ratio: 16 / 9;
  }

  .page-qualification .qualification-steps{
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .page-qualification .qualification-stepCard{ padding: 18px 16px; }

  .page-qualification .qualification-cta{
    grid-template-columns: 1fr;
    width: 100%;
  }

  .page-qualification .qualification-box{ padding: 18px 16px; }

  .page-qualification .qualification-box .qualification-note.-emphasis{
    padding: 18px 16px;
    font-size: 1.15rem;
  }
}

@media (max-width: 767px){
  .page-qualification .qualification-cta{
    width: 100%;
    max-width: none;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .page-qualification .qualification-cta .btn-line{
    width: 100%;
    max-width: 360px;
    margin: 0 auto;
  }
}



/* =====================================================
  PAGE｜ACTIVITY FIELDS（Split Layout）
  Scope: .page-activity-fields
===================================================== */

.page-activity-fields{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --panel: rgba(255,255,255,.92);
  --radius: 14px;

  --sec-pad: 72px;
  --sec-pad-sp: 52px;

  color: var(--ink);
}

.page-activity-fields .subpage-section{
  padding: var(--sec-pad) 16px;
}
@media (max-width: 767px){
  .page-activity-fields .subpage-section{
    padding: var(--sec-pad-sp) 16px;
  }
}

.page-activity-fields .section-title-en,
.page-activity-fields .section-title-ja{
  text-align: center;
}

/* Intro */
.page-activity-fields .activity-intro-text{
  max-width: 860px;
  margin: 0 auto;
  line-height: 2;
  color: var(--muted);
}
.page-activity-fields .activity-intro-text + .activity-intro-text{
  margin-top: 18px;
}

/* STAGE lead */
.page-activity-fields .activity-stage-lead{
  max-width: 900px;
  margin: 0 auto 28px;
  color: var(--muted);
  line-height: 2;
}

/* =========================================
  Split card
========================================= */

.page-activity-fields .activity-detail.activity-split{
  display: grid;
  grid-template-columns: 40% 1fr;
  gap: 28px;

  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;

  box-shadow: 0 10px 30px rgba(0,0,0,.04);
}

.page-activity-fields .activity-detail + .activity-detail{
  margin-top: 22px;
}

.page-activity-fields .activity-media{
  border-radius: 12px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 240px;
}

.page-activity-fields .activity-content{
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.page-activity-fields .activity-detail-title{
  font-size: 1.3rem !important;
  line-height: 1.45;
  margin: 0 0 0.6em;
  letter-spacing: .02em;
  color: var(--ink);
}

.page-activity-fields .activity-detail-text{
  margin: 0;
  color: var(--muted);
  line-height: 2;
  font-size: 0.98rem;
}
.page-activity-fields .activity-detail-text + .activity-detail-text{
  margin-top: 14px;
}

/* list */
.page-activity-fields .activity-detail-list{
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  display: grid;
  gap: 10px;
}
.page-activity-fields .activity-detail-list li{
  position: relative;
  padding-left: 18px;
  line-height: 1.9;
  color: var(--ink);
  font-size: 1rem;
}
.page-activity-fields .activity-detail-list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0.9em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(61,81,85,.35);
  transform: translateY(-50%);
}

/* anchor offset */
.page-activity-fields .activity-detail[id]{
  scroll-margin-top: 120px;
}

/* =========================================
  CTA links
========================================= */

.page-activity-fields .activity-next-lead{
  max-width: 860px;
  margin: 0 auto 22px;
  color: var(--muted);
  line-height: 2;
}

.page-activity-fields .activity-next-links{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;

  max-width: 960px;
  margin: 0 auto;
}

.page-activity-fields .activity-next-links .btn-line{
  width: 100%;
  justify-content: center;
  text-align: center;
  padding-left: 18px;
  padding-right: 18px;
}

/* =========================================
  Responsive
========================================= */

@media (max-width: 900px){
  .page-activity-fields .activity-detail.activity-split{
    grid-template-columns: 1fr;
    padding: 22px 18px;
    gap: 18px;
  }

  .page-activity-fields .activity-media{
    min-height: 180px;
  }

  .page-activity-fields .activity-next-links{
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

/* =========================================
  Images
========================================= */

.page-activity-fields .activity-media.living{
  background-image: url("/wp-content/uploads/2026/01/field-living.jpg");
}
.page-activity-fields .activity-media.education{
  background-image: url("/wp-content/uploads/2026/01/field-education.jpg");
}
.page-activity-fields .activity-media.corporate{
  background-image: url("/wp-content/uploads/2026/01/field-corporate.jpg");
}
.page-activity-fields .activity-media.salon{
  background-image: url("/wp-content/uploads/2026/01/field-salon.jpg");
}
.page-activity-fields .activity-media.personal{
  background-image: url("/wp-content/uploads/2026/01/field-personal.jpg");
}


/* =====================================================
  PAGE｜OUR STRENGTHS
  Scope: .page-our-strengths
===================================================== */

.page-our-strengths{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);

  --panel: rgba(255,255,255,.86);
  --panel-soft: rgba(255,255,255,.72);

  --radius: 16px;
  --shadow: 0 14px 28px rgba(0,0,0,.05);

  --accent: #3a6b66;
  --accent-soft: rgba(58,107,102,.14);

  color: var(--ink);
}

/* ====== Section base ====== */
.page-our-strengths .subpage-section{ padding: 64px 16px; }
.page-our-strengths .subpage-container{ max-width: 980px; margin: 0 auto; }


/* =========================================
  OUR STRENGTHS｜Intro
========================================= */
.page-our-strengths .strengths-intro{
  text-align: center;
  margin: 0 0 32px;
}

.page-our-strengths .strengths-intro-heading{
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  letter-spacing: .08em;
  margin: 0 0 10px !important;
  line-height: 1.5;
}

.page-our-strengths .strengths-intro-lead{
  margin: 0 !important;
  font-size: 14px;
  line-height: 1.95;
  color: rgba(47,62,66,.75);
  max-width: 60em;
  margin-left: auto !important;
  margin-right: auto !important;
}

.page-our-strengths .strengths-intro-lead strong{
  font-weight: 600;
  color: rgba(47,62,66,.92);
  text-decoration: underline;
  text-decoration-color: rgba(58,107,102,.22);
  text-underline-offset: 4px;
}

@media (max-width: 767px){
  .page-our-strengths .strengths-intro{ margin-bottom: 36px; }
}


/* =====================================================
  Feature blocks
===================================================== */
.page-our-strengths .feature-block{
  padding: 22px 0 26px;
  border-top: 1px solid rgba(61,81,85,.10);
}
.page-our-strengths .feature-block:first-of-type{
  border-top: 0;
  padding-top: 6px;
}

.page-our-strengths .feature-main{
  display:grid;
  gap:14px;
}

/* ====== Card ====== */
.page-our-strengths .strength-card{
  border:1px solid rgba(61,81,85,.14);
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 18px 16px;
}

.page-our-strengths .strength-head{
  display:flex;
  align-items:center;
  gap:12px;
}

.page-our-strengths .strength-icon{
  width:40px;
  height:40px;
  display:grid;
  place-items:center;
  border-radius:14px;
  border:1px solid rgba(61,81,85,.18);
  background: rgba(255,255,255,.75);
  color: rgba(58,107,102,.78);
  flex: 0 0 auto;
}
.page-our-strengths .strength-icon-svg,
.page-our-strengths .strength-icon svg{
  width:22px;
  height:22px;
  display:block;
}

.page-our-strengths .strength-title{
  margin:0 !important;
  font-size:1.08rem;
  line-height:1.35;
  color:var(--ink);
}

.page-our-strengths .strength-sub{
  margin:10px 0 0;
  font-size:.9rem;
  letter-spacing:.02em;
  color: rgba(58,107,102,.78);
}

.page-our-strengths .strength-desc{
  margin:10px 0 0;
  color: var(--muted);
  line-height: 1.95;
  min-height: 3.6em;
}

.page-our-strengths .skim-strip{
  margin-top: 2px;
  display:flex;
  gap:10px;
  overflow-x:auto;

  padding: 6px 12px 12px;
  margin-left: -12px;
  margin-right: -12px;

  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;

  -webkit-mask-image: linear-gradient(to right, transparent, #000 10%, #000 90%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 10%, #000 90%, transparent);
}
.page-our-strengths .skim-strip::-webkit-scrollbar{ height:6px; }
.page-our-strengths .skim-strip::-webkit-scrollbar-thumb{
  background: rgba(61,81,85,.18);
  border-radius:999px;
}
.page-our-strengths .skim-chip{
  flex:0 0 auto;
  scroll-snap-align:start;
  border:1px solid rgba(61,81,85,.12);
  background: rgba(255,255,255,.78);
  border-radius:999px;
  padding: 9px 12px;
  font-size:.86rem;
  color: rgba(47,62,66,.82);
  white-space:nowrap;
  box-shadow: 0 8px 18px rgba(0,0,0,.04);
}

.page-our-strengths .feature-copy{
  margin:0;
  color: var(--muted);
  line-height: 1.95;
}
.page-our-strengths .feature-copy strong{
  color: rgba(47,62,66,.92);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-color: rgba(58,107,102,.24);
  text-underline-offset: 4px;
}

.page-our-strengths .feature-media{
  margin: 14px 0 0;
  border:1px solid rgba(61,81,85,.14);
  border-radius: var(--radius);
  overflow:hidden;
  background: var(--panel-soft);
  box-shadow: var(--shadow);
}
.page-our-strengths .feature-media img{
  width:100%;
  height:auto;
  display:block;
}
.page-our-strengths .feature-media figcaption{
  padding: 10px 12px;
  font-size: .85rem;
  color: rgba(47,62,66,.70);
  line-height: 1.7;
}

/* =====================================================
  VARIANTS
===================================================== */

.page-our-strengths .feature-block.v01 .strength-card{
  border-radius: 18px;
}

.page-our-strengths .feature-block.v02 .feature-media.is-primary{
  margin: 10px 0 0;
}
.page-our-strengths .feature-block.v02 .strength-card{
  background: rgba(255,255,255,.78);
}
.page-our-strengths .feature-block.v02 .skim-strip{
  margin-top: 0;
}

.page-our-strengths .feature-block.v03 .strength-card{
  background: rgba(255,255,255,.78);
  border-left: 3px solid rgba(58,107,102,.32);
}
.page-our-strengths .feature-quote{
  margin: 2px 0 0;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(58,107,102,.08);
  border: 1px solid rgba(61,81,85,.10);
  color: rgba(47,62,66,.86);
  line-height: 1.9;
}
.page-our-strengths .feature-quote strong{
  text-decoration: underline;
  text-decoration-color: rgba(58,107,102,.22);
  text-underline-offset: 4px;
}

.page-our-strengths .feature-block.v04 .skim-strip{ display:none; }

.page-our-strengths .keys{
  display:grid;
  gap:8px;
  margin: 2px 0 0;
  padding:0;
  list-style:none;
}
.page-our-strengths .keys li{
  position:relative;
  display:block;
  padding: 10px 12px 10px 28px;
  border-radius: 14px;
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(61,81,85,.10);
  color: rgba(47,62,66,.82);
  line-height: 1.85;
  word-break: normal;
  overflow-wrap: break-word;
  white-space: normal;
}
.page-our-strengths .keys li::before{
  content:"";
  position:absolute;
  left:12px;
  top: 1.05em;
  width:10px;
  height:10px;
  border-radius:999px;
  background: rgba(58,107,102,.28);
  border: 1px solid rgba(61,81,85,.12);
  transform: translateY(-50%);
}
.page-our-strengths .keys li strong{
  color: rgba(47,62,66,.92);
  font-weight: 600;
}

.page-our-strengths .feature-block.v04 .strength-card{
  background: rgba(255,255,255,.92);
}

/* =====================================================
  PC
===================================================== */
@media (min-width: 900px){

  .page-our-strengths .feature-block{
    display:grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 22px;
    align-items: start;
    padding: 26px 0 30px;
  }

  .page-our-strengths .feature-block.is-media-right .feature-main{ grid-column: 1; }
  .page-our-strengths .feature-block.is-media-right .feature-media{ grid-column: 2; margin-top: 0; }

  .page-our-strengths .feature-block.is-media-left{ grid-template-columns: .85fr 1.15fr; }
  .page-our-strengths .feature-block.is-media-left .feature-media{ grid-column: 1; margin-top: 0; }
  .page-our-strengths .feature-block.is-media-left .feature-main{ grid-column: 2; }

  .page-our-strengths .feature-block.v02{
    grid-template-columns: 1fr 1fr;
  }
  .page-our-strengths .feature-block.v02 .feature-media.is-primary{
    margin-top: 0;
  }

  .page-our-strengths .skim-strip{
    margin-left: 0;
    margin-right: 0;
    padding-left: 2px;
    padding-right: 2px;
    -webkit-mask-image: none;
    mask-image: none;
  }

  .page-our-strengths #strength-04{
    display:grid !important;
    grid-template-columns: .85fr 1.15fr !important;
    gap: 22px !important;
    align-items: start !important;
  }
  .page-our-strengths #strength-04 .feature-media{
    grid-column: 1 !important;
    grid-row: 1 !important;
    margin-top: 0 !important;
    align-self: start !important;
    min-width: 0;
  }
  .page-our-strengths #strength-04 .feature-main{
    grid-column: 2 !important;
    min-width: 0;
  }
}

/* =========================================
   OUR STRENGTHS｜SP
========================================= */
@media (max-width: 767px){

  .page-our-strengths .feature-block{
    display: flex;
    flex-direction: column;
  }

  .page-our-strengths .feature-main{
    order: 1;
  }

  .page-our-strengths .feature-media{
    order: 2;
    margin-top: 16px;
  }

  .page-our-strengths .feature-block{
    display: flex !important;
    flex-direction: column !important;
  }

  .page-our-strengths .feature-block > .feature-main{
    order: 1 !important;
  }

  .page-our-strengths .feature-block > .feature-media{
    order: 2 !important;
    margin-top: 16px;
  }
}





/* =====================================================
  PAGE｜Support & Follow
  Scope: .page-follow
===================================================== */

.page-follow{
  --ink:#2f3e42;
  --muted:rgba(47,62,66,.72);
  --line:rgba(61,81,85,.18);
  --panel:rgba(255,255,255,.9);
  --radius:14px;
  color:var(--ink);
}

/* Overview */
.page-follow .follow-leadBox{
  margin-top:24px;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
}
.page-follow .follow-leadText{
  line-height:2;
  color:var(--muted);
}

/* Flow */
.page-follow .follow-path{
  margin-top:22px;
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.page-follow .follow-pathItem{
  min-width:120px;
  text-align:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px;
}
.page-follow .follow-pathEn{
  font-family:"Cormorant Garamond",serif;
  letter-spacing:.18em;
  font-size:12px;
}
.page-follow .follow-pathJa{
  font-size:13px;
}
.page-follow .follow-pathLine{
  flex:1;
  height:1px;
  background:var(--line);
}

/* During & After */
.page-follow .follow-twoCol{
  margin-top:24px;
  display:grid;
  grid-template-columns:46% 1fr;
  gap:26px;
}
.page-follow .follow-media{
  min-height:340px;
  border-radius:var(--radius);
  background-size:cover;
  background-position:center;
}
.page-follow .follow-listBlock{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  margin-bottom:16px;
}
.page-follow .follow-list{
  list-style:none;
  padding:0;
  margin:0;
}
.page-follow .follow-list li{
  padding-left:16px;
  position:relative;
  line-height:1.9;
}
.page-follow .follow-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.9em;
  width:6px;
  height:6px;
  border-radius:50%;
  background:rgba(61,81,85,.35);
}

/* Testimonials */
.page-follow .follow-voiceGrid{
  margin-top:24px;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.page-follow .follow-voiceCard{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
}

/* FAQ下は枠なし */
.page-follow .follow-faq .faq-foot{
  margin-top:22px;
  border:none;
  background:transparent;
}

/* CTA */
.page-follow .follow-cta{
  text-align:center;
}
.page-follow .follow-ctaCatch{
  font-size:1.25rem;
  margin-bottom:14px;
}
.page-follow .follow-ctaBtns{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
}

/* ===============================
   PAGE｜Follow：DURING & AFTER（SP readability）
   =============================== */
@media (max-width: 767px){
  .page-follow .follow-twoCol{
    grid-template-columns: 1fr;
    gap: 18px;
    margin-top: 18px;
  }

  .page-follow .follow-media{
    min-height: 0;
    height: 200px;
    border-radius: var(--radius);
    background-position: center;
  }

  .page-follow .follow-lists{
    display: grid;
    gap: 14px;
  }

  .page-follow .follow-listBlock{
    padding: 18px 16px;
    margin-bottom: 0;
  }

  .page-follow .follow-listTitle{
    font-weight: 800;
    letter-spacing: .06em;
    margin: 0 0 10px;
    font-size: 1rem;
    color: var(--ink);
  }

  .page-follow .follow-list li{
    padding-left: 14px;
    line-height: 1.85;
  }

  .page-follow .follow-list li + li{
    margin-top: 8px;
  }

  .page-follow .follow-list li::before{
    top: .75em;
    width: 6px;
    height: 6px;
    background: rgba(61,81,85,.42);
  }
}


/* =====================================================
  PAGE｜Contact
===================================================== */

.page-contact{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.22);

  --bg-soft: #f7f6f2;
  --bg-panel: rgba(255,255,255,.90);

  --radius: 10px;
  --shadow: 0 12px 30px rgba(0,0,0,.05);
  --border: 1px solid rgba(61,81,85,.14);

  color: var(--ink);
}

/* =========================
   共通：Panel/Card
========================= */
.page-contact .contact-leadBox,
.page-contact .contact-formBox,
.page-contact .contact-formHelp,
.page-contact .contact-infoBox,
.page-contact .contact-linkCard{
  background: var(--bg-panel);
  box-shadow: var(--shadow);
  border-radius: var(--radius);
}

.page-contact .contact-linkCard{
  border: var(--border);
}

/* =========================
   Intro box
========================= */
.page-contact .contact-leadBox{
  margin-top: 14px;
  padding: 22px;
}

.page-contact .contact-leadText{
  margin:0 0 10px;
  color: rgba(47,62,66,.84);
  line-height: 1.95;
}

.page-contact .contact-note{
  margin:0;
  font-size: 13px;
  color: rgba(47,62,66,.70);
}

/* =========================
   Form grid
========================= */
.page-contact .contact-formGrid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
}

@media (max-width: 1023px){
  .page-contact .contact-formGrid{ grid-template-columns: 1fr; }
}

.page-contact .contact-formBox,
.page-contact .contact-formHelp{
  padding: 22px;
}

/* Help */
.page-contact .contact-formHelpTitle{
  margin:0 0 10px;
  font-family:"Shippori Mincho", serif;
  letter-spacing:.10em;
  font-weight:400;
  color: rgba(47,62,66,.92);
}

.page-contact .contact-formHelpList{
  margin:0;
  padding-left: 1.1em;
  color: rgba(47,62,66,.82);
  line-height: 2.0;
  font-size: 13.5px;
}

.page-contact .contact-formHelpList a{
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.page-contact .ff_form_wrap input,
.page-contact .ff_form_wrap select,
.page-contact .ff_form_wrap textarea{
  max-width: 100%;
}

/* =========================
   FAQ + Briefing（siblingCtas）
========================= */
.page-contact .contact-siblingGrid{
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}

@media (max-width: 767px){
  .page-contact .contact-siblingGrid{
    grid-template-columns: 1fr;
  }
}

.page-contact .contact-faqCard,
.page-contact .contact-briefingCard{
  padding: 22px 22px 20px;
}

.page-contact .contact-cardLabel{
  margin: 0 0 10px;
  font-family: "Cormorant Garamond", serif;
  font-size: 14px;
  letter-spacing: .18em;
  color: rgba(47,62,66,.70);
  text-transform: uppercase;
}

.page-contact .contact-linkTitle{
  margin: 0 0 10px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .10em;
  color: rgba(47,62,66,.92);
  font-size: 16px;
}

.page-contact .contact-linkText{
  margin: 0 0 14px;
  color: rgba(47,62,66,.78);
  line-height: 1.95;
  font-size: 13.5px;
}

.page-contact .contact-linkCard .btn-line{
  justify-self: start;
}

.page-contact .contact-cardNote{
  margin: 10px 0 0;
  font-size: 12.5px;
  color: rgba(47,62,66,.62);
}

.page-contact .contact-faqLink .contact-linkCard{
  margin-top: 14px;
  padding: 22px;
}

/* =========================
   Info
========================= */
.page-contact .contact-infoBox{
  margin-top: 14px;
  padding: 22px;
  border: var(--border);
}

.page-contact .contact-infoRow{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(61,81,85,.12);
}

.page-contact .contact-infoRow:last-child{ border-bottom:none; }

@media (max-width: 767px){
  .page-contact .contact-infoRow{
    grid-template-columns: 1fr;
    gap: 6px;
  }
}

/* =========================
   SP
========================= */
@media (max-width: 767px){
  .page-contact .contact-leadBox,
  .page-contact .contact-formBox,
  .page-contact .contact-formHelp,
  .page-contact .contact-infoBox,
  .page-contact .contact-linkCard{
    padding: 18px 16px;
  }

  .page-contact .contact-faqCard,
  .page-contact .contact-briefingCard{
    padding: 18px 16px 16px;
  }
}

/* =====================================================
  PAGE｜法人正会員（入会・更新）
  Scope: .corp-membership-page
===================================================== */

.corp-membership-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.14);
  --panel: rgba(255,255,255,.92);
  --soft: #f7f6f2;
  --radius: 10px;
  --shadow: 0 12px 34px rgba(0,0,0,.05);

  --w: 920px;
  --w-narrow: 860px;

  color: var(--ink);
}

.corp-membership-page .subpage-container{
  max-width: var(--w);
}

/* section */
.corp-membership-page .corp-section{}
.corp-membership-page .corp-soft{ background: var(--soft); }

/* note */
.corp-membership-page .corp-note{
  margin: 12px 0 0;
  color: rgba(47,62,66,.62);
  font-size: 13px;
  line-height: 1.9;
}
.corp-membership-page .corp-note--hero{
  color: rgba(255,255,255,.78);
}

/* text */
.corp-membership-page .corp-text{
  margin: 0;
  color: rgba(47,62,66,.80);
  font-size: 14.5px;
  line-height: 1.95;
}

/* Panel */
.corp-membership-page .corp-panel{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px;
}
@media (max-width: 767px){
  .corp-membership-page .corp-panel{ padding: 18px 16px; }
}

/* =====================================================
  INDEX（Hero外）
===================================================== */

.corp-membership-page .corp-indexSection{
  padding: 26px 16px 10px;
}
@media (max-width: 767px){
  .corp-membership-page .corp-indexSection{
    padding: 20px 16px 6px;
  }
}

.corp-membership-page .corp-index{
  margin: 0 auto;
  max-width: 960px;
}

.corp-membership-page .corp-index-list{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px 18px;
  justify-items: center;
  align-items: center;
}

.corp-membership-page .corp-index-list li{
  width: 100%;
  text-align: center;
}

.corp-membership-page .corp-index-list a{
  display: inline-block;
  position: relative;
  text-decoration: none;
  color: rgba(47,62,66,.82);
  font-size: 13.5px;
  letter-spacing: .06em;
  padding-bottom: 2px;
}
.corp-membership-page .corp-index-list a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background: rgba(61,81,85,.45);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
}
@media (hover:hover) and (pointer:fine){
  .corp-membership-page .corp-index-list a:hover::after{ transform: scaleX(1); }
}
@media (max-width: 1023px){
  .corp-membership-page .corp-index-list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 14px;
  }
}
@media (max-width: 767px){
  .corp-membership-page .corp-index-list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 12px;
  }
}

/* =====================================================
  BENEFITS（見やすいSTEP版）
===================================================== */

.corp-membership-page .corp-stepsGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
  margin-top: 14px;
}
@media (max-width: 1023px){
  .corp-membership-page .corp-stepsGrid{ grid-template-columns: 1fr; }
}

.corp-membership-page .corp-stepCard{
  background: var(--panel);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 22px;
}

.corp-membership-page .corp-stepKicker{
  margin:0 0 8px;
  font-family:"Cormorant Garamond", serif;
  letter-spacing:.20em;
  font-size: 12px;
  color: rgba(61,81,85,.78);
}

.corp-membership-page .corp-stepTitle{
  margin:0 0 12px;
  font-family:"Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing:.10em;
  font-size: 16px;
  color: rgba(47,62,66,.92);
}

.corp-membership-page .corp-list{
  margin:0;
  padding-left: 1.1em;
  color: rgba(47,62,66,.86);
  line-height: 1.95;
  font-size: 13.5px;
}
.corp-membership-page .corp-list small{
  color: rgba(47,62,66,.58);
  font-size: 12.5px;
  letter-spacing: .02em;
}

.corp-membership-page .corp-links{
  margin-top: 18px;
  display: flex;
  justify-content: center;
}

/* =====================================================
  FLOW（カード並び）
===================================================== */

.corp-membership-page .corp-flow{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
  margin-top: 14px;
}
@media (max-width: 1023px){
  .corp-membership-page .corp-flow{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 767px){
  .corp-membership-page .corp-flow{ grid-template-columns: 1fr; }
}

.corp-membership-page .corp-flowItem{
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 18px;
  position:relative;
}

.corp-membership-page .corp-flowItem::before{
  content:"";
  position:absolute;
  left: 16px;
  right: 16px;
  top: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(61,81,85,.55), transparent);
  opacity: .45;
}

.corp-membership-page .corp-flowNum{
  margin:0 0 8px;
  font-family:"Cormorant Garamond", serif;
  font-size: 28px;
  letter-spacing:.06em;
  color: rgba(61,81,85,.78);
}
.corp-membership-page .corp-flowTitle{
  margin:0 0 6px;
  font-weight: 700;
  letter-spacing:.06em;
  font-size: 14px;
  color: rgba(47,62,66,.92);
}
.corp-membership-page .corp-flowText{
  margin:0;
  color: rgba(47,62,66,.72);
  line-height: 1.9;
  font-size: 13px;
}

/* =====================================================
  TABLE（SPは data-labelで縦表示）
===================================================== */

.corp-membership-page .corp-table-wrap{
  margin-top: 14px;
  border: 1px solid var(--line);
  overflow: hidden;
  background: rgba(255,255,255,.70);
}

.corp-membership-page .corp-table{
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.corp-membership-page .corp-table th,
.corp-membership-page .corp-table td{
  padding: 12px 12px;
  border-bottom: 1px solid rgba(61,81,85,.12);
  text-align: left;
  vertical-align: top;
}

.corp-membership-page .corp-table th{
  background: rgba(247,246,242,.85);
  color: rgba(47,62,66,.90);
  font-weight: 700;
}

.corp-membership-page .corp-table tr.is-total td{
  font-weight: 700;
  background: rgba(247,246,242,.65);
}

@media (max-width: 767px){
  .corp-membership-page .corp-table thead{ display:none; }
  .corp-membership-page .corp-table,
  .corp-membership-page .corp-table tbody,
  .corp-membership-page .corp-table tr,
  .corp-membership-page .corp-table td{ display:block; width:100%; }

  .corp-membership-page .corp-table tr{
    padding: 10px 10px;
    border-bottom: 1px solid rgba(61,81,85,.12);
    background: rgba(255,255,255,.75);
  }
  .corp-membership-page .corp-table td{
    border: none;
    padding: 6px 0;
    font-size: 13.5px;
  }
  .corp-membership-page .corp-table td::before{
    content: attr(data-label);
    display: block;
    font-size: 12px;
    letter-spacing: .06em;
    color: rgba(47,62,66,.60);
    margin-bottom: 2px;
  }
  .corp-membership-page .corp-table tr.is-total{
    background: rgba(247,246,242,.80);
  }
}

/* bullets */
.corp-membership-page .corp-bullets{
  margin: 14px 0 0;
  padding-left: 1.2em;
  color: rgba(47,62,66,.78);
}
.corp-membership-page .corp-bullets li{
  margin: 0 0 8px;
  line-height: 1.9;
}
.corp-membership-page .corp-bullets.is-ol{ padding-left: 1.25em; }

/* =====================================================
  REFERENCE（外部 ↗）
===================================================== */

.corp-membership-page .corp-links-list{
  list-style: none;
  padding: 0;
  margin: 16px auto 0;
  display: grid;
  gap: 10px;
  max-width: 860px;
}

.corp-membership-page .corp-links-list a{
  display: block;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.78);
  text-decoration: none;
  color: rgba(47,62,66,.90);
  box-shadow: var(--shadow);
  position: relative;
}

.corp-membership-page .corp-links-list a.is-external{
  padding-right: 42px;
}
.corp-membership-page .corp-links-list a.is-external::after{
  content:"↗";
  position:absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  line-height: 1;
  color: rgba(61,81,85,.60);
  transition: transform .25s ease, opacity .25s ease;
}
@media (hover:hover) and (pointer:fine){
  .corp-membership-page .corp-links-list a:hover{
    background: rgba(255,255,255,.92);
    transform: translateY(-1px);
  }
  .corp-membership-page .corp-links-list a:hover.is-external::after{
    transform: translate(2px,-2px) translateY(-50%);
    opacity: 1;
  }
}

/* =====================================================
  CONTACTLINE（下に静かに）
===================================================== */

.corp-membership-page .corp-contactline{
  margin: 18px auto 0;
  max-width: var(--w-narrow);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 767px){
  .corp-membership-page .corp-contactline{ grid-template-columns: 1fr; }
}

.corp-membership-page .corp-contactline a{
  position: relative;
  display: grid;
  gap: 8px;
  padding: 16px 16px;
  text-decoration: none;
  color: inherit;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(61,81,85,.14);
  border-radius: var(--radius);
  box-shadow: 0 10px 28px rgba(0,0,0,.04);
}

.corp-membership-page .corp-contactline strong{
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  font-size: 12px;
  color: rgba(47,62,66,.70);
}

.corp-membership-page .corp-contactline span{
  font-size: 13.5px;
  line-height: 1.9;
  color: rgba(47,62,66,.82);
}

.corp-membership-page .corp-contactline a.is-external{
  padding-right: 34px;
}
.corp-membership-page .corp-contactline a.is-external::after{
  content:"↗";
  position:absolute;
  right: 14px;
  bottom: 12px;
  font-size: 14px;
  line-height: 1;
  color: rgba(61,81,85,.6);
  transition: transform .25s ease, opacity .25s ease;
}

@media (hover:hover) and (pointer:fine){
  .corp-membership-page .corp-contactline a:hover{
    background: rgba(255,255,255,.92);
    transform: translateY(-1px);
  }
  .corp-membership-page .corp-contactline a:hover.is-external::after{
    transform: translate(2px,-2px);
    opacity: 1;
  }
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  .corp-membership-page .corp-index-list a::after,
  .corp-membership-page .corp-links-list a.is-external::after,
  .corp-membership-page .corp-contactline a.is-external::after{
    transition: none !important;
  }
}







/* =====================================================
  PAGE｜FAQ
  Scope: .page-faq
===================================================== */

.page-faq{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.12);
  --panel: rgba(255,255,255,.88);
  --radius: 10px;
  color: var(--ink);
}

.subpage .page-faq.faq{
  background: transparent;
}

/* =========================
   Header
========================= */
.page-faq .faq-header{
  text-align: center;
  margin-bottom: 56px;
}

.page-faq .faq-lead{
  font-size: 0.875rem;
  color: var(--muted);
  line-height: 1.8;
  max-width: 640px;
  margin: 0.75rem auto 0;
}

/* ========================
  FAQ｜Category Index
  Scope: .page-faq
============================ */

.page-faq .faq-index{
  margin: 32px auto 40px;
  max-width: 960px;
}

.page-faq .faq-index-list{
  list-style: none;
  padding: 0;
  margin: 0;

  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px 18px;
  justify-items: center;
  align-items: center;
}

.page-faq .faq-index-list li{
  width: 100%;
  text-align: center;
}

.page-faq .faq-index-list li a{
  display: inline-block;
  position: relative;
  text-decoration: none;
  color: rgba(47,62,66,.82);
  font-size: 13.5px;
  letter-spacing: .06em;
  padding-bottom: 2px;
}

/* 線（btn-line思想） */
.page-faq .faq-index-list li a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background: rgba(61,81,85,.45);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
}

@media (hover:hover) and (pointer:fine){
  .page-faq .faq-index-list li a:hover::after{
    transform: scaleX(1);
  }
}

/* Tablet：2カラム */
@media (max-width: 1023px){
  .page-faq .faq-index-list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 14px;
  }
}

/* SP */
@media (max-width: 767px){
  .page-faq .faq-index{
    margin: 24px auto 32px;
  }
  .page-faq .faq-index-list{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 12px;
  }
}



/* =========================
   Block
========================= */
.page-faq .faq-block{
  max-width: 860px;
  margin: 0 auto 64px;
}

.page-faq .faq-block-title{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .10em;
  font-size: 1.15rem;
  margin: 0 0 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
  color: rgba(47,62,66,.92);
}

.page-faq .faq-box{
  background: var(--panel);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  border-radius: var(--radius);
  overflow: hidden;
}

/* =========================
   Item
========================= */
.page-faq .faq-item{
  border-bottom: 1px solid var(--line);
}
.page-faq .faq-item:last-child{
  border-bottom: none;
}

/* summary */
.page-faq .faq-q{
  cursor: pointer;
  position: relative;
  padding: 18px 54px 18px 18px;
  line-height: 1.7;
  font-weight: 600;
  color: rgba(47,62,66,.92);
  letter-spacing: .02em;
  user-select: none;
  list-style: none;
}
.page-faq .faq-q::-webkit-details-marker{ display:none; }

@media (hover:hover) and (pointer:fine){
  .page-faq .faq-q:hover{
    background: rgba(247,246,242,.70);
  }
}

/* focus */
.page-faq .faq-q:focus-visible{
  outline: 2px solid rgba(61,81,85,.22);
  outline-offset: -2px;
}

/* +/− */
.page-faq .faq-q::after{
  content: "+";
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding-bottom: 1px;
  border: 1px solid rgba(61,81,85,.20);
  border-radius: 999px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 18px;
  color: rgba(61,81,85,.75);
  background: rgba(255,255,255,.55);
}

.page-faq .faq-item[open] > .faq-q{
  background: rgba(247,246,242,.80);
}
.page-faq .faq-item[open] > .faq-q::after{
  content: "−";
  border-color: rgba(61,81,85,.28);
  color: rgba(61,81,85,.85);
}

.page-faq .faq-a{
  padding: 0 18px 18px 54px;
  font-size: 13.5px;
  line-height: 1.95;
  color: rgba(47,62,66,.72);
}
.page-faq .faq-a p{ margin: 0 0 8px; }
.page-faq .faq-a p:last-child{ margin-bottom: 0; }

/* =========================
   Responsive
========================= */
@media (max-width: 767px){
  .page-faq .faq-header{ margin-bottom: 40px; }
  .page-faq .faq-block{ margin-bottom: 48px; }
  .page-faq .faq-block-title{ font-size: 1.05rem; }

  .page-faq .faq-q{
    padding: 16px 52px 16px 16px;
    font-size: 1rem;
  }

  .page-faq .faq-a{
    padding: 0 16px 16px 50px;
  }
}




/* =====================================================
  PAGE｜Apply
===================================================== */

/* Base */
.page-apply{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.22);
  --bg-soft: #f7f6f2;
  --bg-panel: rgba(255,255,255,.88);
  --radius: 16px;
  color: var(--ink);
}

/* Hero */
.page-apply .apply-hero{
  position: relative;
  overflow: hidden;
  color: #fff;
  isolation: isolate;
}

.page-apply .apply-hero-bg{
  position: absolute;
  inset: 0;
  background: center / cover no-repeat;
  z-index: 0;
  filter: brightness(.78) saturate(.92) contrast(1.03);
}

.page-apply .apply-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background-color: #000;
  opacity: .26;
  z-index: 1;
}

.page-apply .subpage-hero-inner{
  position: relative;
  z-index: 2;
}

.page-apply .subpage-hero-label,
.page-apply .subpage-hero-title{
  color: #fff !important;
}

.page-apply .subpage-hero-lead{
  color: rgba(255,255,255,.92) !important;
}

.page-apply .apply-hero-note{
  margin-top: 14px;
  font-size: 13px;
  color: rgba(255,255,255,.85);
}

.page-apply .subpage-hero-cta .btn-line{
  color: #fff;
  border-color: rgba(255,255,255,.75);
}
@media (hover:hover) and (pointer:fine){
  .page-apply .subpage-hero-cta .btn-line:hover{
    background: rgba(255,255,255,.18);
    border-color: rgba(255,255,255,.95);
    transform: translateX(2px);
    box-shadow: 0 10px 26px rgba(0,0,0,.18);
  }
}

/* Common Card Style */
.page-apply .apply-forBox,
.page-apply .apply-tableWrap,
.page-apply .apply-formEmbed,
.page-apply .apply-formInfo,
.page-apply .apply-faqBox,
.page-apply .apply-closingBox{
  background: var(--bg-panel);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
}

/* Learn / Steps */
.page-apply .apply-learn-lead{
  margin: 10px 0 18px;
  color: rgba(47,62,66,.84);
  line-height: 1.95;
}

.page-apply .apply-steps{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
@media (max-width:1023px){
  .page-apply .apply-steps{ grid-template-columns: 1fr; }
}

.page-apply .apply-step{
  padding: 22px;
  background: rgba(255,255,255,.88);
  box-shadow: 0 10px 26px rgba(0,0,0,.04);
  border-radius: 10px;
}

.page-apply .apply-step::before{
  content: none;
}

.page-apply .apply-step-num{
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  letter-spacing: .1em;
  color: rgba(47,62,66,.64);
  display: inline-block;
  margin-bottom: 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(61,81,85,.20);
}

.page-apply .apply-step-title{
  font-family: "Shippori Mincho", serif;
  font-size: 16px;
  letter-spacing: .1em;
  margin: 6px 0 10px;
}

.page-apply .apply-step-text{
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--muted);
}


/* For Who / List */
.page-apply .apply-list{
  list-style: none;
  padding: 20px 40px;
  margin: 0;
  color: rgba(47,62,66,.82);
}

.page-apply .apply-list li{
  position: relative;
  padding-left: 30px;
  margin-bottom: 16px;
  line-height: 2.0;
}

.page-apply .apply-list li:last-child{
  margin-bottom: 0;
}

.page-apply .apply-list li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0.15em;
  font-family: "Cormorant Garamond", serif;
  font-size: 18px;
  color: rgba(61,81,85,.65);
}
.page-apply .apply-list--sm{
  padding: 0;
}
.page-apply .apply-list--sm li{
  margin-bottom: 10px;
  line-height: 1.9;
}


/* Schedule / Table */
.page-apply .apply-schedule-lead{
  margin: 10px 0 16px;
  line-height: 1.95;
}

.page-apply .apply-tableWrap{
  margin-top: 14px;
  overflow: auto;
  position: relative;
}

.page-apply .apply-tableWrap::after{
  content:"";
  position:absolute;
  top:0; right:0; bottom:0;
  width:28px;
  background: linear-gradient(to left, rgba(0,0,0,.06), transparent);
  pointer-events:none;
  opacity:.25;
}

.page-apply .apply-table{
  width:100%;
  min-width:720px;
  border-collapse: collapse;
}

.page-apply .apply-table th,
.page-apply .apply-table td{
  padding:14px;
  font-size:13.5px;
  border-bottom:1px solid rgba(61,81,85,.12);
  text-align:left;
}

.page-apply .apply-table th{
  background: rgba(247,246,242,.85);
  font-weight:700;
  color: #2f3e42;
}

.page-apply .apply-schedule-note{
  margin-top:12px;
  font-size:13px;
  color: rgba(47,62,66,.7);
}

.page-apply .apply-schedule-cta{ margin-top: 14px; }

/* Form */
.page-apply .apply-formBox{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:14px;
  margin-top:14px;
}
@media (max-width:1023px){
  .page-apply .apply-formBox{ grid-template-columns:1fr; }
}

.page-apply .apply-formEmbed,
.page-apply .apply-formInfo{
  padding:22px;
}

.page-apply .apply-formInfoTitle,
.page-apply .apply-formAfterTitle{
  font-family:"Shippori Mincho", serif;
  letter-spacing:.1em;
  margin-bottom:10px;
}
.page-apply .apply-formAfterTitle{ margin-top:18px; }

.page-apply .apply-formAfterText{
  font-size:13.5px;
  line-height:1.95;
  color: var(--muted);
}

/* Fluent Forms */
.page-apply .fluentform input[type="text"],
.page-apply .fluentform input[type="email"],
.page-apply .fluentform input[type="tel"],
.page-apply .fluentform select,
.page-apply .fluentform textarea,
.page-apply .fluentform .ff-el-form-control{
  width:100%;
  padding:12px;
  border-radius:10px;
  border:1px solid rgba(61,81,85,.22);
  background: rgba(255,255,255,.94);
}
.page-apply .fluentform textarea{ min-height:160px; }

.page-apply .fluentform button[type="submit"],
.page-apply .fluentform input[type="submit"]{
  margin-top:10px;
  border-radius:999px;
  padding:12px 22px;
  background: rgba(255,255,255,.55);
  border:1px solid rgba(61,81,85,.42);
  letter-spacing:.08em;
}
@media (hover:hover) and (pointer:fine){
  .page-apply .fluentform button[type="submit"]:hover,
  .page-apply .fluentform input[type="submit"]:hover{
    background: rgba(255,255,255,.78);
    transform: translateX(2px);
  }
}

/* FAQ */
.page-apply .apply-faqBox{
  max-width: 860px;
  margin: 14px auto 0;
  border-radius: 10px;
  overflow: hidden;
}

.page-apply .apply-faqItem{
  border-bottom: 1px solid rgba(61,81,85,.12);
}
.page-apply .apply-faqItem:last-child{
  border-bottom: none;
}

.page-apply .apply-faqQ{
  cursor: pointer;
  position: relative;
  padding: 18px 54px 18px 18px;
  line-height: 1.7;
  font-weight: 600;
  color: rgba(47,62,66,.92);
  letter-spacing: .02em;
  user-select: none;
  list-style: none;
}
.page-apply .apply-faqQ::-webkit-details-marker{ display:none; }

@media (hover:hover) and (pointer:fine){
  .page-apply .apply-faqItem summary:hover{
    background: rgba(247,246,242,.70);
  }
}

.page-apply .apply-faqQ::after{
  content: "+";
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;

  display: flex;
  align-items: center;
  justify-content: center;

  line-height: 1;
  padding-bottom: 1px;

  border: 1px solid rgba(61,81,85,.20);
  border-radius: 999px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 18px;
  color: rgba(61,81,85,.75);
  background: rgba(255,255,255,.55);
}

.page-apply .apply-faqItem[open] summary{
  background: rgba(247,246,242,.80);
}
.page-apply .apply-faqItem[open] .apply-faqQ::after{
  content: "−";
  border-color: rgba(61,81,85,.28);
  color: rgba(61,81,85,.85);
}

.page-apply .apply-faqA{
  padding: 0 18px 18px 54px;
  font-size: 13.5px;
  line-height: 1.95;
  color: rgba(47,62,66,.72);
}
.page-apply .apply-faqA p{ margin: 0; }

/* Closing */
.page-apply .apply-closingBox{
  padding:26px;
  text-align:center;
}

.page-apply .apply-closingTitle{
  font-family:"Shippori Mincho", serif;
  font-size:18px;
  letter-spacing:.1em;
  margin: 0 0 12px;
}

.page-apply .apply-closingText{
  margin: 0;
  font-size:13.5px;
  line-height:1.95;
  color: var(--muted);
}

/* =====================================================
  PAGE｜TERMS OF SERVICE
  Scope: .page-terms
===================================================== */

.page-terms{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.14);
  --panel: rgba(255,255,255,.88);
  --radius: 10px;

  color: var(--ink);
  line-height: 1.9;
}

/* 背景は subpage 側に任せる */
.subpage .page-terms{
  background: transparent;
}

/* =========================
   Header
========================= */
.page-terms .terms-header{
  text-align: center;
  margin-bottom: 56px;
}

.page-terms .terms-lead{
  font-size: 0.875rem;
  color: var(--muted);
  line-height: 1.8;
  max-width: 640px;
  margin: 0.75rem auto 0;
}

/* =========================
   Body Panel
========================= */
.page-terms .terms-body{
  max-width: 860px;
  margin: 0 auto;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 40px 40px 44px;
}

/* =========================
   Article
========================= */
.page-terms .terms-article{
  display: flex;
  flex-direction: column;
  gap: 28px;
}

/* 条文タイトル */
.page-terms .terms-article h3{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .08em;
  font-size: 1.05rem;
  margin: 0 0 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
  color: rgba(47,62,66,.92);
}

/* 本文 */
.page-terms .terms-article p{
  margin: 0 0 8px;
  font-size: 13.5px;
  line-height: 1.95;
  color: rgba(47,62,66,.78);
}

/* リスト（禁止事項など） */
.page-terms .terms-article ul{
  margin: 8px 0 0;
  padding-left: 1.2em;
}

.page-terms .terms-article li{
  font-size: 13.5px;
  line-height: 1.9;
  color: rgba(47,62,66,.78);
  margin-bottom: 6px;
}

/* 最終条文の余白調整 */
.page-terms .terms-article section:last-child{
  margin-bottom: 0;
}

/* =========================
   Responsive
========================= */
@media (max-width: 767px){

  .page-terms .terms-header{
    margin-bottom: 40px;
  }

  .page-terms .terms-body{
    padding: 28px 18px 32px;
  }

  .page-terms .terms-article{
    gap: 22px;
  }

  .page-terms .terms-article h3{
    font-size: 1rem;
  }

  .page-terms .terms-article p,
  .page-terms .terms-article li{
    font-size: 13px;
  }
}


/* =====================================================
  PAGE｜Sitemap
  Scope: .sitemap-page
===================================================== */

.sitemap-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.22);
  --line-strong: rgba(61,81,85,.48);
  --band: #f7f4ee;
  --panel: rgba(255,255,255,.90);
  color: var(--ink);
}

.sitemap-page .sitemap-hero{
  background: var(--band);
  padding-top: 72px;
  padding-bottom: 56px;
}
.sitemap-page .sitemap-lead{
  margin-top: 14px;
  line-height: 2.0;
  color: rgba(47,62,66,.78);
  font-size: 14px;
}

.sitemap-page .sitemap-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 1023px){
  .sitemap-page .sitemap-grid{
    grid-template-columns: 1fr;
  }
}

.sitemap-page .sitemap-block{
  background: var(--panel);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 22px;
}
.sitemap-page .sitemap-block--legal{
  background: linear-gradient(180deg, rgba(247,244,238,.85), rgba(255,255,255,.88));
}

.sitemap-page .sitemap-heading{
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(61,81,85,.18);
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .10em;
  color: rgba(47,62,66,.92);
  font-size: 16px;
}

.sitemap-page .sitemap-list{
  margin: 0;
  padding-left: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}
.sitemap-page .sitemap-link{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: rgba(47,62,66,.82);
  line-height: 1.8;
  position: relative;
  padding-left: 18px;
}

.sitemap-page .sitemap-link::before{
  content:"";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(61,81,85,.38);
  position: absolute;
  left: 0;
  top: .68em;
}

.sitemap-page .sitemap-link::after{
  content:"";
  position:absolute;
  left: 18px;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: rgba(61,81,85,.22);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease, background .25s ease;
}

@media (hover:hover) and (pointer:fine){
  .sitemap-page .sitemap-link:hover{
    color: rgba(47,62,66,.95);
  }
  .sitemap-page .sitemap-link:hover::after{
    transform: scaleX(1);
    background: rgba(61,81,85,.38);
  }
}

.sitemap-page .sitemap-link.is-current{
  opacity: .72;
  pointer-events: none;
}
.sitemap-page .sitemap-link.is-current::after{
  transform: scaleX(1);
  background: rgba(61,81,85,.18);
}
/* =====================================================
  PAGE｜Company Profile
  Scope: .company-page
===================================================== */

.company-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.22);
  --line-strong: rgba(61,81,85,.48);
  --band: #f7f4ee;
  --panel: rgba(255,255,255,.92);
  --radius: 14px;
  --shadow: 0 12px 34px rgba(0,0,0,.05);

  color: var(--ink);
}

/* Hero */
.company-page .company-hero{
  background: var(--band);
  border-bottom: 1px solid rgba(61,81,85,.12);
  padding-top: 72px;
  padding-bottom: 56px;
}

.company-page .company-lead{
  margin-top: 14px;
  line-height: 2.0;
  color: rgba(47,62,66,.78);
  font-size: 14px;
}

/* Section spacing (optional) */
.company-page .subpage-section{
  padding: 64px 16px;
}
.company-page .company-hero.subpage-section{
  padding: 72px 16px 56px;
}

/* Overview layout (table + photo) */
.company-page .company-overview-inner{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 24px;
  align-items: start;
  margin-top: 24px;
}

.company-page .company-photo{
  aspect-ratio: 4 / 3;
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: var(--shadow);
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
}
.company-page .company-photo::after{
  content: "PHOTO";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-family: "Cormorant Garamond", serif;
  letter-spacing: .18em;
  color: rgba(47,62,66,.28);
}

/* Card */
.company-page .company-card{
  background: var(--panel);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: var(--shadow);
  padding: 26px;
  border-radius: var(--radius);
}

.company-page .company-card-title{
  margin: 0 0 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(61,81,85,.18);
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .10em;
  font-size: 16px;
  color: rgba(47,62,66,.92);
}

/* DL table */
.company-page .company-dl{ margin: 0; }

.company-page .company-row{
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(61,81,85,.10);
}
.company-page .company-row:last-child{ border-bottom: none; }

.company-page .company-dl dt{
  margin: 0;
  color: rgba(47,62,66,.86);
  font-weight: 500;
  letter-spacing: .04em;
}
.company-page .company-dl dd{
  margin: 0;
  color: rgba(47,62,66,.84);
  line-height: 1.95;
}

.company-page .company-note{
  display: inline-block;
  margin-top: 8px;
  color: rgba(47,62,66,.62);
  font-size: 13px;
}

.company-page .company-list{
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
  color: rgba(47,62,66,.84);
}

/* Timeline */
.company-page .about-timeline-wrap{
  margin-top: 24px;
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(61,81,85,.14);
  border-radius: var(--radius);
  padding: 26px;
}

.company-page .about-timeline-title{
  margin: 0 0 18px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .10em;
  font-size: 16px;
  color: rgba(47,62,66,.92);
}

.company-page .timeline-grouped{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 22px;
}

.company-page .timeline-group{
  display: grid;
  gap: 14px;
}

.company-page .timeline-group-year{
  font-family: "Cormorant Garamond", serif;
  font-size: 22px;
  letter-spacing: .12em;
  color: rgba(47,62,66,.82);
}

.company-page .timeline-list{
  list-style: none;
  margin: 0;
  padding: 0;
  border-left: 1px solid rgba(61,81,85,.22);
  display: grid;
  gap: 18px;
}

.company-page .timeline-item{
  position: relative;
  padding-left: 18px;
  display: grid;
  gap: 8px;
}

.company-page .timeline-dot{
  position: absolute;
  left: -5px;
  top: 6px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(61,81,85,.55);
  box-shadow: 0 0 0 3px rgba(255,255,255,.85);
}

.company-page .timeline-month{
  margin: 0;
  font-size: 13px;
  color: rgba(47,62,66,.68);
  letter-spacing: .06em;
}

.company-page .timeline-content h4,
.company-page .timeline-content h3{
  margin: 0;
  font-size: 15px;
  letter-spacing: .06em;
  color: rgba(47,62,66,.92);
}

.company-page .timeline-content p{
  margin: 0;
  font-size: 14px;
  line-height: 1.95;
  color: rgba(47,62,66,.78);
}

/* SP */
@media (max-width: 767px){
  .company-page .company-card{ padding: 20px; }

  .company-page .company-overview-inner{
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .company-page .company-row{
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 12px 0;
  }

  .company-page .company-dl dt{
    font-size: 13px;
    opacity: .86;
  }

  .company-page .about-timeline-wrap{
    padding: 20px;
  }
}

/* =====================================================
  PAGE｜Privacy Policy
===================================================== */

.privacy-page{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.22);
  --line-strong: rgba(61,81,85,.46);
  --band: #f7f4ee;
  --panel: rgba(255,255,255,.92);
  color: var(--ink);
}

/* Hero */
.privacy-page .privacy-hero{
  background: var(--band);
  padding-top: 72px;
  padding-bottom: 56px;
}

.privacy-page .privacy-lead{
  margin-top: 12px;
  color: rgba(47,62,66,.72);
  font-size: 14px;
  letter-spacing: .06em;
  line-height: 1.9;
}

/* Card */
.privacy-page .privacy-card{
  background: var(--panel);
  border: 1px solid rgba(61,81,85,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.05);
  padding: 32px;
}

/* Intro */
.privacy-page .privacy-intro{
  margin: 0 0 28px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(61,81,85,.14);
  color: rgba(47,62,66,.86);
  line-height: 2.1;
  font-size: 14px;
}

/* Sections */
.privacy-page .privacy-section{
  padding: 26px 0;
  border-bottom: 1px solid rgba(61,81,85,.10);
}

.privacy-page .privacy-section:last-of-type{
  border-bottom: none;
}

.privacy-page .privacy-h2{
  margin: 0 0 14px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: .08em;
  font-size: 16px;
  color: rgba(47,62,66,.92);
  display: flex;
  gap: 10px;
  align-items: baseline;
}

.privacy-page .privacy-no{
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  letter-spacing: .02em;
  color: rgba(47,62,66,.65);
}

.privacy-page .privacy-section p{
  margin: 0;
  line-height: 2.0;
  font-size: 14px;
  color: rgba(47,62,66,.84);
}

.privacy-page .privacy-section p + p{
  margin-top: 10px;
}

/* List */
.privacy-page .privacy-list{
  margin: 14px 0 0;
  padding-left: 20px;
  display: grid;
  gap: 8px;
  color: rgba(47,62,66,.84);
  line-height: 1.9;
}

.privacy-page .privacy-list li{
  padding-left: 2px;
}

/* Contact box */
.privacy-page .privacy-contact-box{
  margin-top: 16px;
  padding: 18px;
  border: 1px solid rgba(61,81,85,.14);
  background: rgba(247,244,238,.55);
}

.privacy-page .privacy-org{
  margin: 0 0 8px;
  font-weight: 600;
  letter-spacing: .04em;
}

.privacy-page .privacy-meta{
  margin: 0;
  color: rgba(47,62,66,.80);
  line-height: 2.0;
  font-size: 14px;
}

/* Back link */
.privacy-page .privacy-back{
  margin-top: 32px;
  text-align: center;
}

.privacy-page .privacy-back-link{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  padding: 13px 20px;
  border: 1px solid rgba(61,81,85,.44);
  color: rgba(47,62,66,.92);
  text-decoration: none;
  transition: transform .2s ease, background-color .2s ease, border-color .2s ease;
  background: rgba(255,255,255,.55);
}

.privacy-page .privacy-back-link:hover{
  background: rgba(255,255,255,.88);
  border-color: rgba(61,81,85,.70);
  transform: translateY(-1px);
}

/* SP */
@media (max-width: 767px){
  .privacy-page .privacy-card{
    padding: 22px;
  }

  .privacy-page .privacy-h2{
    font-size: 15px;
    margin-bottom: 12px;
  }

  .privacy-page .privacy-section{
    padding: 22px 0;
  }
}

/* LEGAL */

.subpage.legal-page{
  padding: 64px 16px 120px;
}

.subpage.legal-page .subpage-container{
  max-width: 960px;
  margin: 0 auto;
}

.legal-lead{
  text-align: center;
  font-size: 0.92rem;
  line-height: 1.95;
  color: rgba(0,0,0,0.62);
  margin: 18px auto 52px;
  max-width: 780px;
}

.legal-table{
  margin: 0;
  padding: 0;
  border-top: 1px solid rgba(0,0,0,0.10);
}

.legal-row{
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 24px;
  padding: 22px 0;
  border-bottom: 1px solid rgba(0,0,0,0.10);
}

.legal-row dt{
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  color: rgba(0,0,0,0.62);
  padding-top: 2px;
}

.legal-row dd{
  margin: 0;
  font-size: 1rem;
  line-height: 1.95;
  color: rgba(0,0,0,0.78);
}

.legal-note{
  display: inline-block;
  margin-top: 6px;
  font-size: 0.82rem;
  color: rgba(0,0,0,0.55);
}

.legal-list{
  margin: 0;
  padding-left: 1.1em;
}
.legal-list li{
  margin: 0 0 6px;
}

.legal-assurance{
  margin-top: 72px;
  padding: 44px 32px;
  background: var(--light-beige);
  text-align: center;
}

.legal-assurance-title{
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 1.1rem;
  margin: 0 0 12px;
  color: rgba(0,0,0,0.80);
}

.legal-assurance-text{
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.95;
  color: rgba(0,0,0,0.64);
}

/* SP */
@media (max-width: 767px){
  .legal-lead{
    text-align: left;
    margin: 12px 0 40px;
  }

  .legal-row{
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 18px 0;
  }

  .legal-row dt{
    font-size: 0.82rem;
  }
}

/* =========================================
   Aroma Journal
   ========================================= */

.single-aroma_journal .c-entryContent,
.single-aroma_journal .c-postContent,
.single-aroma_journal .p-entry__body,
.single-aroma_journal .p-entry__content,
.single-aroma_journal .p-entry,
.single-aroma_journal .l-article,
.single-aroma_journal .l-main,
.single-aroma_journal .l-content{
  max-width: 640px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box;
}

.single-aroma_journal .c-postContent{
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.single-aroma_journal .c-entryContent,
.single-aroma_journal .c-postContent{
  font-size: 15px;
  line-height: 1.9;
}


.single-aroma_journal .c-postContent > *{
  max-width: 100%;
}

.single-aroma_journal .p-articleThumb{
  width: auto !important;
  max-width: 640px !important;
  margin: 40px auto 56px !important;
  padding: 0 !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
}

.single-aroma_journal .aj-oil h4{
  margin: 0 0 8px;
  line-height: 1.4;
}

.single-aroma_journal .aj-oil{
  margin: 16px 0;
}

.single-aroma_journal .aj-oils{
  margin-top: 32px;
  margin-bottom: 32px;
}

.single-aroma_journal .c-postContent img,
.single-aroma_journal .aj-figure img,
.single-aroma_journal .p-articleThumb img{
  width: 100% !important;
  height: auto !important;
  display: block !important;
  margin: 0 auto !important;
  border-radius: 8px;
}

.single-aroma_journal .c-postContent figure,
.single-aroma_journal .aj-figure{
  margin: 44px auto !important;
  max-width: 640px !important;
}

.single-aroma_journal .c-postContent .alignwide,
.single-aroma_journal .c-postContent .alignfull{
  width: auto !important;
  max-width: 640px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

@media (max-width: 768px){
  .single-aroma_journal .c-entryContent,
  .single-aroma_journal .c-postContent{
    font-size: 15.5px;
    line-height: 1.85;
  }
}

.post_meta .updated,
.post_meta .post_modified,
.c-postMeta__date--modified {
  display: none !important;
}

/* ===========================
   NEWS｜Schedule (copy/paste)
=========================== */

.news-schedule{
  --ink: #2f3e42;
  --muted: rgba(47,62,66,.72);
  --line: rgba(61,81,85,.18);
  --panel: rgba(255,255,255,.86);
  --soft: #f7f6f2;
  --radius: 14px;

  color: var(--ink);
}

.post-type-news .p-articleThumb {
  display: none;
}


.news-schedule .news-lead{
  margin: 0 0 14px;
  color: var(--muted);
  line-height: 1.9;
  font-size: 0.95rem;
}

/* Tag row (legend) */
.news-schedule .news-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin: 0 0 26px;
}

.news-schedule .news-tag{
  display:inline-block;
  padding: 5px 12px;
  border-radius: 999px;
  font-size: 11px;
  letter-spacing: .06em;
  background: rgba(61,81,85,.06);
  border: 1px solid rgba(61,81,85,.12);
  color: rgba(47,62,66,.86);
  user-select: none;
  cursor: default;
}

.news-schedule .news-tag.-exam{ background: rgba(107,132,124,.10); }
.news-schedule .news-tag.-class{ background: rgba(210,198,160,.18); }
.news-schedule .news-tag.-event{ background: rgba(180,190,200,.22); }

/* Block */
.news-schedule .news-block{
  background: var(--soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 16px;
  margin: 18px 0;
}

.news-schedule .news-list{
  list-style:none;
  margin: 14px 0 0;
  padding: 0;
  display:grid;
  gap: 10px;
}

.news-schedule .news-item{
  display:grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: start;
  background: var(--panel);
  border: 1px solid rgba(61,81,85,.14);
  border-radius: 12px;
  padding: 12px 12px;
}

.news-schedule .news-badge{
  display:inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 10.5px;
  letter-spacing: .06em;
  line-height: 1.2;
  border: 1px solid rgba(61,81,85,.14);
  background: rgba(61,81,85,.06);
  color: rgba(47,62,66,.86);
  user-select:none;
  cursor:default;
  white-space: nowrap;
}

.news-schedule .news-badge.-exam{ background: rgba(107,132,124,.10); }
.news-schedule .news-badge.-class{ background: rgba(210,198,160,.18); }
.news-schedule .news-badge.-event{ background: rgba(180,190,200,.22); }

.news-schedule .news-itemTitle{
  margin: 0 0 3px;
  font-weight: 800;
  letter-spacing: .04em;
  line-height: 1.6;
  font-size: 0.98rem;
}

.news-schedule .news-itemMeta{
  margin: 0;
  color: var(--muted);
  letter-spacing: .04em;
  font-size: 0.9rem;
  line-height: 1.7;
}

.news-schedule .news-note{
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.9;
}


