@charset "UTF-8";
/* =========================================================
   page-extras.css
   各固定ページ専用の CSS を集約。post_content からインライン <style> を抽出して移植。
   各ページのクラス名は独立しているため、明示的なスコープは付与しない。
   生成: 2026-05-06 23:58
========================================================= */


/* =========================================================
   11981 : /about/
========================================================= */
/* =========================================
   ABOUT — 会社概要 統合ページ
   理念 / 代表メッセージ / 会社概要 / アクセス
========================================= */

/* Hero */
.about-mv {
  position: relative;
  height: clamp(72vh, 90vh, 920px);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: 0 0 clamp(72px, 9vw, 120px);
}
.about-mv .bg {
  position: absolute; inset: 0;
  background-image: url('/wp-content/themes/apricot-2026/assets/photos/company/company-04.jpg');
  background-size: cover;
  background-position: center;
}
.about-mv::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.30) 0%, rgba(0,0,0,0) 25%, rgba(0,0,0,0) 60%, rgba(0,0,0,0.55) 100%);
}
.about-mv .container { position: relative; z-index: 2; color: #fff; }
.about-mv .breadcrumb {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: rgba(255,255,255,0.75);
  margin-bottom: 32px;
}
.about-mv .breadcrumb a { color: rgba(255,255,255,0.75); }
.about-mv .breadcrumb span { color: rgba(255,255,255,0.4); }
.about-mv .small {
  font-family: var(--font-en);
  font-weight: 300;
  font-size: clamp(13px, 1.4vw, 18px);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  display: block;
  color: rgba(255,255,255,0.85);
  margin-bottom: 24px;
}
.about-mv .big {
  font-family: var(--font-serif-jp);
  font-weight: 500;
  font-size: clamp(34px, 5.8vw, 88px);
  line-height: 1.45;
  color: #fff;
  letter-spacing: 0.06em;
  margin-bottom: 28px;
  text-shadow: 0 2px 28px rgba(0,0,0,0.22);
}
.about-mv h1 {
  font-size: clamp(13px, 1.2vw, 16px);
  font-weight: 400;
  letter-spacing: 0.24em;
  color: rgba(255,255,255,0.85);
}

/* Section commons */
section.s-philosophy,
section.s-message,
section.s-company,
section.s-access,
section.s-final-cta {
  padding-top: clamp(120px, 16vw, 200px);
  padding-bottom: clamp(120px, 16vw, 200px);
}
.s-philosophy { background: var(--c-bg); }
.s-message { background: var(--c-bg-soft); }
.s-company { background: var(--c-bg); }
.s-access { background: var(--c-bg-soft); }
.s-final-cta { background: var(--c-bg); padding-top: clamp(80px, 10vw, 120px); padding-bottom: clamp(80px, 10vw, 120px); }

.section-label {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.section-label::before {
  content: '';
  width: 32px; height: 1px;
  background: var(--c-sub);
}

/* Editorial intro under section label */
.editorial-head {
  max-width: 800px;
  margin: 0 auto clamp(64px, 8vw, 100px);
  text-align: center;
}
.editorial-head h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(24px, 3.4vw, 44px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.12em;
  color: var(--c-black);
}
.editorial-body {
  max-width: 640px;
  margin: 0 auto;
}
.editorial-body p {
  font-size: 15px;
  line-height: 2.4;
  margin-bottom: 28px;
  color: var(--c-text);
  letter-spacing: 0.06em;
}

/* MVA grid */
.mva-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(48px, 6vw, 100px) clamp(32px, 5vw, 80px);
  max-width: 1280px;
  margin: clamp(72px, 8vw, 120px) auto 0;
}
.mva-item .num {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 28px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.mva-item .num::after {
  content: '';
  width: 32px; height: 1px;
  background: var(--c-sub);
}
.mva-item .en {
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: clamp(22px, 2.2vw, 28px);
  color: var(--c-sub);
  margin-bottom: 8px;
  display: block;
  letter-spacing: 0.02em;
}
.mva-item h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(18px, 1.8vw, 22px);
  font-weight: 500;
  line-height: 1.7;
  color: var(--c-black);
  letter-spacing: 0.08em;
  margin-bottom: 28px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--c-line);
}
.mva-item p {
  font-size: 14px;
  line-height: 2.2;
  color: var(--c-text);
  letter-spacing: 0.06em;
}
@media (max-width: 800px) { .mva-grid { grid-template-columns: 1fr; } }

/* Approach (4 cards) */
.approach-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(40px, 5vw, 72px);
  max-width: 1080px;
  margin: clamp(80px, 10vw, 140px) auto 0;
  border-top: 1px solid var(--c-line);
  padding-top: clamp(48px, 6vw, 80px);
}
.approach-item .num {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 14px;
  display: block;
}
.approach-item h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(18px, 1.8vw, 22px);
  font-weight: 500;
  color: var(--c-black);
  letter-spacing: 0.08em;
  margin-bottom: 20px;
  line-height: 1.7;
}
.approach-item p { font-size: 14px; line-height: 2.2; color: var(--c-text); letter-spacing: 0.06em; }
@media (max-width: 800px) { .approach-grid { grid-template-columns: 1fr; } }

/* Photo band */
.photo-band {
  position: relative;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background: var(--c-bg-soft);
}
.photo-band img { display: block; width: 100%; height: 100%; object-fit: cover; }
.photo-band.aspect-21x9 { aspect-ratio: 21 / 9; }
.photo-band.aspect-16x9 { aspect-ratio: 16 / 9; }

/* Message — portrait + flowing letter */
.message-portrait {
  margin: 0 auto clamp(60px, 8vw, 100px);
  max-width: 720px;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--c-bg);
}
.message-portrait img { width: 100%; height: 100%; object-fit: cover; }
.message-body {
  max-width: 680px;
  margin: 0 auto;
}
.message-body .pre-title {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 24px;
  text-align: center;
}
.message-body h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.12em;
  color: var(--c-black);
  margin-bottom: 56px;
  text-align: center;
}
.message-body h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(18px, 1.8vw, 22px);
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--c-black);
  margin-top: 56px;
  margin-bottom: 28px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--c-line);
}
.message-body p {
  font-size: 15px;
  line-height: 2.4;
  margin-bottom: 28px;
  color: var(--c-text);
  letter-spacing: 0.06em;
}
.message-body .sign {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--c-line);
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
  gap: 16px;
}
.message-body .sign .role {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--c-sub);
}
.message-body .sign .name {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.1em;
}

/* Company table */
.company-table {
  width: 100%;
  max-width: 880px;
  margin: 0 auto;
  border-top: 1px solid var(--c-line);
}
.company-table tr { border-bottom: 1px solid var(--c-line); }
.company-table th,
.company-table td {
  padding: 28px 0;
  text-align: left;
  vertical-align: top;
  font-size: 14px;
  line-height: 2;
}
.company-table th {
  width: 220px;
  font-family: var(--font-en);
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--c-sub);
  font-size: 12px;
  padding-right: 24px;
}
.company-table td { color: var(--c-text); letter-spacing: 0.06em; }
@media (max-width: 700px) {
  .company-table th, .company-table td { display: block; padding: 12px 0; }
  .company-table th { width: 100%; padding-bottom: 4px; }
  .company-table td { padding-top: 0; padding-bottom: 24px; }
}

/* Trademark table */
.trademark-wrap {
  max-width: 880px;
  margin: clamp(72px, 8vw, 120px) auto 0;
}
.trademark-wrap .sub-label {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.28em;
  color: var(--c-sub);
  margin-bottom: 20px;
  display: block;
}
.trademark-wrap h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(18px, 1.8vw, 22px);
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--c-black);
  margin-bottom: 36px;
}
.trademark-table {
  width: 100%;
  border-top: 1px solid var(--c-line);
}
.trademark-table tr { border-bottom: 1px solid var(--c-line); }
.trademark-table td {
  padding: 22px 0;
  font-size: 13px;
  line-height: 2;
  letter-spacing: 0.06em;
  color: var(--c-text);
}
.trademark-table td:first-child {
  width: 50%;
  color: var(--c-black);
  font-weight: 500;
}
.trademark-table td:last-child {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.1em;
  color: var(--c-sub);
}

/* Clients */
.clients-wrap {
  max-width: 880px;
  margin: clamp(72px, 8vw, 120px) auto 0;
}
.clients-wrap p {
  font-size: 14px;
  line-height: 2.2;
  letter-spacing: 0.06em;
  color: var(--c-text);
  margin-bottom: 20px;
}
.clients-wrap .clients-list {
  font-size: 13px;
  line-height: 2.4;
  letter-spacing: 0.06em;
  color: var(--c-text);
  padding: 32px 0;
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
}
.clients-wrap .note { font-size: 12px; color: var(--c-sub); margin-top: 24px; line-height: 2; }

