@charset "UTF-8";
/* ========================================================================
   Page: 六本木オフィス (locations/roppongi.html)
   PC -> .page-roppongi   /   SP -> .page-roppongi-sp
   Figma: PC_六本木オフィス (node 15907:9138)
   ======================================================================== */
:root {
  --rp-gray-800: #282828;
  --rp-gray-700: #404040;
  --rp-gray-600: #8e8e8e;
  --rp-gray-500: #a6a6a6;
  --rp-border-3: #888888;
  --rp-border-1: #e0e0e0;
  --rp-bg-gray: #ececec;
}

/* ===================== PC ===================== */
.page-roppongi { background:#fff; color:var(--color-black); font-family:var(--font-noto); overflow:hidden; }
.page-roppongi img { display:block; max-width:100%; }

/* 見出し */
.rp-heading { display:flex; align-items:center; gap:32px; }
.rp-heading__jami { width:104px; height:37px; flex-shrink:0; }
.rp-heading__text { display:flex; flex-direction:column; gap:10px; }
.rp-heading__jp { font-family:var(--font-zen); font-weight:700; font-size:40px; line-height:1.4; letter-spacing:4px; color:var(--color-black); }
.rp-heading__jp--white { color:#fff; }
.rp-heading__en { font-family:var(--font-futura); font-weight:500; font-size:22px; line-height:1; letter-spacing:1px; color:var(--rp-gray-600); text-transform:uppercase; }

/* ヒーロー */
.rp-hero { padding:72px 90px 96px; }
.rp-hero__inner { display:flex; justify-content:space-between; align-items:flex-start; gap:64px; }
.rp-hero__left { flex:1 1 auto; max-width:600px; padding-top:32px; }
.rp-hero__titlewrap { display:flex; align-items:flex-start; gap:22px; }
.rp-hero__en { font-family:var(--font-futura); font-weight:600; font-size:100px; line-height:1; letter-spacing:0; color:var(--color-black); }
.rp-hero__mark { background:linear-gradient(transparent 36%, var(--color-yellow) 36%, var(--color-yellow) 76%, transparent 76%); padding:0 2px; box-decoration-break:clone; -webkit-box-decoration-break:clone; }
.rp-hero__jami { width:165px; height:auto; margin-top:4px; flex-shrink:0; align-self:flex-start; }
.rp-hero__jp { font-family:var(--font-zen); font-weight:700; font-size:22px; letter-spacing:4px; color:var(--color-black); margin-top:22px; }
.rp-hero__lead { font-family:var(--font-zen); font-weight:500; font-size:16px; line-height:2.1; letter-spacing:1.5px; color:var(--color-black); margin-top:34px; }
.rp-hero__anchor { display:flex; flex-wrap:wrap; gap:12px; margin-top:56px; }
.rp-hero__anchor a { display:inline-flex; align-items:center; gap:12px; background:var(--color-black); color:#fff; font-family:var(--font-noto); font-weight:500; font-size:13px; letter-spacing:1px; padding:12px 22px; border-radius:999px; transition:opacity .25s ease; }
.rp-hero__anchor a:hover { opacity:.82; }
.rp-hero__anchor-arrow { width:6px; height:6px; border-right:1.5px solid #fff; border-bottom:1.5px solid #fff; transform:rotate(45deg); margin-top:-3px; }
.rp-hero__photo { width:680px; aspect-ratio:3/2; height:auto; flex-shrink:0; overflow:hidden; border-radius:4px; background:#0d0d0d; }
.rp-hero__photo img { width:100%; height:100%; object-fit:cover; }

/* オフィス紹介 */
.rp-overview { padding:120px 90px 140px; position:relative; }
.rp-overview__desc { margin-top:40px; margin-left:auto; width:720px; font-size:15px; line-height:2; letter-spacing:1px; color:var(--color-dark-text); }
.rp-overview__wordmark { font-family:var(--font-futura); font-weight:500; font-size:180px; line-height:1; letter-spacing:4px; color:#f1f1f1; white-space:nowrap; margin:48px 0 0 -10px; user-select:none; }
.rp-gallery { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.rp-gallery__item { aspect-ratio:4/3; overflow:hidden; border-radius:8px; background:#eee; }
.rp-gallery__item img { width:100%; height:100%; object-fit:cover; }

/* 数字で見る (ダーク) */
.rp-numbers { padding:120px 90px 140px; background:var(--color-black); }
.rp-numbers .rp-heading__jp { color:#fff; }
.rp-numbers .rp-heading__en { color:var(--rp-gray-600); }
.rp-stats { display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:1fr; gap:24px; margin-top:72px; }
.rp-stat { background:var(--rp-gray-800); border:1px dashed var(--rp-border-3); border-radius:8px; display:flex; align-items:center; justify-content:space-between; gap:24px; padding:32px 40px; min-height:200px; }
.rp-stat__body { display:flex; flex-direction:column; gap:8px; }
.rp-stat__label { font-family:var(--font-noto); font-weight:500; font-size:16px; letter-spacing:1.5px; color:var(--rp-gray-500); }
.rp-stat__value { font-family:var(--font-noto); font-weight:700; font-size:44px; line-height:1.1; letter-spacing:2px; color:#fff; }
.rp-stat__unit { font-size:22px; margin-left:2px; }
.rp-stat__icon { width:110px; height:110px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.rp-stat__icon img { width:100%; height:100%; object-fit:contain; }
/* テレワーク率 フィーチャーカード（大きな円グラフ） */
.rp-stat--feature { grid-row:span 2; flex-direction:column; justify-content:center; align-items:center; padding:40px; }
.rp-gauge { position:relative; width:340px; height:340px; max-width:100%; display:flex; align-items:center; justify-content:center; }
.rp-gauge__ring { width:100%; height:100%; object-fit:contain; }
.rp-gauge__text { position:absolute; top:38%; left:50%; transform:translate(-50%,-50%); text-align:center; }
.rp-gauge__label { display:block; font-size:16px; letter-spacing:1.5px; color:var(--rp-gray-500); margin-bottom:6px; }
.rp-gauge__value { font-family:var(--font-noto); font-weight:700; font-size:64px; line-height:1; color:#fff; }
.rp-gauge__value span { font-size:28px; }

/* 専門チーム / チーム構成 (淡グレー) */
.rp-teams { padding:120px 90px 140px; background:var(--rp-bg-gray); }
.rp-teams__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:80px; }
.rp-team-card { background:#fff; border:1px solid var(--rp-border-1); border-radius:6px; padding:32px; display:flex; flex-direction:column; gap:18px; }
.rp-team-card__tag { position:relative; align-self:flex-start; padding-left:16px; font-family:var(--font-zen); font-weight:700; font-size:17px; letter-spacing:1px; color:var(--color-black); }
.rp-team-card__tag::before { content:''; position:absolute; left:0; top:3px; bottom:3px; width:4px; border-radius:2px; background:var(--color-black); }
.rp-team-card__desc { font-size:14px; line-height:1.9; letter-spacing:0.5px; color:var(--color-dark-text); }

/* 拠点長メッセージ */
.rp-message { padding:120px 90px 140px; }
.rp-message__body { display:flex; gap:90px; margin-top:80px; align-items:flex-start; }
.rp-message__photo { width:360px; height:460px; flex-shrink:0; overflow:hidden; border-radius:4px; background:#eee; }
.rp-message__photo img { width:100%; height:100%; object-fit:cover; }
.rp-message__content { flex:1; padding-top:24px; }
.rp-message__title { font-family:var(--font-zen); font-weight:700; font-size:30px; line-height:1.6; letter-spacing:2px; color:var(--color-black); }
.rp-message__text { margin-top:28px; font-size:15px; line-height:2; letter-spacing:1px; color:var(--color-dark-text); }
.rp-message__profile { margin-top:40px; }
.rp-message__role { font-size:14px; letter-spacing:1px; color:var(--rp-gray-600); }
.rp-message__name { margin-top:8px; display:flex; align-items:baseline; gap:14px; }
.rp-message__name-title { font-size:15px; }
.rp-message__name-main { font-family:var(--font-zen); font-weight:700; font-size:28px; letter-spacing:2px; }

/* 求める人物像 (ダーク) */
.rp-vision { background:#fff; padding:120px 0 140px; }
.rp-vision__head { padding:0 90px; display:flex; justify-content:space-between; align-items:flex-end; gap:40px; }
.rp-vision__lead { width:540px; font-size:15px; line-height:2; letter-spacing:1px; color:var(--color-dark-text); }
.rp-vision__track { display:flex; gap:24px; margin-top:64px; padding:0 90px; overflow-x:auto; scroll-snap-type:x mandatory; }
.rp-vision__track::-webkit-scrollbar { height:6px; }
.rp-vision__track::-webkit-scrollbar-thumb { background:var(--rp-gray-700); border-radius:3px; }
.rp-vision-card { position:relative; flex-shrink:0; width:540px; height:420px; background:var(--color-black); border:1px dashed var(--rp-border-3); border-radius:6px; padding:48px; scroll-snap-align:start; overflow:hidden; }
.rp-vision-card > * { position:relative; z-index:1; }
.rp-vision-card__num { position:absolute; top:32px; right:40px; z-index:0; font-family:var(--font-futura); font-weight:500; font-size:110px; line-height:1; color:var(--rp-gray-700); }
.rp-vision-card__head { display:flex; flex-direction:column; gap:16px; }
.rp-vision-card__icon { width:56px; height:56px; }
.rp-vision-card__icon img { width:100%; height:100%; object-fit:contain; }
.rp-vision-card__title { font-family:var(--font-noto); font-weight:700; font-size:32px; line-height:1.6; letter-spacing:3.2px; color:#fff; text-decoration:underline; text-underline-offset:6px; padding-right:56px; }
.rp-vision-card__desc { margin-top:32px; font-size:15px; line-height:2; letter-spacing:0.75px; color:#fff; }

/* 働く環境 (ダーク) */
.rp-env { padding:120px 90px 140px; background:var(--color-black); position:relative; overflow:hidden; }
.rp-env > * { position:relative; z-index:1; }
.rp-env .rp-heading__en { color:var(--rp-gray-600); }
.rp-env__deco { position:absolute; top:40px; right:-20px; z-index:0; font-family:var(--font-futura); font-weight:700; font-size:150px; line-height:0.92; letter-spacing:4px; color:#ffffff; opacity:.04; text-align:right; white-space:nowrap; user-select:none; }
.rp-env__list { margin-top:80px; display:flex; flex-direction:column; gap:72px; }
.rp-env-point { display:flex; align-items:center; gap:90px; }
.rp-env-point--reverse { flex-direction:row-reverse; }
.rp-env-point__photo { width:542px; height:344px; flex-shrink:0; overflow:hidden; border-radius:4px; background:#1c1c1c; }
.rp-env-point__photo img { width:100%; height:100%; object-fit:cover; }
.rp-env-point__text { flex:1; }
.rp-env-point__no { font-family:var(--font-futura); font-weight:500; font-size:18px; letter-spacing:2px; color:var(--rp-gray-500); text-transform:uppercase; }
.rp-env-point__title { margin-top:18px; font-family:var(--font-zen); font-weight:700; font-size:32px; line-height:1.5; letter-spacing:2px; color:#fff; }
.rp-env-point__desc { margin-top:24px; font-size:15px; line-height:2.1; letter-spacing:1px; color:#d8d8d8; }

/* スタッフ紹介 (一旦非表示) */
.rp-staff, #sp-staff { display:none; }
.rp-staff { padding:120px 0 140px; background:var(--rp-bg-gray); position:relative; }
.rp-staff__head { padding:0 90px; display:flex; justify-content:space-between; align-items:flex-end; gap:40px; position:relative; z-index:2; }
.rp-staff__head-right { display:flex; align-items:center; gap:36px; }
.rp-staff__lead { font-size:15px; line-height:1.8; letter-spacing:1px; color:var(--color-dark-text); }
.rp-staff__nav { display:flex; gap:14px; flex-shrink:0; }
.rp-staff__arrow { width:56px; height:56px; border:1px solid var(--rp-border-3); border-radius:50%; background:transparent; cursor:pointer; position:relative; transition:background .25s, border-color .25s; }
.rp-staff__arrow::before { content:''; position:absolute; top:50%; left:50%; width:8px; height:8px; border-top:1.5px solid var(--color-black); border-right:1.5px solid var(--color-black); }
.rp-staff__arrow--next::before { transform:translate(-65%,-50%) rotate(45deg); }
.rp-staff__arrow--prev::before { transform:translate(-35%,-50%) rotate(-135deg); }
.rp-staff__arrow:hover { background:var(--color-black); border-color:var(--color-black); }
.rp-staff__arrow:hover::before { border-color:#fff; }
.rp-staff::after { content:''; position:absolute; left:0; right:0; bottom:150px; height:220px; background:var(--color-yellow); z-index:0; }
.rp-staff__track { display:flex; gap:36px; margin-top:64px; padding:0 90px 8px; overflow-x:auto; scroll-snap-type:x mandatory; position:relative; z-index:1; }
.rp-staff__track::-webkit-scrollbar { height:6px; }
.rp-staff__track::-webkit-scrollbar-thumb { background:rgba(0,0,0,.25); border-radius:3px; }
.rp-staff-card { flex-shrink:0; width:300px; scroll-snap-align:start; }
.rp-staff-card__photo { position:relative; width:300px; height:420px; overflow:hidden; border-radius:2px; background:#222; }
.rp-staff-card__photo img { width:100%; height:100%; object-fit:cover; filter:grayscale(1); transition:filter .35s, transform .35s; }
.rp-staff-card:hover .rp-staff-card__photo img { filter:grayscale(0); transform:scale(1.04); }
.rp-staff-card__photo::after { content:''; position:absolute; inset:0; background:linear-gradient(transparent 52%, rgba(0,0,0,.78)); }
.rp-staff-card__info { position:absolute; left:0; right:0; bottom:0; padding:24px; z-index:2; }
.rp-staff-card__name { font-family:var(--font-zen); font-weight:700; font-size:22px; letter-spacing:2px; color:#fff; }
.rp-staff-card__role { margin-top:6px; font-size:13px; letter-spacing:1px; color:#e2e2e2; }
.rp-staff-card__more { display:inline-flex; align-items:center; gap:10px; margin-top:18px; font-size:13px; letter-spacing:1px; color:var(--color-black); text-decoration:underline; text-underline-offset:4px; }
.rp-staff-card__more-arrow { width:18px; height:18px; border-radius:50%; background:var(--color-black); position:relative; flex-shrink:0; }
.rp-staff-card__more-arrow::before { content:''; position:absolute; top:50%; left:50%; width:5px; height:5px; border-top:1.5px solid #fff; border-right:1.5px solid #fff; transform:translate(-65%,-50%) rotate(45deg); }

/* 1日の流れ */
.rp-flow { padding:120px 90px 140px; }
.rp-flow__head { display:flex; justify-content:space-between; align-items:flex-end; gap:40px; }
.rp-flow__lead { width:540px; font-size:15px; line-height:2; letter-spacing:1px; color:var(--color-dark-text); }
.rp-flow__body { display:grid; grid-template-columns:1fr 1fr; gap:80px; margin:72px auto 0; max-width:1260px; }
.rp-flow__photos { display:flex; flex-direction:column; gap:48px; padding-top:0; }
.rp-flow__photo { overflow:hidden; border-radius:6px; background:#eee; }
.rp-flow__photo img { width:100%; height:100%; object-fit:cover; display:block; }
.rp-flow__photo--a { width:100%; aspect-ratio:4/3; }
.rp-flow__photo--b { width:82%; aspect-ratio:4/3; margin-left:auto; }
.rp-flow__photo--c { width:92%; aspect-ratio:16/11; }
.rp-flow__steps { position:relative; padding-left:48px; padding-top:8px; }
.rp-flow__steps::before { content:''; position:absolute; left:6px; top:10px; bottom:10px; width:1px; background:var(--rp-border-1); }
.rp-flow-step { position:relative; padding-bottom:48px; }
.rp-flow-step:last-child { padding-bottom:0; }
.rp-flow-step::before { content:''; position:absolute; left:-48px; top:5px; width:12px; height:12px; border-radius:50%; background:var(--color-black); }
.rp-flow-step__time { font-family:var(--font-futura); font-weight:500; font-size:18px; letter-spacing:1px; color:var(--rp-gray-600); }
.rp-flow-step h3 { margin-top:8px; font-family:var(--font-zen); font-weight:700; font-size:20px; letter-spacing:1.5px; }
.rp-flow-step p { margin-top:10px; font-size:14px; line-height:1.9; letter-spacing:0.5px; color:var(--color-dark-text); }
.rp-flow__note { max-width:1260px; margin:24px auto 0; text-align:right; font-size:13px; color:var(--rp-gray-600); }

/* アクセス */
.rp-access { padding:120px 90px 140px; background:var(--rp-bg-gray); }
.rp-access__body { display:flex; gap:90px; margin-top:80px; align-items:flex-start; }
.rp-access__info { width:450px; flex-shrink:0; }
.rp-access__name { font-family:var(--font-zen); font-weight:700; font-size:28px; letter-spacing:2px; }
.rp-access__addr { margin-top:24px; font-size:15px; line-height:2; letter-spacing:1px; }
.rp-access__train { margin-top:24px; font-size:14px; line-height:2; letter-spacing:0.5px; color:var(--color-dark-text); }
.rp-access__map { flex:1; height:360px; border-radius:4px; overflow:hidden; background:#e6e6e6; }
.rp-access__map iframe { width:100%; height:100%; border:0; }

/* CTA (背景写真) */
.rp-cta { position:relative; padding:120px 90px; background-size:cover; background-position:center; }
.rp-cta__overlay { position:absolute; inset:0; background:rgba(8,10,12,.64); }
.rp-cta__box { position:relative; z-index:1; max-width:760px; margin:0 auto; text-align:center; }
.rp-cta__title { font-family:var(--font-zen); font-weight:700; font-size:40px; line-height:1.5; letter-spacing:3px; color:#fff; }
.rp-cta__lead { margin-top:28px; font-size:15px; line-height:2; letter-spacing:1px; color:#f0f0f0; }
.rp-cta__btns { margin-top:44px; display:flex; justify-content:center; gap:32px; flex-wrap:wrap; }
.rp-cta__btn { display:inline-flex; align-items:center; justify-content:center; gap:18px; min-width:300px; height:64px; padding:0 28px; font-weight:700; font-size:15px; letter-spacing:1.5px; border-radius:999px; transition:opacity .25s ease; }
.rp-cta__btn:hover { opacity:.85; }
.rp-cta__btn--entry { background:var(--color-yellow); color:var(--color-black); }
.rp-cta__btn--online { background:var(--color-black); color:#fff; }
.rp-cta__btn-arrow { width:26px; height:26px; border-radius:50%; position:relative; flex-shrink:0; }
.rp-cta__btn--entry .rp-cta__btn-arrow { background:var(--color-black); }
.rp-cta__btn--online .rp-cta__btn-arrow { background:#fff; }
.rp-cta__btn-arrow::before { content:''; position:absolute; top:50%; left:50%; width:6px; height:6px; border-top:1.5px solid currentColor; border-right:1.5px solid currentColor; transform:translate(-65%,-50%) rotate(45deg); }
.rp-cta__btn--entry .rp-cta__btn-arrow::before { color:var(--color-yellow); }
.rp-cta__btn--online .rp-cta__btn-arrow::before { color:var(--color-black); }

/* 他の拠点を見る (ダーク) */
.rp-other { padding:120px 90px 140px; background:var(--color-black); }
.rp-other .rp-heading__en { color:var(--rp-gray-600); }
.rp-other__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:40px 36px; margin-top:80px; }
.rp-office-card { background:#fff; border-radius:4px; overflow:hidden; display:flex; flex-direction:column; transition:transform .3s ease, box-shadow .3s ease; }
.rp-office-card:hover { transform:translateY(-6px); box-shadow:0 10px 30px rgba(0,0,0,.4); }
.rp-office-card__photo { width:100%; aspect-ratio:16/10; overflow:hidden; background:#222; }
.rp-office-card__photo img { width:100%; height:100%; object-fit:cover; }
.rp-office-card__info { padding:20px 24px 26px; }
.rp-office-card__name { display:flex; align-items:center; gap:10px; font-family:var(--font-zen); font-weight:700; font-size:18px; letter-spacing:1px; color:var(--color-black); text-decoration:underline; text-underline-offset:4px; }
.rp-office-card__arrow { width:22px; height:22px; border-radius:50%; background:var(--color-black); position:relative; flex-shrink:0; }
.rp-office-card__arrow::before { content:''; position:absolute; top:50%; left:50%; width:6px; height:6px; border-top:1.5px solid #fff; border-right:1.5px solid #fff; transform:translate(-65%,-50%) rotate(45deg); }
.rp-office-card__addr { margin-top:14px; font-size:13px; line-height:1.8; letter-spacing:.5px; color:var(--color-dark-text); }

/* パンくず */
.page-roppongi .breadcrumb { padding:32px 90px; border-top:1px solid var(--rp-border-1); }
.page-roppongi .breadcrumb__list { display:flex; flex-wrap:wrap; gap:8px; font-size:12px; letter-spacing:1px; color:var(--rp-gray-600); }
.page-roppongi .breadcrumb__list li { display:flex; align-items:center; }
.page-roppongi .breadcrumb__list li + li::before { content:'/'; margin:0 10px; color:var(--rp-gray-500); }
.page-roppongi .breadcrumb__list a { color:var(--color-dark-text); }
.page-roppongi .breadcrumb__list a:hover { text-decoration:underline; }

/* 狭幅PC */
@media (max-width:1200px) {
  .rp-hero__inner { flex-direction:column; gap:40px; }
  .rp-hero__left { max-width:none; }
  .rp-hero__photo { width:100%; height:auto; aspect-ratio:16/11; }
  .rp-hero__en { font-size:72px; }
  .rp-overview__desc { width:100%; }
  .rp-overview__wordmark { font-size:120px; }
  .rp-stats { grid-template-columns:repeat(2,1fr); }
  .rp-stat--feature { grid-row:span 1; }
  .rp-teams__grid { grid-template-columns:repeat(2,1fr); }
  .rp-message__body, .rp-access__body, .rp-env-point, .rp-env-point--reverse { flex-direction:column; gap:40px; }
  .rp-message__photo, .rp-access__info, .rp-env-point__photo { width:100%; }
  .rp-flow__body { grid-template-columns:1fr; gap:40px; }
  .rp-flow__photos { flex-direction:row; flex-wrap:wrap; }
  .rp-flow__photo--a, .rp-flow__photo--b, .rp-flow__photo--c { width:48%; margin:0; }
  .rp-other__grid { grid-template-columns:repeat(2,1fr); }
  .rp-staff__head { flex-direction:column; align-items:flex-start; gap:24px; }
  .rp-env__deco { font-size:90px; }
  .rp-cta__btn { min-width:0; width:100%; max-width:360px; }
}

/* ===================== SP ===================== */
.page-roppongi-sp { background:#fff; color:var(--color-black); font-family:var(--font-noto); overflow:hidden; }
.page-roppongi-sp img { display:block; max-width:100%; }

/* SP ヒーロー */
.rps-hero { padding:36px 24px 8px; }
.rps-hero__titlewrap { display:flex; align-items:flex-start; gap:14px; }
.rps-hero__en { font-family:var(--font-futura); font-weight:600; font-size:48px; line-height:1; letter-spacing:0; color:var(--color-black); }
.rps-hero__mark { background:linear-gradient(transparent 36%, var(--color-yellow) 36%, var(--color-yellow) 76%, transparent 76%); padding:0 2px; box-decoration-break:clone; -webkit-box-decoration-break:clone; }
.rps-hero__jami { width:96px; height:auto; margin-top:4px; align-self:flex-start; }
.rps-hero__jp { font-family:var(--font-zen); font-weight:700; font-size:17px; letter-spacing:3px; margin-top:16px; }
.rps-hero .rps-lead { margin-top:18px; }
.rps-hero__photo { aspect-ratio:4/3; height:auto; margin-top:20px; }
.rps-hero__photo img { width:100%; height:100%; object-fit:cover; }
.rps-hero__anchor { display:flex; flex-wrap:wrap; gap:8px; margin-top:22px; }
.rps-hero__anchor a { display:inline-flex; align-items:center; gap:8px; background:var(--color-black); color:#fff; font-size:12px; letter-spacing:.5px; padding:9px 14px; border-radius:999px; }
.rps-hero__anchor a span { width:5px; height:5px; border-right:1.5px solid #fff; border-bottom:1.5px solid #fff; transform:rotate(45deg); margin-top:-3px; }

.rps-section { padding:64px 24px; }
.rps-section--dark { background:var(--color-black); }
.rps-section--dark .rps-text, .rps-section--dark p { color:#e6e6e6; }

.rps-heading { position:relative; padding-left:14px; margin-bottom:28px; }
.rps-heading::before { content:''; position:absolute; left:0; top:4px; bottom:4px; width:3px; border-radius:2px; background:var(--color-yellow); }
.rps-heading__jp { font-family:var(--font-zen); font-weight:700; font-size:26px; letter-spacing:2px; color:var(--color-black); }
.rps-heading__jp--white { color:#fff; }
.rps-heading__en { font-family:var(--font-futura); font-weight:500; font-size:15px; color:var(--rp-gray-600); text-transform:uppercase; margin-top:6px; }

.rps-lead { font-family:var(--font-zen); font-weight:500; font-size:16px; line-height:1.9; letter-spacing:1px; }
.rps-lead--white { color:#fff; }
.rps-text { font-size:14px; line-height:1.9; letter-spacing:0.5px; color:var(--color-dark-text); margin-top:16px; }
.rps-photo { width:100%; margin:24px 0; border-radius:4px; overflow:hidden; background:#eee; }
.rps-photo img { width:100%; height:100%; object-fit:cover; }

.rps-gallery { column-count:2; column-gap:12px; }
.rps-gallery img { width:100%; height:auto; border-radius:4px; background:#eee; margin-bottom:12px; break-inside:avoid; display:block; aspect-ratio:4/3; object-fit:cover; }

.rps-stats { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.rps-stat { background:var(--rp-gray-800); border:1px dashed var(--rp-border-3); border-radius:4px; padding:20px 16px; text-align:center; }
.rps-stat__label { font-size:13px; color:var(--rp-gray-500); letter-spacing:1px; }
.rps-stat__value { font-weight:700; font-size:32px; color:#fff; margin-top:6px; }
.rps-stat__value span { font-size:16px; }

.rps-teams { display:flex; flex-direction:column; gap:16px; }
.rps-team { background:#fff; border:1px solid var(--rp-border-1); border-radius:6px; padding:20px; }
.rps-team__tag { position:relative; display:inline-block; padding-left:14px; font-family:var(--font-zen); font-weight:700; font-size:15px; color:var(--color-black); margin-bottom:12px; }
.rps-team__tag::before { content:''; position:absolute; left:0; top:2px; bottom:2px; width:3px; background:var(--color-black); }
.rps-team p { font-size:13px; line-height:1.85; color:var(--color-dark-text); }

.rps-message-title { font-family:var(--font-zen); font-weight:700; font-size:20px; line-height:1.6; letter-spacing:1px; margin-top:8px; }
.rps-message-name { margin-top:20px; font-family:var(--font-zen); font-weight:700; font-size:18px; }
.rps-message-name span { font-family:var(--font-noto); font-weight:400; font-size:13px; color:var(--rp-gray-600); }

.rps-vision { display:flex; flex-direction:column; gap:16px; margin-top:24px; }
.rps-vision-card { position:relative; background:var(--color-black); border:1px dashed var(--rp-border-3); border-radius:6px; padding:28px 24px; overflow:hidden; }
.rps-vision-card > * { position:relative; z-index:1; }
.rps-vision-card__num { position:absolute; top:16px; right:18px; z-index:0; font-family:var(--font-futura); font-size:64px; color:var(--rp-gray-700); line-height:1; }
.rps-vision-card h3 { font-weight:700; font-size:20px; color:#fff; text-decoration:underline; text-underline-offset:5px; padding-right:56px; }
.rps-vision-card p { font-size:13px; line-height:1.9; color:#fff; margin-top:16px; }

.rps-points { display:flex; flex-direction:column; gap:40px; }
.rps-point .rps-photo { margin:0 0 16px; }
.rps-point__no { font-family:var(--font-futura); font-size:15px; color:var(--rp-gray-600); }
.rps-point h3 { font-family:var(--font-zen); font-weight:700; font-size:20px; letter-spacing:1px; margin-top:8px; }
.rps-point p { font-size:13px; line-height:1.85; color:var(--color-dark-text); margin-top:12px; }

.rps-staff { display:flex; gap:16px; overflow-x:auto; margin-top:24px; padding-bottom:8px; scroll-snap-type:x mandatory; }
.rps-staff-card { flex-shrink:0; width:220px; scroll-snap-align:start; }
.rps-staff-card img { width:220px; height:300px; object-fit:cover; border-radius:4px; background:#e6e6e6; }

.rps-timeline { display:flex; flex-direction:column; gap:28px; margin-top:24px; border-left:1px solid var(--rp-border-1); padding-left:24px; }
.rps-tl { position:relative; }
.rps-tl::before { content:''; position:absolute; left:-29px; top:5px; width:10px; height:10px; border-radius:50%; background:var(--color-black); }
.rps-tl__time { font-family:var(--font-futura); font-size:16px; color:var(--rp-gray-600); }
.rps-tl h3 { font-family:var(--font-zen); font-weight:700; font-size:17px; margin-top:6px; }
.rps-tl p { font-size:13px; line-height:1.8; color:var(--color-dark-text); margin-top:8px; }
.rps-note { font-size:12px; color:var(--rp-gray-600); margin-top:16px; }

.rps-access-name { font-family:var(--font-zen); font-weight:700; font-size:22px; }
.rps-map { width:100%; height:240px; border-radius:4px; overflow:hidden; background:#e6e6e6; margin-top:20px; }
.rps-map iframe { width:100%; height:100%; border:0; }

.rps-cta { position:relative; padding:64px 24px; text-align:center; background-size:cover; background-position:center; }
.rps-cta__overlay { position:absolute; inset:0; background:rgba(8,10,12,.64); }
.rps-cta__inner { position:relative; z-index:1; }
.rps-cta__title { font-family:var(--font-zen); font-weight:700; font-size:24px; line-height:1.5; letter-spacing:1px; color:#fff; }
.rps-cta__lead { font-size:13px; line-height:1.9; color:#eee; margin-top:16px; }
.rps-cta__btn { display:flex; align-items:center; justify-content:center; height:60px; max-width:360px; margin:16px auto 0; border-radius:999px; font-weight:700; font-size:15px; letter-spacing:1px; }
.rps-cta__btn--entry { background:var(--color-yellow); color:var(--color-black); }
.rps-cta__btn--online { background:var(--color-black); color:#fff; }

/* SP 他の拠点 */
.rps-offices { display:flex; flex-direction:column; gap:20px; }
.rps-office { display:block; background:#fff; border-radius:4px; overflow:hidden; }
.rps-office__photo { width:100%; aspect-ratio:16/10; overflow:hidden; background:#222; }
.rps-office__photo img { width:100%; height:100%; object-fit:cover; }
.rps-office__name { font-family:var(--font-zen); font-weight:700; font-size:16px; color:var(--color-black); padding:14px 18px 0; text-decoration:underline; text-underline-offset:3px; }
.rps-office__addr { font-size:12px; line-height:1.7; color:var(--color-dark-text); padding:8px 18px 18px; }

.breadcrumb--sp { padding:24px; border-top:1px solid var(--rp-border-1); }
.breadcrumb--sp .breadcrumb__list { display:flex; flex-wrap:wrap; gap:6px; font-size:11px; color:var(--rp-gray-600); }
.breadcrumb--sp .breadcrumb__list li + li::before { content:'/'; margin:0 8px; }
.breadcrumb--sp .breadcrumb__list a { color:var(--color-dark-text); }

@media (min-width:600px) {
  .rps-section, .rps-cta { padding-left:48px; padding-right:48px; }
  .rps-stats { grid-template-columns:repeat(4,1fr); }
  .rps-gallery { column-count:3; }
  .rps-points { display:grid; grid-template-columns:repeat(2,1fr); gap:32px; }
}
