.ab-hero h1 { font-size: clamp(40px, 6.5vw, 96px); line-height: 1.3; }
.ab-hero .sub { margin-top: 48px; display: flex; gap: 32px; flex-wrap: wrap; color: var(--stone); font-family: "Inter", sans-serif; font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; }
.ab-hero .sub span { position: relative; padding-left: 18px; }
.ab-hero .sub span::before { content: ""; position: absolute; left: 0; top: 50%; width: 10px; height: 1px; background: var(--orange); }

/* MVV blocks */
.mvv { padding: 120px 48px; max-width: 1320px; margin: 0 auto; border-top: 1px solid var(--mist); }
.mvv-row { display: grid; grid-template-columns: 220px 1fr; gap: 80px; align-items: start; }
.mvv-row .lbl { position: sticky; top: 120px; }
.mvv-row .lbl .mono { color: var(--orange); display: block; margin-bottom: 8px; }
.mvv-row .lbl .tate { font-family: "Noto Serif JP", serif; font-size: 14px; color: var(--stone); letter-spacing: 0.3em; margin-top: 24px; }
.mvv-row h2 { font-size: clamp(30px, 4.4vw, 56px); line-height: 1.4; margin-bottom: 40px; }
.mvv-row p { font-size: 16px; line-height: 2.1; color: #2f2f33; max-width: 720px; }
.mvv-row .big-en { font-family: "Cormorant Garamond", serif; font-style: italic; color: var(--mist); font-size: 110px; line-height: 0.9; margin-bottom: 24px; letter-spacing: -0.02em;; }
@media (max-width: 900px) {
  .mvv { padding: 80px 24px; }
  .mvv-row { grid-template-columns: 1fr; gap: 32px; }
  .mvv-row .lbl { position: static; }
  .mvv-row .lbl .tate { display: none; }
}

/* Vision 2036 — poster style */
.v2036 {
  padding: 160px 48px;
  background: var(--forest); color: var(--off);
  position: relative; overflow: hidden;
}
.v2036-wrap { max-width: 1320px; margin: 0 auto; }
.v2036 .mono { color: #c5d3c9; letter-spacing: 0.3em; }
.v2036 h2 { font-family: "Noto Serif JP", serif; font-weight: 500; font-size: clamp(34px, 5.4vw, 72px); line-height: 1.4; margin: 28px 0 40px; max-width: 1000px; }
.v2036 .kpi { display: flex; gap: 80px; flex-wrap: wrap; align-items: baseline; margin-top: 64px; border-top: 1px solid rgba(246,244,238,.15); padding-top: 40px; }
.v2036 .kpi .item .n { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: clamp(64px, 9vw, 140px); line-height: 1; color: var(--orange); }
.v2036 .kpi .item .lbl { color: #c5d3c9; font-size: 13px; font-family: "Inter", sans-serif; letter-spacing: 0.14em; }
.v2036 .kpi .item .cap { margin-top: 10px; font-family: "Noto Serif JP", serif; font-size: 14px; color: var(--off); }
.v2036-orange { position: absolute; top: 60px; right: 48px; font-family: "Cormorant Garamond", serif; font-style: italic; font-size: clamp(80px, 14vw, 220px); color: rgba(232,100,58,.2); line-height: 0.9; pointer-events: none; user-select: none; }
@media (max-width: 900px) { .v2036 { padding: 80px 24px; } .v2036-orange { top: 24px; right: 16px; } }

/* Vision 2036 — Floating Marquee */
.v2036-mq { background: var(--ink); color: var(--off); padding: 120px 0 140px; overflow: hidden; position: relative; }
.v2036-mq-head { max-width: 1320px; margin: 0 auto 72px; padding: 0 48px; }
.v2036-mq-head .mono { color: var(--orange); }
.v2036-mq-head h3 { font-family: "Noto Sans JP", sans-serif; font-weight: 900; font-size: clamp(32px, 4.6vw, 64px); line-height: 1.3; margin-top: 20px; color: var(--off); letter-spacing: 0.02em; }
.v2036-mq-track { overflow: hidden; margin-bottom: 28px; mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.v2036-mq-inner { display: flex; gap: 24px; width: max-content; animation: mqL 60s linear infinite; }
.v2036-mq-r .v2036-mq-inner { animation: mqR 72s linear infinite; }
.v2036-mq .chip {
  display: inline-flex; align-items: baseline; gap: 16px;
  padding: 20px 32px; border: 1px solid rgba(246,244,238,.22);
  white-space: nowrap; flex-shrink: 0;
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.v2036-mq .chip:hover { background: var(--orange); border-color: var(--orange); }
.v2036-mq .chip .k { font-family: "Noto Sans JP", sans-serif; font-weight: 900; font-size: 20px; letter-spacing: 0.04em; color: var(--orange); }
.v2036-mq .chip.alt .k { color: var(--off); }
.v2036-mq .chip:hover .k { color: var(--ink); }
.v2036-mq .chip .v { font-family: "Noto Sans JP", sans-serif; font-weight: 500; font-size: 14px; color: rgba(246,244,238,.7); letter-spacing: 0.02em; }
.v2036-mq .chip:hover .v { color: var(--ink); }
@keyframes mqL { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes mqR { from { transform: translateX(-50%); } to { transform: translateX(0); } }
@media (max-width: 900px) {
  .v2036-mq { padding: 80px 0 100px; }
  .v2036-mq-head { padding: 0 24px; margin-bottom: 48px; }
  .v2036-mq .chip { padding: 14px 22px; gap: 10px; }
  .v2036-mq .chip .k { font-size: 15px; }
  .v2036-mq .chip .v { font-size: 12px; }
}

/* Values grid */
.val-sec { padding: 100px 48px; max-width: 1320px; margin: 0 auto; }
.val-head { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; margin-bottom: 80px; }
.val-head h2 { font-size: clamp(30px, 4.4vw, 56px); line-height: 1.3; }
.val-head h2 .en { display: block; font-family: "Cormorant Garamond", serif; font-style: italic; color: var(--orange); font-size: 0.5em; margin-bottom: 8px; font-weight: 400; }
.val-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; border-top: 1px solid var(--mist); border-bottom: 1px solid var(--mist); }
.val-card { padding: 48px 28px; border-right: 1px solid var(--mist); display: flex; flex-direction: column; gap: 28px; min-height: 380px; transition: background .5s var(--ease); position: relative; }
.val-card:last-child { border-right: 0; }
.val-card:hover { background: var(--ink); color: var(--off); }
.val-card .n { font-family: "Inter", sans-serif; font-size: 11px; letter-spacing: 0.2em; color: var(--stone); }
.val-card h3 { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 42px; font-weight: 400; color: var(--orange); line-height: 1; }
.val-card p { font-family: "Noto Serif JP", serif; font-size: 15px; line-height: 1.9; }
.val-card .mini { position: absolute; bottom: 24px; right: 28px; opacity: 0; transition: opacity .4s var(--ease); color: var(--orange); font-family: "Inter", sans-serif; font-size: 10px; letter-spacing: 0.3em; }
.val-card:hover .mini { opacity: 1; }
@media (max-width: 1000px) {
  .val-grid { grid-template-columns: repeat(2, 1fr); }
  .val-card { border-right: 1px solid var(--mist); border-bottom: 1px solid var(--mist); min-height: auto; padding: 36px 24px; }
  .val-card:nth-child(2n) { border-right: 0; }
}
@media (max-width: 600px) {
  .val-grid { grid-template-columns: 1fr; }
  .val-card { border-right: 0; }
}

/* Representative */
.rep-sec { padding: 100px 48px; max-width: 1320px; margin: 0 auto; background: var(--off-2); }
.rep-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 96px; align-items: center; }
.rep-photo-wrap { position: relative; }
.rep-photo-wrap::before { content: ""; position: absolute; inset: -20px -20px 20px 20px; border: 1px solid var(--orange); z-index: 0; }
.rep-photo { position: relative; aspect-ratio: 4/5; overflow: hidden; background: var(--mist); z-index: 1; }
.rep-photo img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.02); }
.rep-photo-wrap .tate-name { position: absolute; top: 20px; left: -40px; writing-mode: vertical-rl; font-family: "Noto Serif JP", serif; font-size: 14px; letter-spacing: 0.4em; color: var(--stone); z-index: 2; }
.rep-info .title { font-family: "Inter", sans-serif; font-size: 11px; letter-spacing: 0.24em; color: var(--orange); text-transform: uppercase; margin-bottom: 16px; }
.rep-info h3 { font-size: clamp(34px, 4.6vw, 58px); line-height: 1.2; margin-bottom: 6px; font-weight: 500; }
.rep-info .romaji { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 22px; color: var(--stone); margin-bottom: 40px; }
.rep-info p { font-size: 15px; line-height: 2.1; color: #2f2f33; margin-bottom: 20px; max-width: 560px; }
.rep-info .sig { margin-top: 40px; font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 32px; color: var(--ink); }

/* Career timeline */
.rep-career { margin-top: 80px; max-width: 1100px; margin-left: auto; margin-right: auto; }
.rep-career-head { display: flex; align-items: baseline; gap: 20px; margin-bottom: 40px; padding-bottom: 20px; border-bottom: 1px solid var(--mist); }
.rep-career-head .num { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 42px; color: var(--orange); line-height: 1; }
.rep-career-head .ttl { font-family: "Noto Serif JP", serif; font-size: 22px; font-weight: 500; letter-spacing: 0.06em; }
.rep-career-head .en { font-family: "Inter", sans-serif; font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--stone); margin-left: auto; }
.rep-timeline { display: grid; gap: 0; }
.rep-timeline .row { display: grid; grid-template-columns: 200px 1fr; gap: 40px; padding: 28px 0; border-bottom: 1px solid var(--mist); align-items: start; }
.rep-timeline .row:last-child { border-bottom: 0; }
.rep-timeline .when { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 22px; color: var(--orange); line-height: 1.3; }
.rep-timeline .when .jp { display: block; font-family: "Noto Serif JP", serif; font-style: normal; font-size: 12px; color: var(--stone); letter-spacing: 0.1em; margin-top: 4px; }
.rep-timeline .what { font-family: "Noto Serif JP", serif; font-size: 15px; line-height: 2; color: #2f2f33; }
.rep-timeline .what strong { font-weight: 600; color: var(--ink); }
@media (max-width: 900px) {
  .rep-timeline .row { grid-template-columns: 1fr; gap: 8px; padding: 20px 0; }
  .rep-career-head { flex-wrap: wrap; }
  .rep-career-head .en { margin-left: 0; width: 100%; }
}
@media (max-width: 900px) {
  .rep-sec { padding: 100px 24px; }
  .rep-grid { grid-template-columns: 1fr; gap: 48px; }
  .rep-photo-wrap .tate-name { display: none; }
}

/* Company table */
.co-sec { padding: 20px 48px 30px; max-width: 1000px; margin: 0 auto; }
.co-head { text-align: center; margin-bottom: 64px; }
.co-head .en { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 64px; color: var(--orange); margin-bottom: 8px; }
.co-head h2 { font-size: clamp(26px, 3vw, 36px); }
.co-table { width: 100%; }
.co-table tr { border-bottom: 1px solid var(--mist); }
.co-table tr:first-child { border-top: 1px solid var(--mist); }
.co-table th { text-align: left; padding: 24px 32px 24px 0; font-family: "Inter", sans-serif; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--stone); font-weight: 500; width: 220px; vertical-align: top; }
.co-table td { padding: 24px 0; font-family: "Noto Serif JP", serif; font-size: 16px; }
@media (max-width: 700px) {
  .co-sec { padding: 80px 24px; }
  .co-table th, .co-table td { display: block; width: auto; padding: 8px 0; }
  .co-table th { padding-top: 20px; }
}

/* About h1 サイズ修正 */
.ab-hero h1 {
  font-size: clamp(28px, 4vw, 64px) !important;
  line-height: 1.4 !important;
}

/* end */