/* Access — 2 office grid */
.office-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--c-line);
  border-left: 1px solid var(--c-line);
  margin-top: clamp(48px, 6vw, 80px);
}
.office-card {
  padding: clamp(40px, 5vw, 72px) clamp(28px, 4vw, 56px);
  border-right: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  background: var(--c-bg);
}
.office-card .visual {
  aspect-ratio: 16 / 10;
  background: var(--c-bg-soft);
  margin-bottom: 32px;
  overflow: hidden;
}
.office-card .visual img { width: 100%; height: 100%; object-fit: cover; }
.office-card .visual.map iframe { width: 100%; height: 100%; border: 0; display: block; }
.office-card .label {
  font-family: var(--font-en);
  font-size: 13px;
  letter-spacing: 0.24em;
  color: var(--c-black);
  margin-bottom: 16px;
  display: block;
  font-weight: 500;
}
.office-card h3 {
  font-size: 18px;
  font-weight: 500;
  color: var(--c-black);
  margin-bottom: 14px;
  letter-spacing: 0.06em;
}
.office-card .zip { font-family: var(--font-en); font-size: 12px; color: var(--c-sub); margin-bottom: 6px; letter-spacing: 0.06em; }
.office-card .addr { font-size: 14px; line-height: 2; color: var(--c-text); margin-bottom: 16px; }
.office-card .meta { font-size: 13px; color: var(--c-sub); line-height: 2; margin-bottom: 24px; }
.office-card .map-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--c-black);
  border-bottom: 1px solid var(--c-black);
  padding-bottom: 4px;
}
.office-card .map-link::after { content: '↗'; font-size: 14px; }
@media (max-width: 800px) { .office-grid { grid-template-columns: 1fr; } }

/* Visit info card */
.visit-info {
  max-width: 880px;
  margin: clamp(60px, 8vw, 100px) auto 0;
  padding: clamp(36px, 4vw, 56px) clamp(28px, 4vw, 64px);
  background: var(--c-bg);
  border: 1px solid var(--c-line);
}
.visit-info .label {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.28em;
  color: var(--c-sub);
  margin-bottom: 16px;
  display: block;
}
.visit-info h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(18px, 1.8vw, 22px);
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-bottom: 28px;
}
.visit-info ul { list-style: none; padding: 0; }
.visit-info li {
  font-size: 14px;
  line-height: 2.2;
  letter-spacing: 0.06em;
  padding-left: 18px;
  position: relative;
  color: var(--c-text);
}
.visit-info li::before {
  content: '';
  position: absolute;
  left: 0; top: 1.05em;
  width: 8px; height: 1px;
  background: var(--c-sub);
}

/* Final CTA */
.s-final-cta .ctablk {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.s-final-cta h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(20px, 2.4vw, 30px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.1em;
  margin-bottom: 28px;
  color: var(--c-black);
}
.s-final-cta p { font-size: 14px; line-height: 2.2; letter-spacing: 0.06em; color: var(--c-text); margin-bottom: 40px; }
.s-final-cta .btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 18px 40px;
  background: var(--c-black);
  color: #fff;
  font-size: 13px;
  letter-spacing: 0.18em;
  border-radius: 999px;
}
.s-final-cta .btn::after { content: '→'; font-size: 14px; }

/* =========================================================
   11984 : /download/
========================================================= */
.dl-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 48px);
}
.dl-card {
  background: var(--c-bg-soft);
  padding: clamp(28px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  border: 1px solid var(--c-line);
}
.dl-card .preview {
  aspect-ratio: 4 / 5;
  background: var(--c-bg);
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.dl-card .preview img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.dl-card .badge {
  position: absolute;
  top: 12px; left: 12px;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.2em;
  color: #fff;
  background: var(--c-black);
  padding: 5px 10px;
}
.dl-card .en {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.2em;
  color: var(--c-sub);
  margin-bottom: 8px;
}
.dl-card h3 {
  font-size: 17px;
  font-weight: 500;
  color: var(--c-black);
  margin-bottom: 14px;
  letter-spacing: 0.04em;
}
.dl-card p {
  font-size: 13px;
  line-height: 2;
  color: var(--c-sub);
  margin-bottom: 24px;
  flex-grow: 1;
}
.dl-card .meta {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--c-sub);
  margin-bottom: 16px;
  display: flex;
  gap: 14px;
}
.dl-card .btn {
  width: 100%;
  justify-content: center;
}
@media (max-width: 800px) { .dl-grid { grid-template-columns: 1fr; } }

.dl-form-block { background: var(--c-bg); }
.dl-form {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 28px clamp(28px, 4vw, 56px);
  padding-top: clamp(32px, 4vw, 56px);
}
.dl-form .field { display: contents; }
.dl-form label {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--c-black);
  padding-top: 18px;
  line-height: 1.5;
}
.dl-form .input { display: block; }
.dl-form input, .dl-form select, .dl-form textarea {
  width: 100%;
  font-family: inherit;
  font-size: 16px;
  padding: 16px 18px;
  border: 1px solid var(--c-line);
  background: #fafafa;
  color: var(--c-black);
  outline: none;
  border-radius: 4px;
  transition: background .15s ease, border-color .15s ease;
}
.dl-form input:hover, .dl-form select:hover, .dl-form textarea:hover { background: #f4f4f4; }
.dl-form input:focus, .dl-form select:focus, .dl-form textarea:focus {
  background: #ffffff;
  border-color: var(--c-black);
}
.dl-form input::placeholder, .dl-form textarea::placeholder { color: #a0a0a0; }
.dl-form textarea { min-height: 160px; resize: vertical; line-height: 1.9; }
.dl-form .submit-row {
  grid-column: 1 / -1;
  text-align: center;
  margin-top: 32px;
}
.dl-form button {
  background: var(--c-black);
  color: #fff;
  border: 1px solid var(--c-black);
  padding: 22px 80px;
  font-family: var(--font-en);
  font-size: 13px;
  letter-spacing: 0.18em;
  cursor: pointer;
  transition: all .25s ease;
}
.dl-form button:hover { background: transparent; color: var(--c-black); }

@media (max-width: 700px) { .dl-form { grid-template-columns: 1fr; } }

/* =========================================================
   16678 : /environment/
========================================================= */
.env-stance { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 100px); align-items: center; padding: clamp(80px, 10vw, 140px) 0; border-bottom: 1px solid var(--c-line); }
.env-stance:last-of-type { border-bottom: none; }
.env-stance:first-of-type { padding-top: 140px; }
.env-stance.reveal.is-in { margin-top: 0; }
.env-stance.alt.reveal.is-in { margin-top: 0; }
.env-stance.alt { direction: rtl; }
.env-stance.alt > * { direction: ltr; }
.env-stance .img { aspect-ratio: 4 / 5; overflow: hidden; background: var(--c-bg); }
.env-stance .img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s cubic-bezier(.2,.8,.2,1); }
.env-stance:hover .img img { transform: scale(1.04); }
.env-stance .body .num { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.32em; color: var(--c-sub); margin-bottom: 24px; display: inline-flex; align-items: center; gap: 14px; }
.env-stance .body .num::after { content: ''; width: 32px; height: 1px; background: var(--c-sub); }
.env-stance .body h2 { font-family: var(--font-serif-jp); font-size: clamp(22px, 2.6vw, 32px); font-weight: 500; line-height: 1.7; letter-spacing: 0.08em; color: var(--c-black); margin-bottom: 28px; padding-bottom: 28px; border-bottom: 1px solid var(--c-line); }
.env-stance .body p { font-size: 15px; line-height: 2.4; margin-bottom: 24px; letter-spacing: 0.06em; color: var(--c-text); }
@media (max-width: 800px) { .env-stance, .env-stance.alt { grid-template-columns: 1fr; direction: ltr; } }

.tv-mark { display: flex; flex-wrap: wrap; gap: 14px 28px; padding: 28px 0; border-top: 1px solid var(--c-line); margin-top: 8px; }
.tv-mark span { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.18em; color: var(--c-sub); }

.benefits-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--c-line); border-left: 1px solid var(--c-line); }
.benefit-item { padding: clamp(28px, 3vw, 44px); border-right: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); background: var(--c-bg-soft); }
.benefit-item .en { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.24em; color: var(--c-sub); margin-bottom: 16px; display: block; }
.benefit-item h4 { font-size: 16px; font-weight: 500; color: var(--c-black); margin-bottom: 12px; letter-spacing: 0.06em; }
.benefit-item p { font-size: 13px; line-height: 2; color: var(--c-text); letter-spacing: 0.04em; }
@media (max-width: 800px) { .benefits-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .benefits-grid { grid-template-columns: 1fr; } }

/* =========================================================
   16679 : /faq/
========================================================= */
.faq-cat {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--c-sub);
  margin-top: 100px;
  margin-bottom: 24px;
  padding-top: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--c-line);
  display: block;
}
.faq-list { max-width: 880px; margin: 0 auto clamp(60px, 8vw, 100px); }
.faq-item { padding: 28px 0; border-bottom: 1px solid var(--c-line); }
.faq-item .q {
  display: flex; gap: 18px;
  font-family: var(--font-serif-jp);
  font-size: clamp(16px, 1.6vw, 18px);
  font-weight: 500;
  color: var(--c-black);
  margin-bottom: 18px;
  letter-spacing: 0.06em;
  line-height: 1.7;
}
.faq-item .q::before {
  content: 'Q.';
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: 20px;
  color: var(--c-sub);
  flex-shrink: 0;
}
.faq-item .a {
  display: flex;
  gap: 18px;
  font-size: 14px;
  line-height: 2.2;
  color: var(--c-text);
  letter-spacing: 0.06em;
}
.faq-item .a::before {
  content: 'A.';
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: 20px;
  color: var(--c-sub);
  flex-shrink: 0;
}
@media (max-width: 600px) {
  .faq-cat { margin-top: 40px; }
}

/* =========================================================
   16673 : /keys/
========================================================= */
/* Article-style page hero */
.art-mv {
  background: var(--c-bg);
  padding: clamp(140px, 16vw, 220px) 0 clamp(80px, 10vw, 140px);
  border-bottom: 1px solid var(--c-line);
}
.art-mv .breadcrumb {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--c-sub);
  margin-bottom: 32px;
}
.art-mv .breadcrumb a { color: var(--c-sub); }
.art-mv .breadcrumb span { color: var(--c-line); }
.art-mv .en-label {
  font-family: var(--font-en);
  font-size: clamp(13px, 1.4vw, 16px);
  letter-spacing: 0.32em;
  color: var(--c-sub);
  display: block;
  margin-bottom: 24px;
}
.art-mv h1 {
  font-family: var(--font-serif-jp);
  font-size: clamp(28px, 4.4vw, 56px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.08em;
  color: var(--c-black);
  margin-bottom: 36px;
  max-width: 900px;
}
.art-mv .lead {
  font-size: clamp(13px, 1.4vw, 16px);
  line-height: 2.2;
  letter-spacing: 0.06em;
  color: var(--c-text);
  max-width: 720px;
}

/* Article body — narrow text */
.art-body {
  background: var(--c-bg-soft);
  padding: clamp(120px, 14vw, 200px) 0;
}
.art-narrow {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 clamp(24px, 4vw, 40px);
}
.art-narrow h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(22px, 2.6vw, 32px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.1em;
  color: var(--c-black);
  margin: clamp(72px, 9vw, 120px) 0 36px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--c-line);
}
.art-narrow h2:first-child { margin-top: 0; }
.art-narrow h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(18px, 1.8vw, 22px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.08em;
  color: var(--c-black);
  margin: 56px 0 24px;
}
.art-narrow p {
  font-size: 15px;
  line-height: 2.4;
  margin-bottom: 28px;
  letter-spacing: 0.06em;
  color: var(--c-text);
}
.art-narrow ul {
  list-style: none;
  padding: 0;
  margin: 28px 0;
  border-top: 1px solid var(--c-line);
}
.art-narrow li {
  padding: 18px 0 18px 24px;
  border-bottom: 1px solid var(--c-line);
  position: relative;
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.06em;
  color: var(--c-text);
}
.art-narrow li::before {
  content: '';
  position: absolute;
  left: 0; top: 1.7em;
  width: 8px; height: 1px;
  background: var(--c-sub);
}

/* Pull quote */
.art-pull {
  margin: clamp(60px, 8vw, 100px) 0;
  padding: clamp(40px, 5vw, 64px);
  background: var(--c-bg);
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  text-align: center;
}
.art-pull p {
  font-family: var(--font-serif-jp);
  font-size: clamp(18px, 2vw, 22px);
  line-height: 2;
  letter-spacing: 0.1em;
  color: var(--c-black);
  font-weight: 500;
}

/* Article CTA */
.art-cta {
  background: var(--c-bg);
  padding: clamp(80px, 10vw, 120px) 0;
  text-align: center;
}
.art-cta h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(20px, 2.4vw, 30px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.1em;
  margin-bottom: 28px;
  color: var(--c-black);
}
.art-cta p { font-size: 14px; line-height: 2.2; letter-spacing: 0.06em; color: var(--c-text); margin-bottom: 40px; max-width: 640px; margin-left: auto; margin-right: auto; }
.art-cta .btn-row { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.art-cta .btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 16px 36px;
  font-size: 13px;
  letter-spacing: 0.18em;
  border-radius: 999px;
}
.art-cta .btn::after { content: '→'; font-size: 14px; }
.art-cta .btn-primary { background: var(--c-black); color: #fff; }
.art-cta .btn-ghost { background: transparent; color: var(--c-black); border: 1px solid var(--c-black); }

/* Related links */
.art-related {
  background: var(--c-bg-soft);
  padding: clamp(80px, 10vw, 140px) 0;
  border-top: 1px solid var(--c-line);
}
.art-related .label {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 28px;
  display: block;
  text-align: center;
}
.art-related h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(20px, 2.4vw, 28px);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
  margin-bottom: clamp(48px, 6vw, 72px);
}
.related-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 2.4vw, 32px);
  max-width: 1280px;
  margin: 0 auto;
}
.related-grid a {
  display: block;
  padding: 28px clamp(20px,3vw,32px);
  background: var(--c-bg);
  border: 1px solid var(--c-line);
}
.related-grid a:hover { border-color: var(--c-black); }
.related-grid .lab { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.24em; color: var(--c-sub); display: block; margin-bottom: 12px; }
.related-grid h3 { font-size: 15px; font-weight: 500; letter-spacing: 0.06em; line-height: 1.7; color: var(--c-black); }
@media (max-width: 800px) { .related-grid { grid-template-columns: repeat(2, 1fr); } }

/* =========================================================
   16680 : /message/
========================================================= */
.message-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr); gap: clamp(40px, 6vw, 96px); align-items: start; max-width: 1200px; margin: 0 auto; }
.message-portrait { aspect-ratio: 4 / 5; overflow: hidden; background: var(--c-bg); position: sticky; top: 100px; }
.message-portrait img { width: 100%; height: 100%; object-fit: cover; }
.message-body { max-width: none; }
.message-body h2 { text-align: left; font-family: var(--font-serif-jp); font-size: clamp(22px, 2.6vw, 30px); font-weight: 500; line-height: 2; letter-spacing: 0.1em; color: var(--c-black); margin: 0 0 clamp(36px, 4vw, 56px); padding-bottom: clamp(28px, 3vw, 36px); border-bottom: 0; }
.message-body p { font-size: 15px; line-height: 2.4; margin-bottom: 28px; color: var(--c-text); letter-spacing: 0.06em; }
.message-body p:last-of-type { margin-bottom: 0; }
.message-body .sign { margin-top: clamp(40px, 4vw, 56px); padding-top: 28px; border-top: 0; display: flex; justify-content: flex-end; align-items: baseline; gap: 16px; }
.message-body .sign .role { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.24em; color: var(--c-sub); }
.message-body .sign .name { font-size: 18px; font-weight: 500; letter-spacing: 0.1em; color: var(--c-black); }
@media (max-width: 900px) {
  .message-grid { grid-template-columns: 1fr; gap: 40px; }
  .message-portrait { position: static; width: 70%; max-width: 480px; margin: 0 auto; }
  .message-body .sign { display: grid; grid-template-columns: 1fr; gap: 8px; justify-items: end; }
  .message-body .sign .role { text-align: right; }
  .message-body .sign .name { text-align: right; }
}

/* =========================================================
   16672 : /new-business/
========================================================= */
/* New business — entry page */
.nb-mv {
  position: relative;
  min-height: clamp(60vh, 80vh, 760px);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: clamp(120px, 14vw, 200px) 0 clamp(72px, 8vw, 120px);
  background: var(--c-bg);
}
.nb-mv .bg {
  position: absolute; inset: 0;
  background-image: url('/wp-content/themes/apricot-2026/assets/photos/branding/branding-03.jpg');
  background-size: cover;
  background-position: center;
  opacity: 0.85;
}
.nb-mv::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0.55) 100%);
}
.nb-mv .container { position: relative; z-index: 2; color: #fff; }
.nb-mv .breadcrumb {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: rgba(255,255,255,0.75);
  margin-bottom: 32px;
}
.nb-mv .breadcrumb a { color: rgba(255,255,255,0.75); }
.nb-mv .breadcrumb span { color: rgba(255,255,255,0.4); }
.nb-mv .en-label {
  font-family: var(--font-en);
  font-size: clamp(14px, 1.4vw, 18px);
  letter-spacing: 0.32em;
  display: block;
  color: rgba(255,255,255,0.85);
  margin-bottom: 24px;
}
.nb-mv h1 {
  font-family: var(--font-serif-jp);
  font-weight: 500;
  font-size: clamp(28px, 4.8vw, 64px);
  line-height: 1.55;
  letter-spacing: 0.06em;
  color: #fff;
  margin-bottom: 32px;
  text-shadow: 0 2px 28px rgba(0,0,0,0.22);
}
.nb-mv .lead {
  font-size: clamp(13px, 1.4vw, 16px);
  line-height: 2.2;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.92);
  max-width: 640px;
}

/* Section commons */
section.nb-sec {
  padding-top: clamp(120px, 14vw, 180px);
  padding-bottom: clamp(120px, 14vw, 180px);
}
.nb-sec.bg-soft { background: var(--c-bg-soft); }
.nb-sec.bg-base { background: var(--c-bg); }
.section-label {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.section-label::before { content: ''; width: 32px; height: 1px; background: var(--c-sub); }
.nb-head {
  max-width: 800px;
  margin: 0 auto clamp(64px, 8vw, 100px);
  text-align: center;
}
.nb-head h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(22px, 3vw, 38px);
  font-weight: 500;
  line-height: 1.9;
  letter-spacing: 0.12em;
  color: var(--c-black);
}
.nb-body { max-width: 680px; margin: 0 auto; }
.nb-body p { font-size: 15px; line-height: 2.4; margin-bottom: 28px; color: var(--c-text); letter-spacing: 0.06em; }

/* Issue list — 5 items */
.nb-issues {
  max-width: 920px;
  margin: 0 auto;
  border-top: 1px solid var(--c-line);
}
.nb-issue {
  padding: 36px 0;
  border-bottom: 1px solid var(--c-line);
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: clamp(20px, 3vw, 40px);
}
.nb-issue .num {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.28em;
  color: var(--c-sub);
}
.nb-issue h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(17px, 1.7vw, 20px);
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--c-black);
  margin-bottom: 14px;
  line-height: 1.7;
}
.nb-issue p { font-size: 14px; line-height: 2.2; letter-spacing: 0.06em; color: var(--c-text); }
@media (max-width: 700px) { .nb-issue { grid-template-columns: 1fr; gap: 12px; } }

/* TOC of articles — 3 cards */
.nb-toc {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 40px);
  max-width: 1200px;
  margin: 0 auto;
}
.nb-toc-card {
  background: var(--c-bg);
  border: 1px solid var(--c-line);
  padding: clamp(32px, 4vw, 48px);
  display: block;
  transition: transform .3s ease, border-color .3s ease;
}
.nb-toc-card:hover { transform: translateY(-2px); border-color: var(--c-black); }
.nb-toc-card .num {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.28em;
  color: var(--c-sub);
  margin-bottom: 18px;
  display: block;
}
.nb-toc-card h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(17px, 1.7vw, 20px);
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.08em;
  color: var(--c-black);
  margin-bottom: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--c-line);
}
.nb-toc-card p { font-size: 13px; line-height: 2; letter-spacing: 0.06em; color: var(--c-text); margin-bottom: 24px; }
.nb-toc-card .more {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--c-black);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.nb-toc-card .more::after { content: '→'; }
@media (max-width: 800px) { .nb-toc { grid-template-columns: 1fr; } }

/* Related services */
.nb-related {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 2.4vw, 32px);
  max-width: 1280px;
  margin: 0 auto;
}
.nb-related a {
  display: block;
  padding: 28px clamp(20px,3vw,32px);
  background: var(--c-bg-soft);
  border: 1px solid var(--c-line);
}
.nb-related a:hover { border-color: var(--c-black); }
.nb-related .label {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--c-sub);
  display: block;
  margin-bottom: 12px;
}
.nb-related h3 {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.7;
  color: var(--c-black);
}
@media (max-width: 800px) { .nb-related { grid-template-columns: repeat(2, 1fr); } }

/* CTA */
.nb-cta { background: var(--c-bg); padding: clamp(80px, 10vw, 120px) 0; text-align: center; }
.nb-cta h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(20px, 2.4vw, 30px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.1em;
  margin-bottom: 28px;
  color: var(--c-black);
}
.nb-cta p { font-size: 14px; line-height: 2.2; letter-spacing: 0.06em; color: var(--c-text); margin-bottom: 40px; max-width: 640px; margin-left: auto; margin-right: auto; }
.nb-cta .btn-row { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.nb-cta .btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 16px 36px;
  font-size: 13px;
  letter-spacing: 0.18em;
  border-radius: 999px;
}
.nb-cta .btn::after { content: '→'; font-size: 14px; }
.nb-cta .btn-primary { background: var(--c-black); color: #fff; }
.nb-cta .btn-ghost { background: transparent; color: var(--c-black); border: 1px solid var(--c-black); }

/* =========================================================
   11983 : /policy/
========================================================= */
.policy-list { display: flex; flex-direction: column; gap: 0; max-width: 920px; margin: 0 auto; border-top: 1px solid var(--c-line); }
.policy-item { display: grid; grid-template-columns: 100px 1fr; gap: 32px; padding: 40px 0; border-bottom: 1px solid var(--c-line); }
.policy-item .no { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.28em; color: var(--c-sub); }
.policy-item h3 { font-size: 18px; font-weight: 700; margin-bottom: 18px; color: var(--c-black); letter-spacing: 0.06em; line-height: 1.7; }
.policy-item p { font-size: 14px; line-height: 2.2; color: var(--c-text); letter-spacing: 0.06em; }
@media (max-width: 700px) { .policy-item { grid-template-columns: 1fr; gap: 12px; } }

.policy-intro {
  background: var(--c-bg);
  padding: clamp(80px, 10vw, 140px) 0;
}
.policy-intro h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(22px, 2.8vw, 34px);
  font-weight: 500;
  line-height: 1.95;
  letter-spacing: 0.1em;
  color: var(--c-black);
  margin-bottom: 40px;
  max-width: 880px;
}
.policy-intro p {
  font-size: 15px;
  line-height: 2.2;
  max-width: 760px;
  margin-bottom: 24px;
  letter-spacing: 0.06em;
}

/* =========================================================
   11988 : /recruit/
========================================================= */
.rc-mv .bg { background-image: url('/wp-content/themes/apricot-2026/assets/photos/recruit/recruit-mv.jpg'); }

/* =========================================================
   16682 : /requirements/
========================================================= */
.position { background: var(--c-bg-soft); border: 1px solid var(--c-line); padding: clamp(36px, 4vw, 60px); margin-bottom: clamp(28px, 3vw, 40px); }
.position .head { display: flex; flex-wrap: wrap; gap: 16px 24px; align-items: baseline; padding-bottom: 24px; border-bottom: 1px solid var(--c-line); margin-bottom: 32px; }
.position .num { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.24em; color: var(--c-sub); }
.position .en { font-family: var(--font-en); font-size: 13px; letter-spacing: 0.16em; color: var(--c-sub); }
.position h2 { font-size: clamp(20px, 2.4vw, 26px); font-weight: 500; color: var(--c-black); letter-spacing: 0.06em; line-height: 1.5; }
.position .type { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.18em; color: var(--c-black); border: 1px solid var(--c-line); padding: 5px 10px; background: #ffffff; margin-left: auto; }
.position table { width: 100%; }
.position table tr { display: grid; grid-template-columns: 180px 1fr; gap: 24px; padding: 18px 0; border-bottom: 1px dashed var(--c-line); }
.position table tr:last-child { border-bottom: none; }
.position table th { font-family: var(--font-en); font-size: 20px; letter-spacing: 0.18em; color: var(--c-sub); text-align: left; font-weight: 500; padding-top: 4px; }
.position table td { font-size: 14px; line-height: 2.1; color: var(--c-text); letter-spacing: 0.06em; }
.position table td ul { list-style: none; padding: 0; }
.position table td ul li { padding-left: 18px; position: relative; line-height: 2.1; }
.position table td ul li::before { content: '—'; position: absolute; left: 0; color: var(--c-sub); }
.position .apply { margin-top: 32px; text-align: right; }
.process { max-width: 880px; margin: 0 auto clamp(60px, 8vw, 100px); }
.process-step { display: grid; grid-template-columns: 80px 1fr; gap: clamp(20px, 3vw, 40px); padding: 24px 0; border-bottom: 1px solid var(--c-line); }
.process-step .num { font-family: var(--font-en); font-size: 13px; letter-spacing: 0.18em; color: var(--c-sub); padding-top: 4px; }
.process-step h4 { font-size: 16px; font-weight: 500; color: var(--c-black); margin-bottom: 8px; letter-spacing: 0.06em; }
.process-step p { font-size: 14px; line-height: 2; color: var(--c-text); letter-spacing: 0.04em; }
@media (max-width: 700px) {
  .position { border: 0; padding-left: 0; padding-right: 0; }
  .position table tr { grid-template-columns: 1fr; gap: 5px; padding: 40px 0; }
  .position .head { flex-direction: column; align-items: flex-start; }
  .position .type { margin-left: 0; }
  .position .apply { text-align: center; }
  .process-step { grid-template-columns: 1fr; gap: 4px; }
}

.req-anchor { background: #ffffff; padding: clamp(40px, 5vw, 60px) 0; }
.req-anchor-inner { max-width: 1200px; margin: 0 auto; padding: 0 var(--pad-x); }
.req-anchor-head { display: flex; align-items: center; gap: 14px; margin-bottom: clamp(20px, 2.4vw, 28px); }
.req-anchor-head .en { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.28em; color: var(--c-sub); }
.req-anchor-head .en::before { content: ''; display: inline-block; width: 24px; height: 1px; background: var(--c-sub); margin-right: 12px; vertical-align: middle; }
.req-anchor-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px; background: var(--c-line); border: 1px solid var(--c-line); }
.req-anchor-grid a { display: flex; flex-direction: column; gap: 8px; padding: clamp(20px, 2.2vw, 28px) clamp(16px, 1.8vw, 24px); background: var(--c-bg-soft); transition: background .25s ease; text-decoration: none; }
.req-anchor-grid a:hover { background: var(--c-bg); opacity: 1; }
.req-anchor-grid a .num { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.24em; color: var(--c-sub); }
.req-anchor-grid a .jp { font-size: 14px; font-weight: 500; color: var(--c-black); letter-spacing: 0.06em; }
.req-anchor-grid a .en { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.18em; color: var(--c-sub); }
@media (max-width: 1100px) { .req-anchor-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .req-anchor-grid { grid-template-columns: repeat(2, 1fr); } }

/* スクロール時のアンカー位置調整（rc-tabs 70px 分のオフセット） */
article.position { scroll-margin-top: 100px; }

/* 追従エントリーボタン（画面右下） */
.req-float-cta {
  position: fixed;
  right: clamp(16px, 2vw, 28px);
  bottom: clamp(16px, 2vw, 28px);
  z-index: 80;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 28px 16px 24px;
  background: var(--c-black);
  color: #fff;
  font-size: 13px;
  letter-spacing: 0.12em;
  font-weight: 500;
  border-radius: 999px;
  box-shadow: 0 10px 28px rgba(0,0,0,0.18);
  transition: transform .35s cubic-bezier(.2,.8,.2,1), opacity .35s ease;
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
}
.req-float-cta.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.req-float-cta::after {
  content: '';
  width: 24px;
  height: 1px;
  background: #fff;
  transition: width .3s ease;
}
.req-float-cta:hover::after { width: 36px; }
.req-float-cta:hover { color: #fff; opacity: 1; }
@media (max-width: 700px) {
  .req-float-cta { padding: 14px 22px 14px 18px; font-size: 12px; }
}

/* =========================================================
   16674 : /roadmap/
========================================================= */
/* Roadmap page hero */
.rm-mv {
  background: var(--c-bg);
  padding: clamp(140px, 16vw, 220px) 0 clamp(80px, 10vw, 140px);
  border-bottom: 1px solid var(--c-line);
}
.rm-mv .breadcrumb {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--c-sub);
  margin-bottom: 32px;
}
.rm-mv .breadcrumb a { color: var(--c-sub); }
.rm-mv .breadcrumb span { color: var(--c-line); }
.rm-mv .en-label {
  font-family: var(--font-en);
  font-size: clamp(13px, 1.4vw, 16px);
  letter-spacing: 0.32em;
  color: var(--c-sub);
  display: block;
  margin-bottom: 24px;
}
.rm-mv h1 {
  font-family: var(--font-serif-jp);
  font-size: clamp(28px, 4.4vw, 56px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.08em;
  color: var(--c-black);
  margin-bottom: 36px;
  max-width: 900px;
}
.rm-mv .lead {
  font-size: clamp(13px, 1.4vw, 16px);
  line-height: 2.2;
  letter-spacing: 0.06em;
  color: var(--c-text);
  max-width: 720px;
}

/* Roadmap section */
section.rm-sec {
  padding-top: clamp(120px, 14vw, 180px);
  padding-bottom: clamp(120px, 14vw, 180px);
}
.rm-sec.bg-soft { background: var(--c-bg-soft); }
.rm-sec.bg-base { background: var(--c-bg); }
.section-label {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.section-label::before { content: ''; width: 32px; height: 1px; background: var(--c-sub); }
.rm-head {
  max-width: 800px;
  margin: 0 auto clamp(64px, 8vw, 100px);
  text-align: center;
}
.rm-head h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(22px, 3vw, 38px);
  font-weight: 500;
  line-height: 1.9;
  letter-spacing: 0.12em;
  color: var(--c-black);
}
.rm-body { max-width: 720px; margin: 0 auto; }
.rm-body p { font-size: 15px; line-height: 2.4; margin-bottom: 28px; color: var(--c-text); letter-spacing: 0.06em; text-align: center; }

/* Phases — vertical timeline */
.phases {
  max-width: 1080px;
  margin: 0 auto;
  border-top: 1px solid var(--c-line);
}
.phase {
  display: grid;
  grid-template-columns: 140px 200px 1fr 220px;
  gap: clamp(20px, 3vw, 40px);
  padding: clamp(36px, 4vw, 56px) 0;
  border-bottom: 1px solid var(--c-line);
  align-items: start;
}
.phase .num {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.28em;
  color: var(--c-sub);
}
.phase .timing {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--c-black);
  font-weight: 500;
  line-height: 1.7;
}
.phase .body h3 {
  font-family: var(--font-serif-jp);
  font-size: clamp(17px, 1.7vw, 20px);
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--c-black);
  margin-bottom: 14px;
  line-height: 1.7;
}
.phase .body p { font-size: 14px; line-height: 2.2; letter-spacing: 0.06em; color: var(--c-text); }
.phase .related {
  font-size: 12px;
  line-height: 2;
  letter-spacing: 0.06em;
  color: var(--c-sub);
}
.phase .related .lab {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--c-sub);
  display: block;
  margin-bottom: 10px;
}
.phase .related a { color: var(--c-black); border-bottom: 1px solid var(--c-line); display: inline-block; margin-right: 8px; }
.phase .related a:hover { border-bottom-color: var(--c-black); }
@media (max-width: 1000px) {
  .phase { grid-template-columns: 1fr; gap: 12px; }
  .phase .num, .phase .timing { display: inline-block; margin-right: 16px; }
}

/* Checklist */
.checklist {
  max-width: 880px;
  margin: 0 auto;
  list-style: none;
  padding: 0;
  border-top: 1px solid var(--c-line);
}
.checklist li {
  padding: 22px 0 22px 36px;
  border-bottom: 1px solid var(--c-line);
  position: relative;
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.06em;
  color: var(--c-text);
}
.checklist li::before {
  content: '';
  position: absolute;
  left: 0; top: 1.6em;
  width: 16px; height: 16px;
  border: 1px solid var(--c-line);
}
.checklist .note {
  margin-top: 36px;
  font-size: 13px;
  color: var(--c-sub);
  line-height: 2;
  text-align: center;
}

/* Examples */
.examples {
  max-width: 920px;
  margin: 0 auto;
  border-top: 1px solid var(--c-line);
}
.example {
  padding: 28px 0;
  border-bottom: 1px solid var(--c-line);
  display: grid;
  grid-template-columns: 200px 1fr 120px;
  gap: 24px;
  align-items: center;
}
.example .industry {
  font-family: var(--font-serif-jp);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--c-black);
}
.example .desc { font-size: 14px; line-height: 1.9; letter-spacing: 0.06em; color: var(--c-text); }
.example .phase-tag {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--c-sub);
  text-align: right;
}
@media (max-width: 800px) {
  .example { grid-template-columns: 1fr; }
  .example .phase-tag { text-align: left; }
}

/* Benefits — 5 simple list */
.benefits {
  max-width: 760px;
  margin: 0 auto;
  list-style: none;
  padding: 0;
  border-top: 1px solid var(--c-line);
}
.benefits li {
  padding: 24px 0 24px 24px;
  border-bottom: 1px solid var(--c-line);
  position: relative;
  font-size: 15px;
  line-height: 2;
  letter-spacing: 0.06em;
  color: var(--c-text);
}
.benefits li::before {
  content: '';
  position: absolute;
  left: 0; top: 1.5em;
  width: 8px; height: 1px;
  background: var(--c-sub);
}

/* Roadmap CTA */
.rm-cta {
  background: var(--c-bg);
  padding: clamp(80px, 10vw, 120px) 0;
  text-align: center;
}
.rm-cta h2 {
  font-family: var(--font-serif-jp);
  font-size: clamp(20px, 2.4vw, 30px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.1em;
  margin-bottom: 28px;
  color: var(--c-black);
}
.rm-cta p { font-size: 14px; line-height: 2.2; letter-spacing: 0.06em; color: var(--c-text); margin-bottom: 40px; max-width: 640px; margin-left: auto; margin-right: auto; }
.rm-cta .btn-row { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.rm-cta .btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 16px 36px;
  font-size: 13px;
  letter-spacing: 0.18em;
  border-radius: 999px;
}
.rm-cta .btn::after { content: '→'; font-size: 14px; }
.rm-cta .btn-primary { background: var(--c-black); color: #fff; }
.rm-cta .btn-ghost { background: transparent; color: var(--c-black); border: 1px solid var(--c-black); }

/* =========================================================
   11996 : /service/
========================================================= */
.sv-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--c-line); border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
.sv-card { background: var(--c-bg); padding: clamp(32px, 4vw, 56px) clamp(28px, 3vw, 48px); display: flex; flex-direction: column; gap: 16px; transition: background .3s ease; }
.sv-card:hover { background: var(--c-bg-soft); }
.sv-card .num { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.24em; color: var(--c-sub); }
.sv-card h3 { font-size: 18px; font-weight: 500; color: var(--c-black); letter-spacing: 0.04em; }
.sv-card p { font-size: 14px; line-height: 2; color: var(--c-text); flex-grow: 1; }
.sv-card .more { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.18em; color: var(--c-black); margin-top: auto; display: inline-flex; align-items: center; gap: 12px; }
.sv-card .more::after { content: ''; width: 24px; height: 1px; background: var(--c-black); transition: width .3s ease; }
.sv-card:hover .more::after { width: 36px; }
@media (max-width: 700px) { .sv-cards { grid-template-columns: 1fr; } }
.sv-pricing-link { display: flex; flex-direction: column; align-items: center; gap: 18px; padding: clamp(48px, 6vw, 80px) clamp(24px, 3vw, 48px); background: var(--c-bg-soft); border: 1px solid var(--c-line); margin-top: clamp(48px, 6vw, 80px); }
.sv-pricing-link h3 { font-size: clamp(16px, 1.4vw, 20px); font-weight: 500; letter-spacing: 0.06em; color: var(--c-black); margin: 0; }
.sv-pricing-link p { font-size: 14px; line-height: 2; color: var(--c-text); max-width: 620px; text-align: center; margin: 0; }
.sv-pricing-link .btn { margin-top: 8px; }

/* =========================================================
   16683 : /work/
========================================================= */
/* #1780 padding 上下 0 / border-bottom 撤去 */
.rc-jobnav { display: flex; flex-wrap: wrap; gap: 12px 16px; justify-content: center; padding: 0 clamp(16px, 4vw, 32px); border-bottom: 0; background: #ffffff; }
@media (max-width: 600px) {
  .rc-jobnav { border-bottom: 0; gap: 8px; max-width: var(--container); margin: 0 auto; padding: 0 var(--pad-x) 0; justify-content: flex-start; }
  .rc-jobnav a { padding: 10px 18px; font-size: 12px; }
  .rc-page .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--pad-x) 0; }
}
.rc-jobnav a {
  font-size: 13px;
  letter-spacing: 0.08em;
  color: var(--c-black);
  padding: 12px 26px;
  border: 1px solid var(--c-line);
  border-radius: 999px;
  background: #ffffff;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.rc-jobnav a:hover { background: var(--c-black); color: #ffffff; border-color: var(--c-black); }

.rc-job { padding: clamp(80px, 10vw, 140px) 0 0; }
.rc-job:nth-child(odd) { background: #ffffff; }
.rc-job:nth-child(even) { background: #ffffff; }
.rc-job-inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 100px); align-items: flex-start; }
.rc-job-inner.alt { direction: rtl; }
.rc-job-inner.alt > * { direction: ltr; }
.rc-job-img { aspect-ratio: 4 / 5; overflow: hidden; background: var(--c-bg); }
.rc-job-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s cubic-bezier(.2,.8,.2,1); }
.rc-job:hover .rc-job-img img { transform: scale(1.04); }
.rc-job-body .num { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.32em; color: var(--c-sub); margin-bottom: 24px; display: inline-flex; align-items: center; gap: 14px; }
.rc-job-body .num::after { content: ''; width: 32px; height: 1px; background: var(--c-sub); }
.rc-job-body .en { font-family: var(--font-serif-en); font-style: italic; font-size: clamp(22px, 2.4vw, 30px); color: var(--c-sub); display: block; margin-bottom: 8px; }
.rc-job-body h2 { font-family: var(--font-serif-jp); font-size: clamp(22px, 2.6vw, 32px); font-weight: 500; line-height: 1.7; letter-spacing: 0.08em; color: var(--c-black); margin-bottom: 28px; padding-bottom: 28px; border-bottom: 1px solid var(--c-line); }
.rc-job-body .block { margin-bottom: 28px; }
.rc-job-body .block-label { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.24em; color: var(--c-sub); margin-bottom: 12px; display: block; }
.rc-job-body .block p { font-size: 14px; line-height: 2.2; letter-spacing: 0.06em; color: var(--c-text); }
.rc-job-body .career { background: #ffffff; padding: 24px 28px; margin-top: 24px; border-left: 2px solid var(--c-black); }
.rc-job-body .career .career-title { font-family: var(--font-en); font-size: 12px; letter-spacing: 0.24em; color: var(--c-black); margin-bottom: 12px; display: block; }
.rc-job-body .career p { font-size: 13px; line-height: 2.1; color: var(--c-text); letter-spacing: 0.04em; margin-bottom: 12px; }
.rc-job-body .career p:last-child { margin-bottom: 0; }
.rc-job-body .apply { margin-top: 32px; }
@media (max-width: 800px) { .rc-job-inner, .rc-job-inner.alt { grid-template-columns: 1fr; direction: ltr; } .rc-job-img { aspect-ratio: 16 / 9; } }

/* ============================================
   /about-branding/ — わたぼうがブランディングを解説するページ
============================================ */
.ab-mv {
  background: #faf7f3;
  position: relative;
  overflow: hidden;
}
.ab-mv-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
  min-height: 60vh;
}
.ab-mv-text { min-width: 0; }
.ab-mv-watabo { min-width: 0; }
.ab-mv-text { padding: clamp(40px, 5vw, 80px) 0; }
.ab-mv-en {
  display: inline-block;
  font-family: var(--font-en);
  font-size: 13px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: clamp(24px, 3vw, 36px);
}
.ab-mv h1 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 46px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: var(--c-black);
  margin-bottom: clamp(28px, 3vw, 40px);
}
.ab-mv-lead {
  font-size: clamp(15px, 1.4vw, 17px);
  line-height: 2.2;
  color: var(--c-text);
  letter-spacing: 0.04em;
  max-width: 540px;
}
.ab-mv-watabo {
  margin: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.ab-mv-watabo img {
  width: 100%;
  max-width: 380px;
  height: auto;
  animation: ab-watabo-float 6s ease-in-out infinite;
}
@keyframes ab-watabo-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}
@media (max-width: 900px) {
  .ab-mv-grid { grid-template-columns: 1fr; gap: 32px; min-height: auto; }
  .ab-mv-watabo { order: -1; }
  .ab-mv-watabo img { max-width: 220px; }
}

/* 共通ナロー */
.ab-narrow { max-width: 1100px; margin-left: auto; margin-right: auto; }

/* STEP セクション */
.ab-step { background: #ffffff; }
.ab-step + .ab-step { padding-top: 0 !important; }
.ab-step-head {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: baseline;
  gap: clamp(12px, 2vw, 24px);
  margin-bottom: clamp(28px, 3vw, 44px);
  padding-bottom: clamp(20px, 2.4vw, 32px);
  border-bottom: 1px solid var(--c-line);
}
.ab-step-num {
  font-family: var(--font-en);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(48px, 6vw, 80px);
  line-height: 1;
  color: rgba(0, 0, 0, 0.12);
}
.ab-step-en {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--c-sub);
  text-transform: uppercase;
}
.ab-step-head h2 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--c-black);
  line-height: 1.6;
  grid-column: 1 / -1;
  margin-top: 8px;
}
.ab-step-talk { font-size: clamp(15px, 1.2vw, 16px); line-height: 2.2; letter-spacing: 0.04em; color: var(--c-text); }
.ab-step-talk p { margin-bottom: 24px; }
.ab-step-talk p:last-child { margin-bottom: 0; }
.ab-step-talk strong { font-weight: 500; color: var(--c-black); border-bottom: 1px dashed rgba(0,0,0,0.3); padding-bottom: 1px; }
/* ブランド体験タッチポイント — わたげ印つきの白「吹き出し」を wrap で並べる */
.ab-list {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(14px, 1.6vw, 22px) clamp(10px, 1.2vw, 14px);
  padding: 16px 0 28px;
  margin: 32px 0;
}
.ab-list li {
  position: relative;
  background: #ffffff;
  border-radius: 18px;
  padding: 14px 24px 14px 44px;
  /* tail も含めて影をかけたいので filter で drop-shadow */
  filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.14)) drop-shadow(0 1px 3px rgba(0, 0, 0, 0.06));
  font-size: 14px;
  line-height: 1.6;
  color: var(--c-black);
  letter-spacing: 0.04em;
}
/* 左側の小さなわたげアイコン */
.ab-list li::before {
  content: '';
  position: absolute;
  left: 14px; top: 50%;
  transform: translateY(-50%);
  width: 20px; height: 20px;
  background: center/contain no-repeat
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40' fill='none' stroke='%235db38e' stroke-width='1.4' stroke-linecap='round'><line x1='20' y1='6' x2='20' y2='22'/><line x1='8' y1='14' x2='20' y2='22'/><line x1='32' y1='14' x2='20' y2='22'/><line x1='13' y1='7' x2='20' y2='22'/><line x1='27' y1='7' x2='20' y2='22'/><circle cx='20' cy='22' r='1.8' fill='%235db38e' stroke='none'/></svg>");
}
/* 吹き出しの「しっぽ」 — 左下から下向きの小さな三角 */
.ab-list li::after {
  content: '';
  position: absolute;
  left: 28px; bottom: -10px;
  width: 0; height: 0;
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
  border-top: 12px solid #ffffff;
}
/* しっぽの位置を交互にずらして自然な配置に */
.ab-list li:nth-child(even)::after { left: auto; right: 32px; }
.ab-list li:nth-child(3n)::after  { left: 50%; transform: translateX(-50%); }

/* CALLOUT */
.ab-callout {
  background: #2a2a2a;
  color: #e8e8e8;
  text-align: center;
}
.ab-callout-inner { max-width: 1100px; margin: 0 auto; padding: 0 clamp(20px, 4vw, 40px); }
.ab-callout-en {
  display: block;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: clamp(20px, 2vw, 28px);
}
.ab-callout h2 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 2.8vw, 32px);
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.06em;
  color: #fff;
  margin-bottom: clamp(28px, 3.5vw, 44px);
}
.ab-callout p {
  font-size: clamp(14px, 1.1vw, 15px);
  line-height: 2.2;
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.78);
  max-width: 720px;
  margin: 0 auto 22px;
}
.ab-callout p:last-child { margin-bottom: 0; }

/* WORKS */
.ab-works { background: #ffffff; }
.ab-works-head { text-align: center; margin-bottom: clamp(48px, 5vw, 72px); }
.ab-works-en {
  display: inline-block;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 16px;
}
.ab-works-head h2 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.6;
  color: var(--c-black);
}
.ab-work {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: clamp(28px, 4vw, 56px);
  padding: clamp(36px, 4vw, 56px) 0;
  border-top: 1px solid var(--c-line);
  align-items: start;
  max-width: 1040px;
  margin: 0 auto;
}
.ab-work:last-child { border-bottom: 1px solid var(--c-line); }
.ab-work-num {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ab-work-num span {
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.28em;
  color: var(--c-sub);
}
.ab-work-num strong {
  font-family: var(--font-en);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(56px, 6vw, 88px);
  line-height: 1;
  color: var(--c-black);
}
.ab-work-body h3 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.6;
  color: var(--c-black);
  margin-bottom: 24px;
}
.ab-work-body p {
  font-size: 15px;
  line-height: 2.2;
  letter-spacing: 0.04em;
  color: var(--c-text);
  margin-bottom: 18px;
}
.ab-work-body p:last-child { margin-bottom: 0; }
.ab-work-body strong { font-weight: 500; color: var(--c-black); }
@media (max-width: 800px) {
  .ab-work { grid-template-columns: 1fr; gap: 16px; }
  .ab-work-num { flex-direction: row; align-items: baseline; gap: 14px; }
  .ab-work-num strong { font-size: 48px; }
}

/* OUTCOMES */
.ab-outcomes { background: #faf7f3; }
.ab-outcomes-head { text-align: center; margin-bottom: clamp(40px, 4vw, 56px); }
.ab-outcomes-en {
  display: inline-block;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 16px;
}
.ab-outcomes-head h2 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.6;
  color: var(--c-black);
  margin-bottom: 24px;
}
.ab-outcomes-head p {
  font-size: 14px;
  line-height: 2.1;
  color: var(--c-text);
  max-width: 560px;
  margin: 0 auto;
}
.ab-outcomes-list {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 1.6vw, 24px);
}
.ab-outcomes-list li {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #ffffff;
  border-radius: 14px;
  padding: clamp(46px, 3.6vw, 58px) clamp(18px, 1.8vw, 24px);
  font-size: 14px;
  line-height: 1.9;
  text-wrap: balance;
  color: var(--c-text);
  box-shadow: 0 12px 30px -18px rgba(0, 0, 0, 0.16);
}
.ab-outcomes-list li::before,
.ab-outcomes-list li::after {
  position: absolute;
  font-family: var(--font-en), Georgia, serif;
  font-size: clamp(46px, 4.6vw, 62px);
  font-weight: 700;
  line-height: 1;
  color: #5db38e;
  opacity: 0.5;
}
.ab-outcomes-list li::before {
  content: '“';
  top: clamp(10px, 1.2vw, 16px);
  left: clamp(12px, 1.4vw, 20px);
}
.ab-outcomes-list li::after {
  content: '”';
  bottom: clamp(-10px, 0vw, -2px);
  right: clamp(12px, 1.4vw, 20px);
}
.ab-outcomes-list .ab-oc-key {
  display: inline-block;
  white-space: nowrap;
  font-weight: 600;
  color: var(--c-black);
  border-bottom: 2px dotted #5db38e;
  padding-bottom: 3px;
}
.ab-outcomes-foot {
  text-align: center;
  font-size: 14px;
  line-height: 2.1;
  color: var(--c-text);
  margin-top: clamp(32px, 3vw, 48px);
}
@media (max-width: 900px) {
  .ab-outcomes-list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .ab-outcomes-list { grid-template-columns: 1fr; gap: 14px; }
}

/* WATABO BOTTOM CTA */
.ab-watabo-cta {
  background: #faf7f3;
  position: relative;
  overflow: hidden;
}
.ab-watabo-cta-inner {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: clamp(32px, 5vw, 72px);
  max-width: 980px;
  margin: 0 auto;
}
.ab-watabo-cta-img { margin: 0; flex-shrink: 0; }
.ab-watabo-cta-img img {
  width: clamp(160px, 18vw, 240px);
  height: auto;
  animation: ab-watabo-float 6s ease-in-out infinite;
}
.ab-watabo-cta-en {
  display: block;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.32em;
  color: var(--c-sub);
  margin-bottom: 18px;
}
.ab-watabo-cta-text h2 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.06em;
  color: var(--c-black);
  margin-bottom: 24px;
}
.ab-watabo-cta-text p {
  font-size: 14px;
  line-height: 2.1;
  color: var(--c-text);
  margin-bottom: 32px;
}
.ab-watabo-cta-actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
@media (max-width: 700px) {
  .ab-watabo-cta-inner { grid-template-columns: 1fr; text-align: center; }
  .ab-watabo-cta-img { display: flex; justify-content: center; }
  .ab-watabo-cta-actions { justify-content: center; }
}

/* ABOUT セクションの CTA ボタン位置調整 */
.sd-about-cta {
  text-align: center !important;
  margin-top: clamp(96px, 10vw, 160px) !important;
  padding-top: 60px !important;
  display: block !important;
}

/* ============================================
   /about-branding/ — スクロール追従わたぼう + ひらひらわたげ
============================================ */
body.page-id-18270 { position: relative; }

/* スクロールでついてくる「歩くわたぼう」
   右下のチャットウィジェット（わたぼうチャット）と被らないよう上に配置 */
.ab-walker {
  position: fixed;
  right: clamp(20px, 3vw, 40px);
  bottom: clamp(120px, 14vh, 180px);
  width: clamp(80px, 10vw, 130px);
  z-index: 80;
  pointer-events: none;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s ease, transform .6s ease;
}
.ab-walker.is-visible { opacity: 1; transform: translateY(0); }
.ab-walker .ab-walker-inner {
  display: block;
  transform-origin: 50% 90%;
  animation: ab-walker-step 1.2s ease-in-out infinite;
}
/* バイバイアニメ（CTA セクションに到達したとき） */
.ab-walker.is-bye .ab-walker-inner {
  animation: ab-walker-bye 1.4s ease-in-out forwards;
}
.ab-walker.is-bye {
  opacity: 1 !important;
  transform: translateY(0) !important;
  transition: opacity .6s ease .9s, transform .6s ease .9s;
}
@keyframes ab-walker-bye {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  15%      { transform: translateY(-10px) rotate(-12deg); }
  30%      { transform: translateY(-2px) rotate(8deg); }
  45%      { transform: translateY(-10px) rotate(-12deg); }
  60%      { transform: translateY(-2px) rotate(8deg); }
  80%      { transform: translateY(-6px) rotate(-6deg); }
}
.ab-walker .ab-walker-inner img { width: 100%; height: auto; display: block; }
@keyframes ab-walker-step {
  0%, 100% { transform: translateY(0) rotate(-4deg); }
  25%      { transform: translateY(-6px) rotate(0deg); }
  50%      { transform: translateY(0) rotate(4deg); }
  75%      { transform: translateY(-6px) rotate(0deg); }
}

@media (prefers-reduced-motion: reduce) {
  .ab-walker .ab-walker-inner { animation: none; }
}
@media (max-width: 700px) {
  .ab-walker { width: 64px; right: 12px; bottom: 100px; }
}

/* ============================================================
   /policy/ — page post 11983 のインライン style から移植
============================================================ */
section.policy-list-section { background: var(--c-bg-soft); padding-top: 0 !important; }
section.policy-cta-section { background: transparent; padding-top: 0 !important; }
.policy-cta-section .container-narrow { text-align: center; }
.policy-cta-text {
  font-family: var(--font-serif-jp);
  font-size: clamp(20px, 2.4vw, 28px);
  line-height: 2;
  letter-spacing: 0.1em;
  color: var(--c-black);
  margin-bottom: 48px;
}

/* ============================================================
   2026-06-13 / recruit 子ページ 大量コメント反映 #1731-#1762
============================================================ */

/* page-hero h1 削除（entry / environment / faq / people / requirements / work） */
body.page-id-16677 .post-hero h1,
body.page-id-16678 .post-hero h1,
body.page-id-16679 .post-hero h1,
body.page-id-16681 .post-hero h1,
body.page-id-16682 .post-hero h1,
body.page-id-16683 .post-hero h1 { display: none; }

/* インタビュー一覧 (#1734) */
body.page-id-16681 .iv-list .iv-list-title { font-weight: 700; }

/* インタビュー詳細 (#1736-#1739) */
body.single-interview .iv-title { font-weight: 700; }
body.single-interview .iv-prose .iv-h2 { font-weight: 700; }
body.single-interview .iv-others-grid .iv-thumb-title { font-weight: 700; }

/* #1737 iv-body 上 padding 0 (single-interview) */
body.single-interview .iv-body { padding-top: 0; }

/* #1735 SP: インタビュー詳細 sidebar nav を 1行横スクロール */
@media (max-width: 1000px) {
  body.single-interview .rc-sidebar-nav {
    display: flex !important;
    flex-direction: row;
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: none;
    gap: 16px;
  }
  body.single-interview .rc-sidebar-nav::-webkit-scrollbar { display: none; }
  body.single-interview .rc-sidebar-nav li { flex: 0 0 auto; }
  body.single-interview .rc-sidebar-nav .en { display: inline; }
}

/* /recruit/environment/ */
body.page-id-16678 .env-stance .body h2 { font-weight: 700; }  /* #1747 */
/* #1782-#1784 env-stance h2 下線(border-width)を撤去 */
body.page-id-16678 .env-stance .body h2 { border-bottom: 0; }
@media (max-width: 700px) {
  /* #1746: 1枚目 env-stance の上 padding を 0 に */
  body.page-id-16678 .env-stance:first-of-type { padding-top: 0 !important; }
  /* #1796 SP: env-stance h2 の下 padding 28→0 */
  body.page-id-16678 .env-stance .body h2 { padding-bottom: 0; }
}
/* #1748: 3列目 h4 を 18px / 700 (.benefits-grid 等) */
body.page-id-16678 .benefits-grid .b-card h4,
body.page-id-16678 .env-benefits h4 {
  font-size: 18px;
  font-weight: 700;
}

/* /recruit/faq/ #1750-#1753 */
body.page-id-16679 .faq-item .q {
  margin-bottom: 0;    /* #1750 */
  font-weight: 700;    /* #1752 */
}
body.page-id-16679 .faq-cat { font-size: 14px; }  /* #1753 */
/* #1786 先頭 faq-item の padding を 0 に（カテゴリ見出し直下に詰める） */
body.page-id-16679 .faq-list .faq-item:first-of-type { padding: 0; }
@media (max-width: 700px) {
  body.page-id-16679 .faq-item { padding: 20px 0; }  /* #1751 */
}

/* /recruit/requirements/ #1755-#1758 */
body.page-id-16682 .req-anchor-head .en { font-size: 16px; }  /* #1755 */
/* #1757: 各 job セクションの h2（.rc-job-body 内 / 外の素の article h2 両方カバー） */
body.page-id-16682 main h2,
body.page-id-16682 .rc-job-body h2 { font-weight: 700; }
/* #1758: job-table th を太く + 文字色 #333 に */
body.page-id-16682 table th {
  font-weight: 700;
  color: var(--c-black);
}
/* #1797 padding-bottom 24→0 / #1798 margin-bottom 32→0（.position .head） */
body.page-id-16682 .position .head { padding-bottom: 0; margin-bottom: 0; }

/* /recruit/message/ #1790 message-body h2 の下 padding 36→0 */
body.page-id-16680 .message-body h2 { padding-bottom: 0; }

/* /recruit/work/ #1742-#1744 */
body.page-id-16683 .rc-job-body .en { font-size: 18px; }       /* #1742 */
body.page-id-16683 .rc-job-body h2 { font-weight: 700; }       /* #1743 */
body.page-id-16683 .rc-job-body .block-label { font-size: 14px; }  /* #1744 */

/* /recruit/entry/ SP #1760-#1762 */
@media (max-width: 700px) {
  body.page-id-16677 .wpcf7-form .cf7-field label,
  body.page-id-16677 .wpcf7-form > div > label {
    font-size: 18px;     /* #1760 */
  }
  body.page-id-16677 .wpcf7-form {
    gap: 35px;            /* #1761 */
  }
  /* #1762: 10番目の field label の gap 拡大 + padding-bottom 削除 */
  body.page-id-16677 .wpcf7-form > div:nth-of-type(10) > label {
    gap: 15px;
    padding-bottom: 0;
  }
}

/* SP おしゃれセレクトボックス（#1756 requirements / #1740 work）
   JS で grid 上に <select.rc-job-select> を挿入し、SP では grid を非表示 */
.rc-job-select { display: none; }
@media (max-width: 700px) {
  body.page-id-16682 .req-anchor-grid { display: none; }
  body.page-id-16683 .rc-job-nav-grid,
  body.page-id-16683 article > nav { display: none; }
  .rc-job-select {
    display: block;
    width: 100%;
    margin: 0 0 32px;
    padding: 18px 48px 18px 22px;
    border: 1px solid var(--c-line);
    background-color: #ffffff;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'><path d='M1 1l5 5 5-5' stroke='%23333' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/></svg>");
    background-repeat: no-repeat;
    background-position: right 20px center;
    background-size: 14px;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.06em;
    color: var(--c-black);
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border-radius: 0;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04);
  }
  .rc-job-select:focus { outline: 1px solid var(--c-black); outline-offset: -1px; }
  /* #1794 work: select の両サイドに余白（コンテンツのガターに揃える） */
  body.page-id-16683 .rc-job-select { width: auto; margin-left: var(--pad-x); margin-right: var(--pad-x); }
  /* #1795 work: article.rc-article の背景を白に */
  body.page-id-16683 .rc-article { background-color: #ffffff; }
}

/* 2026-06-26 websupport #3593 — policy SP */
@media (max-width: 900px) {
  section.policy-list-section { padding-bottom: 100px; }                                /* #3593 下80->100 */
}

/* 2026-06-27 websupport #3612-#3613 — /recruit/message/（16680）SP */
@media (max-width: 900px) {
  .message-body p { font-size: 14px; line-height: 28px; }                                /* #3612 15->14/lh28 */
  body.page-id-16680 .message-body .sign { margin-top: 20px; }                            /* #3613 40->20 */
}

/* 2026-06-27 websupport #3624-#3632 — /recruit/environment/(16678) /recruit/work/(16683) SP */
@media (max-width: 900px) {
  .env-stance .body p { font-size: 14px; line-height: 28px; }                          /* #3630 15->14/lh28 */
  .env-stance .tv-mark span { font-size: 14px; line-height: 28px; }                    /* #3631 12->14/lh28 */
  .rc-editorial-head .label { margin-bottom: 20px; }                                   /* #3632 24->20 */
  .rc-job-body .block-label { font-size: 16px; font-weight: 700; }                     /* #3624 14->16/700 全ページ */
  body.page-id-16683 .rc-job-body .block-label { font-size: 16px; font-weight: 700; }  /* #3624 既存#1744(14px)を上書き */
  .rc-job-body .career .career-title { font-size: 16px; }                              /* #3626 12->16 */
  body.page-id-16683 #nailist > .container { margin-bottom: 100px; }                   /* #3627 下margin->100（この要素のみ） */
  body.page-id-16683 section.rc-band .rc-feature-text { margin-top: 40px; }            /* #3628 上0->40（この要素のみ） */
  body.page-id-16683 section.rc-band { padding-bottom: 100px; }                        /* #3629 下80->100（この要素のみ） */
  body.page-id-16683 main > article > select { width: 100%; }                          /* #3625 全幅 */
}

/* 2026-06-27 websupport #3633-#3642 — environment(16678)/faq(16679)/requirements(16682) SP */
@media (max-width: 900px) {
  body.page-id-16678 section.rc-band-soft { padding-bottom: 100px; }                                  /* #3633 */
  .faq-list { gap: 40px; }                                                                            /* #3634 10->40 全ページ */
  body.page-id-16679 section.rc-band .rc-feature-text--small { font-size: 16px; line-height: 30px; }  /* #3635 18->16/lh30 */
  body.page-id-16679 section.rc-band { padding-bottom: 100px; }                                       /* #3636 */
  .position .head { border-bottom-width: 0; }                                                         /* #3637 下border削除 全ページ */
  .position table th { font-size: 18px; }                                                             /* #3638 20->18 全ページ */
  .position { margin-bottom: 60px; padding-bottom: 0; }                                               /* #3639 mb->60 / pb->0 */
  .position .apply { margin-top: 0; }                                                                 /* #3640 32->0 */
  body.page-id-16682 section.rc-band { padding-bottom: 0; }                                           /* #3641 */
  /* #3642 span.label(SELECTION FLOW) は既存 .rc-editorial-head .label{mb:20} で対応済み */
}

/* 2026-06-27 websupport #3643/#3645 — /recruit/entry/（16677）SP */
@media (max-width: 900px) {
  body.page-id-16677 #form > .container-narrow { padding-left: 40px; padding-right: 40px; }   /* #3643 L/R20->40 */
  body.page-id-16677 section.rc-band-sm { padding-bottom: 100px; }                            /* #3645 下48->100 */
}

/* 2026-06-27 websupport #3656/#3657 — /recruit/message/（16680）SP */
@media (max-width: 900px) {
  body.page-id-16680 .message-body h2 { font-size: 20px; line-height: 38px; letter-spacing: 1px; }   /* #3656 22->20/lh38/ls1 */
  body.page-id-16680 section.rc-band-soft > .container { padding-bottom: 100px; }                     /* #3657 下0->100 */
}

/* #4317 資料DLフォーム: container-narrow に下余白150px（#dl-form のみ・PC/SP） */
#dl-form > .container-narrow { margin-bottom: 150px; }
