/* ============================================================
   AGARI PHOTOGRAPHER ／ メインスタイルシート
   ART DIRECTION: "Quiet, editorial, photo-first."

   構成：
     01. リセット・基本設定
     02. カラー・タイポ変数
     03. ベース要素
     04. 共通レイアウト
     05. ヘッダー / ナビゲーション
     06. ヒーロー
     07. セクション
     08. ABOUTブロック
     09. カテゴリカード
     10. 動画ブロック
     11. フッター
     12. アンビエントモーション
     13. モバイル
     14. 管理画面側の調整
============================================================ */


/* ─── 01. リセット ─── */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body { line-height: 1.6; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: none; }
input, textarea, select { font: inherit; }


/* ─── 02. 変数 ─── 黒バージョン（Dark／映画的・重厚）
 * 戦略: --paper / --ink は両方とも「明色（クリーム）」に統一。
 *       「ページ背景・暗い面」は新変数 --bg を使用。
 *       これで color: var(--paper) / color: var(--ink) が自然に明色で表示される。
 */
:root {
    /* テキスト・コントラスト（明色） */
    --paper:       #f3efe6;        /* 旧用途: 明るい背景 → 黒版では「明るい色」として残す（暗背景上のテキスト等） */
    --ink:         #f3efe6;        /* メインテキスト（クリーム） */
    --ink-soft:    rgba(243,239,230,0.66);
    --ink-faint:   rgba(243,239,230,0.40);

    /* 背景（暗色） */
    --bg:          #0b0e13;        /* ページ背景（深いネイビー）*/
    --bg-2:        #13171f;
    --bg-soft:     #1a1f29;
    --bg-card:     #161a23;

    /* 旧トークン（互換性維持） */
    --sand:        #13171f;        /* サブ背景 */
    --night-sea:   #9cb8d4;        /* アクセント */
    --line:        rgba(243,239,230,0.12);
    --white:       #FFFFFF;
    --note-red:    #C44A3D;

    /* アクセント補助 */
    --accent:      #9cb8d4;
    --accent-2:    #6e8faf;

    --font-display: "Cormorant Garamond", "Noto Serif JP", "Hiragino Mincho ProN", serif;
    --font-brand:   "Manrope", "Noto Sans JP", "Helvetica Neue", system-ui, sans-serif;
    --font-jp:      "Noto Sans JP", "Hiragino Kaku Gothic ProN", system-ui, sans-serif;
    --font-jp-serif:"Noto Serif JP", "Hiragino Mincho ProN", serif;

    --space-1: 0.5rem;
    --space-2: 1rem;
    --space-3: 1.5rem;
    --space-4: 2.5rem;
    --space-5: 4rem;
    --space-6: 6rem;
    --space-7: 9rem;
    --space-8: 12rem;

    --container-w: 1200px;
    --content-w:   720px;

    --ease: cubic-bezier(0.16, 1, 0.3, 1);
    --duration-slow: 900ms;
    --duration-base: 600ms;
    --duration-fast: 300ms;
}


/* ─── 03. ベース要素 ─── */
body {
    background: var(--paper);
    color: var(--ink);
    font-family: var(--font-jp);
    font-size: 15px;
    font-weight: 400;
    letter-spacing: 0.03em;
    font-feature-settings: "palt" 1; /* 日本語の自動詰め */
}

::selection { background: var(--ink); color: var(--paper); }

.skip-link {
    position: absolute; left: -9999px; top: 0; z-index: 100;
    background: var(--ink); color: var(--paper); padding: 12px 18px;
}
.skip-link:focus { left: 16px; top: 16px; }


/* ─── 04. 共通レイアウト ─── */
.container { max-width: var(--container-w); margin: 0 auto; padding: 0 40px; }
.container--narrow { max-width: var(--content-w); }

.section { padding: var(--space-7) 0; }
.section--first { padding-top: 0; }

/* インナーページのヘッダー下の余白（TOP以外） */
.section--page-top {
    padding: 120px 0 var(--space-4);
}
@media (max-width: 900px) {
    .section--page-top {
        padding: 120px 0 var(--space-3);
    }
}

.section__head { margin-bottom: var(--space-5); }

/* タイポ */
.eyebrow {
    display: inline-block;
    font-family: var(--font-brand);
    font-weight: 500;
    font-size: 11px;
    letter-spacing: 0.3em;
    color: var(--ink-soft);
    text-transform: uppercase;
    margin-bottom: var(--space-3);
}

.h-display {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(24px, 4vw, 36px);
    line-height: 1.5;
    letter-spacing: 0.01em;
    margin-bottom: var(--space-3);
}
.h-display em {
    font-style: normal;
    font-weight: 400;
}
/* 英文だけの見出しは Space Grotesk のみ参照 */
.h-display:lang(en) { letter-spacing: -0.01em; }

.lead {
    font-family: var(--font-jp);
    font-size: 15px;
    line-height: 1.95;
    color: var(--ink);
    max-width: 36em;
}
.lead p + p { margin-top: var(--space-2); }

.section__lead {
    font-size: 14px;
    line-height: 1.9;
    color: var(--ink-soft);
    margin-top: var(--space-2);
    max-width: 32em;
}

.section__lead-link {
    color: var(--accent);
    font-weight: 600;
    border-bottom: 1px solid var(--accent);
    padding-bottom: 1px;
    transition: opacity .2s var(--ease);
}
.section__lead-link:hover { opacity: .7; }

.link-arrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-brand);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.2em;
    color: var(--ink);
    padding-bottom: 6px;
    border-bottom: 1px solid var(--ink);
    transition: opacity var(--duration-fast) var(--ease);
    margin-top: var(--space-3);
}
.link-arrow span { transition: transform var(--duration-base) var(--ease); }
.link-arrow:hover { opacity: 0.7; }
.link-arrow:hover span { transform: translateX(4px); }


/* ─── 05. ヘッダー・ナビゲーション ─── */
.site-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 50;
    padding: 28px 40px;
    background: rgba(11, 14, 19, 0.85);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--line);
    transition: padding var(--duration-base) var(--ease);
}
body.is-scrolled .site-header { padding: 18px 40px; }

.site-header__inner {
    max-width: 1440px; margin: 0 auto;
    display: flex; align-items: center; justify-content: space-between;
}

.site-logo {
    font-family: var(--font-brand);
    line-height: 1;
}
.site-logo__brand {
    font-weight: 600;
    font-size: 18px;
    letter-spacing: 0.14em;
    display: block;
}
.site-logo__sub {
    display: block;
    font-size: 9px;
    font-weight: 400;
    color: var(--ink-soft);
    letter-spacing: 0.3em;
    margin-top: 4px;
}
.site-logo img { max-height: 40px; width: auto; }

.site-nav__list {
    display: flex; gap: 36px;
    list-style: none;
}
.site-nav__item a {
    font-family: var(--font-brand);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.2em;
    color: var(--ink);
    transition: opacity var(--duration-fast) var(--ease);
    position: relative;
    padding: 4px 0;
}
.site-nav__item a:hover { opacity: 0.6; }
.site-nav__item.is-current a { color: var(--ink); }
.site-nav__item.is-current a::after {
    content: "";
    position: absolute; left: 0; right: 0; bottom: -2px;
    height: 1px; background: var(--ink);
}
.site-nav__item.is-cta a {
    border: 1px solid var(--ink);
    padding: 10px 18px;
}

.nav-toggle {
    display: none;
    flex-direction: column; gap: 5px;
    padding: 8px;
    z-index: 60;
}
.nav-toggle span {
    display: block; width: 24px; height: 1px;
    background: var(--ink);
    transition: transform var(--duration-base) var(--ease);
}


/* ─── 06. ヒーロー ─── */
.hero {
    position: relative;
    height: 100vh;
    min-height: 600px;
    overflow: hidden;
    background: var(--ink);
}
.hero__slides { position: absolute; inset: 0; }
/* スライドはシンプルにopacityだけでクロスフェード（z-index で重なり制御） */
.hero__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 1.6s var(--ease);
    pointer-events: none;
    will-change: opacity;
}
.hero__slide.is-active {
    opacity: 1;
    pointer-events: auto;
    z-index: 1;
}
.hero__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transform: scale(1) translate(0, 0);
    transition: transform 11s linear;
    will-change: transform;
    backface-visibility: hidden;
}
.hero__slide.is-active img {
    transform: scale(1.08) translate(-1.5%, -1%);
}

.hero__placeholder {
    background: linear-gradient(135deg, #1a1a1a 0%, #333 100%);
    display: flex; align-items: center; justify-content: center;
    color: var(--paper);
    opacity: 1;
}
.hero__placeholder-text {
    text-align: center; padding: 24px;
}
.hero__placeholder-label {
    font-family: var(--font-brand);
    font-size: 11px; letter-spacing: 0.3em;
    color: var(--ink-faint);
    margin-bottom: 14px;
}

.hero__overlay {
    position: absolute; inset: 0;
    display: flex; align-items: flex-end;
    padding: 80px 40px;
    background: linear-gradient(to top, rgba(0,0,0,0.4) 0%, transparent 50%);
    z-index: 2;
}
.hero__caption { color: var(--paper); }
.hero__title {
    font-family: var(--font-brand);
    font-weight: 500;
    font-size: clamp(2rem, 5vw, 3.5rem);
    line-height: 1;
    letter-spacing: 0.04em;
    margin-bottom: 16px;
}
.hero__sub {
    font-family: var(--font-brand);
    font-size: 11px;
    letter-spacing: 0.4em;
    color: var(--paper);
    opacity: 0.7;
}

.hero__indicators {
    position: absolute; right: 40px; bottom: 40px; z-index: 3;
    display: flex; gap: 8px;
}
.hero__dot {
    display: block;
    width: 24px; height: 1px;
    background: rgba(255,255,255,0.3);
    transition: background var(--duration-base) var(--ease);
}
.hero__dot.is-active { background: var(--paper); }


/* ─── 07. セクション一般 ─── */
.section {
    padding-top: var(--space-7);
    padding-bottom: var(--space-7);
}


/* ─── 08. ABOUTブロック ─── ABOUTページのHEROと同サイズ */
.section--about {
    padding: 5rem 0;
}
.about-block {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: var(--space-5);
    align-items: flex-start;
}
.about-block__image {
    aspect-ratio: 3/4;
    overflow: hidden;
    background: var(--sand);
    margin: 0;
}
.about-block__image img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 3s var(--ease);
}
.about-block:hover .about-block__image img {
    transform: scale(1.03);
}
.about-block__image--placeholder {
    background: linear-gradient(135deg, #2e2e2e 0%, #161616 100%);
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.3);
    font-family: var(--font-brand);
    font-size: 11px; letter-spacing: 0.3em;
}
.about-block__copy {
    color: var(--ink);
    display: flex;
    flex-direction: column;
    justify-content: center;
}


/* ─── 09. カテゴリカード ─── フルブリード・タイル */
.section--categories {
    padding: var(--space-4) 0 0;
}
.section--categories .container {
    max-width: none;
    padding: 0;
}
.section--categories .section__head {
    max-width: var(--container-w);
    margin: 0 auto;
    padding: 0 40px var(--space-4);
    text-align: center;
}
.section--categories .section__lead {
    margin-left: auto;
    margin-right: auto;
}

.cat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}
.cat-card {
    position: relative;
    overflow: hidden;
    height: 58vh;
    min-height: 420px;
    display: block;
}
.cat-card__image {
    aspect-ratio: auto;
    width: 100%;
    height: 100%;
    margin: 0;
    background: linear-gradient(135deg, #2e2e2e 0%, #161616 100%);
    overflow: hidden;
}
.cat-card__image img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 2.5s var(--ease);
}
.cat-card:hover .cat-card__image img {
    transform: scale(1.05);
}
/* 画像未設定時のプレースホルダー文字は非表示（キャプションと重なるため） */
.cat-card__placeholder {
    display: none;
}
.cat-card__caption {
    position: absolute;
    inset: 0;
    z-index: 2;
    padding: 0 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--paper);
    background: linear-gradient(180deg, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.55) 100%);
    pointer-events: none;
}
.cat-card__title {
    font-family: var(--font-brand);
    font-weight: 500;
    font-size: clamp(22px, 2.5vw, 32px);
    letter-spacing: 0.22em;
    color: var(--paper);
    margin-bottom: 10px;
}
.cat-card__ja {
    font-family: var(--font-jp);
    font-size: 13px;
    color: var(--paper);
    opacity: 0.85;
    margin-bottom: 24px;
    letter-spacing: 0.06em;
}
.cat-card__more {
    font-family: var(--font-brand);
    font-size: 10px;
    letter-spacing: 0.3em;
    color: var(--paper);
    padding: 12px 24px;
    border: 1px solid rgba(255,255,255,0.45);
    background: transparent;
    margin-top: 0;
    transition: background var(--duration-base) var(--ease), color var(--duration-base) var(--ease);
}
.cat-card:hover .cat-card__more {
    background: var(--paper);
    color: var(--ink);
}


/* ─── 10. 動画ブロック ─── フルブリード 50/50 */
.section--video {
    padding: 0;
}
.section--video .container {
    max-width: none;
    padding: 0;
}
.video-block {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    align-items: stretch;
    min-height: 52vh;
}
.video-block__media {
    aspect-ratio: auto;
    height: 100%;
    overflow: hidden;
    background: var(--ink);
    position: relative;
}
.video-block__media iframe,
.video-block__media video {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    background: var(--ink);
}
.video-block__media img {
    width: 100%; height: 100%; object-fit: cover;
}
.video-block__placeholder {
    display: flex; align-items: center; justify-content: center;
    height: 100%;
    min-height: 180px;
    color: var(--ink-faint);
    font-family: var(--font-brand);
    font-size: 12px; letter-spacing: 0.2em;
}
.video-block__copy {
    background: var(--ink);
    color: var(--paper);
    padding: var(--space-4) clamp(32px, 6vw, 80px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.video-block__copy .eyebrow { color: var(--paper); opacity: 0.55; }
.video-block__copy .h-display { color: var(--paper); }
.video-block__copy .lead { color: var(--paper); opacity: 0.82; }
.video-block__copy .link-arrow {
    color: var(--paper);
    border-bottom-color: rgba(255,255,255,0.5);
}


/* ─── 10.5 TOP SERVICES（業務向け：撮影・動画制作のご依頼） ─── */
.section--services {
    padding: var(--space-6) 0 var(--space-5);
    border-top: 1px solid var(--line);
}
.section--services .section__head {
    text-align: center;
    margin-bottom: var(--space-5);
}
.section--services .section__lead {
    margin-left: auto;
    margin-right: auto;
}

.top-services {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border: 1px solid var(--line);
}
.top-service {
    padding: clamp(28px, 4vw, 56px);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    background: transparent;
}
.top-service + .top-service {
    border-left: 1px solid var(--line);
}
.top-service__num {
    font-family: var(--font-brand);
    font-size: 11px;
    letter-spacing: 0.32em;
    color: var(--ink-faint);
}
.top-service__en {
    font-family: var(--font-brand);
    font-size: 12px;
    letter-spacing: 0.28em;
    color: var(--ink-soft);
    text-transform: uppercase;
}
.top-service__title {
    font-family: var(--font-display);
    font-size: clamp(24px, 2.4vw, 30px);
    font-weight: 400;
    line-height: 1.3;
    color: var(--ink);
    font-feature-settings: "palt" 1;
    margin: 0;
}
.top-service__desc {
    font-size: 14px;
    line-height: 1.85;
    color: var(--ink-soft);
    flex-grow: 1;
}
.top-service .link-arrow {
    margin-top: 6px;
}

.top-services-cta {
    margin-top: var(--space-4);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}
.top-services-cta__lead {
    font-size: 14px;
    line-height: 1.85;
    color: var(--ink-soft);
    max-width: 560px;
}
.top-services-cta__button {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 16px 36px;
    background: var(--accent);
    color: var(--bg);
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.22em;
    border: 1px solid var(--accent);
    transition: background var(--duration-base) var(--ease), color var(--duration-base) var(--ease);
}
.top-services-cta__button span {
    transition: transform var(--duration-base) var(--ease);
    font-size: 14px;
}
.top-services-cta__button:hover {
    background: transparent;
    color: var(--accent);
}
.top-services-cta__button:hover span {
    transform: translateX(4px);
}

@media (max-width: 900px) {
    .section--services { padding: var(--space-4) 0; }
    .top-services { grid-template-columns: 1fr; }
    .top-service + .top-service {
        border-left: none;
        border-top: 1px solid var(--line);
    }
    .top-services-cta { margin-top: var(--space-3); }
    .top-services-cta__button { padding: 14px 28px; font-size: 11px; }
}


/* ─── ギャラリー／VIDEOGRAPHY 業務向けノート ─── */
.gallery-header__note,
.vg-section-note {
    margin-top: 14px;
    font-size: 13px;
    line-height: 1.8;
    color: var(--ink-soft);
    letter-spacing: 0.02em;
}
.gallery-header__note a,
.vg-section-note a {
    color: var(--ink);
    border-bottom: 1px solid var(--line);
    padding-bottom: 1px;
    transition: opacity var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
}
.gallery-header__note a:hover,
.vg-section-note a:hover {
    opacity: 0.75;
    border-bottom-color: var(--accent);
}


/* ─── 11. フッター ─── */
.site-footer {
    background: var(--ink);
    color: var(--paper);
    padding: var(--space-6) 40px var(--space-4);
}
.site-footer__inner {
    max-width: 1440px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr;
    gap: var(--space-5);
}
.site-footer__brand {}
.site-footer__name {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 18px;
    letter-spacing: 0.14em;
    display: block;
    margin-bottom: 12px;
}
.site-footer__tagline {
    font-family: var(--font-brand);
    font-weight: 300;
    font-size: 13px;
    letter-spacing: 0.04em;
    opacity: 0.65;
}
.site-footer__nav {
    display: flex; gap: 24px; justify-content: flex-end;
    flex-wrap: wrap;
}
.site-footer__nav a {
    font-family: var(--font-brand);
    font-size: 11px;
    letter-spacing: 0.2em;
    opacity: 0.8;
    transition: opacity var(--duration-fast) var(--ease);
}
.site-footer__nav a:hover { opacity: 1; }
.site-footer__bottom {
    grid-column: 1 / -1;
    padding-top: var(--space-3);
    margin-top: var(--space-3);
    border-top: 1px solid rgba(255,255,255,0.1);
    font-family: var(--font-brand);
    font-size: 10px;
    letter-spacing: 0.2em;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}
.site-footer__legal a {
    color: var(--paper);
    opacity: 0.7;
    border-bottom: 1px solid transparent;
    transition: opacity var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
}
.site-footer__legal a:hover { opacity: 1; border-bottom-color: rgba(255,255,255,0.5); }
.site-footer__bottom p { opacity: 0.5; margin: 0; }
@media (max-width: 600px) {
    .site-footer__bottom { justify-content: flex-start; }
}


/* ─── 12. アンビエントモーション ───
 * .reveal は3重のセーフティネットで「絶対に消えたまま固まらない」設計：
 *   ① 通常時：JSが <html> に js-enabled を付け、IntersectionObserver で .is-visible 付与 → フェードイン
 *   ② JSが部分的に動く時：header.php のインラインスクリプトが3秒後に強制 .is-visible
 *   ③ CSSセーフティネット：このスタイル自体に animation の delay を仕込み、JS全停止でも3秒後にCSSアニメで強制表示
 *   ④ js-enabled が一切付かない場合：.reveal の opacity:0 ルールごと適用されない → 常時表示
 */
.js-enabled .reveal {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity var(--duration-slow) var(--ease), transform var(--duration-slow) var(--ease);
    /* CSSセーフティネット：3秒後にアニメで強制表示（JSの.is-visibleが付かなくても発火） */
    animation: agariRevealFallback 0.8s var(--ease) 3s forwards;
}
.js-enabled .reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
    animation: none;  /* JSが.is-visibleを付けたらCSSアニメは不要 */
}
@keyframes agariRevealFallback {
    to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
    .js-enabled .reveal { opacity: 1; transform: none; transition: none; animation: none; }
    .hero__slide img { animation: none; }
    .hero__slide { transition-duration: 0.1s; }
    * { transition-duration: 0.01s !important; animation-duration: 0.01s !important; }
}


/* ─── 13. モバイル ─── */
@media (max-width: 900px) {
    .container { padding: 0 24px; }
    .section { padding: var(--space-4) 0; }

    /* フルブリードセクションは余白なし（メディアクエリ後の上書き対策） */
    .section--video {
        padding: 0;
    }
    .section--about {
        padding: 2rem 0;
    }

    .site-header { padding: 18px 24px; }

    .nav-toggle { display: flex; }
    .site-nav {
        position: fixed !important;
        top: 0 !important; right: 0 !important; bottom: 0 !important; left: 0 !important;
        width: 100vw; height: 100vh;
        background-color: #0b0e13 !important;
        backdrop-filter: none !important;
        display: flex; align-items: flex-start; justify-content: center;
        padding-top: clamp(120px, 22vh, 200px);
        opacity: 0; pointer-events: none;
        transition: opacity var(--duration-base) var(--ease);
        z-index: 9998;
    }
    body.is-nav-open .site-header {
        background: #0b0e13 !important;
        backdrop-filter: none !important;
        z-index: 9999;
    }
    body.is-nav-open .site-nav {
        opacity: 1; pointer-events: auto;
    }
    body.is-nav-open .nav-toggle {
        z-index: 10000;
    }
    body.is-nav-open .nav-toggle span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
    body.is-nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
    body.is-nav-open .nav-toggle span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

    .site-nav__list {
        flex-direction: column; gap: 28px; align-items: center;
    }
    .site-nav__item a { font-size: 16px; letter-spacing: 0.2em; }
    .site-nav__item.is-cta a { padding: 14px 24px; font-size: 14px; }

    .hero { height: 75vh; min-height: 480px; max-height: 640px; }
    .hero__overlay { padding: 40px 24px; }
    .hero__indicators { right: 24px; bottom: 24px; }

    /* About: 縦積み */
    .about-block {
        grid-template-columns: 1fr;
        gap: var(--space-3);
    }
    .about-block__image { aspect-ratio: 4/3; }

    /* Categories: 縦並び（余白を最小化） */
    .cat-grid { grid-template-columns: 1fr; }
    .cat-card { height: 50vh; min-height: 340px; }
    .section--categories { padding: var(--space-2) 0 0; }
    .section--categories .section__head { padding: 0 24px var(--space-2); }

    /* Video: 縦積み */
    .video-block {
        grid-template-columns: 1fr;
        min-height: auto;
    }
    .video-block__media { aspect-ratio: 16/9; height: auto; min-height: 56.25vw; }
    .video-block__copy { padding: var(--space-2) 24px var(--space-3); }

    /* 見出しのマージン下を圧縮 */
    .h-display { margin-bottom: var(--space-2); }
    .eyebrow { margin-bottom: var(--space-1); }

    /* フッター */
    .site-footer { padding: var(--space-3) 24px var(--space-2); }

    .site-footer { padding: var(--space-4) 24px var(--space-3); }
    .site-footer__inner { grid-template-columns: 1fr; gap: var(--space-3); }
    .site-footer__nav { justify-content: flex-start; }
}


/* ─── ギャラリー：見出し ─── */
.gallery-header {
    margin-bottom: var(--space-3);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--line);
}

/* ─── ギャラリーフィルター ─── */
.gallery-filter {
    border: 1px solid var(--line);
    padding: 8px var(--space-3);
    margin-bottom: var(--space-2);
}
.gallery-filter__row {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: var(--space-2);
    align-items: center;
    padding: 12px 0;
}
.gallery-filter__row + .gallery-filter__row {
    border-top: 1px dashed var(--line);
}
.gallery-filter__label {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.2em;
    color: var(--ink);
}
.gallery-filter__label small {
    display: block;
    font-family: var(--font-jp);
    font-weight: 400;
    font-size: 10px;
    color: var(--ink-soft);
    letter-spacing: 0.06em;
    margin-top: 3px;
}
.gallery-filter__chips {
    display: flex; flex-wrap: wrap; gap: 6px;
}
.filter-chip {
    font-family: var(--font-brand);
    font-weight: 500;
    font-size: 11px;
    letter-spacing: 0.08em;
    border: 1px solid var(--line);
    background: transparent;
    color: var(--ink-soft);
    padding: 5px 12px;
    cursor: pointer;
    border-radius: 999px;
    transition: background var(--duration-fast) var(--ease), color var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
}
.filter-chip:hover {
    border-color: var(--ink);
    color: var(--ink);
}
.filter-chip.is-active {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
}
.filter-chip .ct {
    font-size: 10px;
    opacity: 0.7;
    margin-left: 4px;
}

/* ─── 件数・リセット ─── */
.gallery-result {
    display: flex; align-items: center; gap: 10px;
    padding: var(--space-2) 0 var(--space-3);
    font-family: var(--font-brand);
    font-size: 11px;
    letter-spacing: 0.14em;
    color: var(--ink-soft);
}
.gallery-result b { color: var(--ink); font-weight: 700; }
.gallery-result__status { color: var(--ink-soft); }
.gallery-result__reset {
    margin-left: auto;
    font-family: var(--font-brand);
    font-weight: 500;
    font-size: 10px;
    letter-spacing: 0.2em;
    color: var(--ink-soft);
    background: transparent;
    border: none;
    cursor: pointer;
    padding-bottom: 2px;
    border-bottom: 1px dashed var(--ink-soft);
    display: none;
}
.gallery-result.has-filter .gallery-result__reset { display: inline-block; }
.gallery-result.has-filter .gallery-result__reset:hover { color: var(--ink); border-color: var(--ink); }

/* ─── テーマカード（フラットグリッド） ─── */
.theme-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
}
@media (max-width: 900px) { .theme-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .theme-grid { grid-template-columns: 1fr; gap: 6px; } }
.theme-card {
    aspect-ratio: 1/1;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #2e2e2e 0%, #161616 100%);
    cursor: pointer;
    transition: opacity var(--duration-base) var(--ease);
}
.theme-card.is-hidden { display: none; }
.theme-card.is-faded { opacity: 0.25; pointer-events: none; }
.theme-card__num {
    position: absolute; top: 8px; left: 8px; z-index: 3;
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 10px;
    background: var(--paper); color: var(--ink);
    padding: 2px 6px;
    letter-spacing: 0.1em;
}
.theme-card__image {
    width: 100%; height: 100%;
}
.theme-card__image img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 1.5s var(--ease);
}
.theme-card:hover .theme-card__image img {
    transform: scale(1.04);
}
.theme-card__overlay {
    position: absolute; inset: 0;
    z-index: 2;
    background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,0.55) 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding: 16px;
    text-align: center;
    color: var(--paper);
}
.theme-card__name {
    font-family: var(--font-brand);
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.18em;
    color: var(--paper);
    text-align: center;
    text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}
.theme-card__count {
    font-family: var(--font-brand);
    font-size: 9px;
    color: var(--paper);
    opacity: 0.75;
    margin-top: 6px;
    letter-spacing: 0.14em;
}

/* 空状態 */
.gallery-empty {
    text-align: center;
    padding: var(--space-5) 0;
    font-family: var(--font-jp);
    color: var(--ink-soft);
    line-height: 1.9;
}
.gallery-empty small { font-size: 12px; opacity: 0.7; }

/* モバイル：フィルターを縦積みに */
@media (max-width: 700px) {
    .gallery-filter { padding: 4px 16px; }
    .gallery-filter__row {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 10px 0;
    }
    .gallery-filter__label small { display: inline; margin-left: 6px; }
}

/* ─── ギャラリー詳細：写真グリッド ─── */
.photo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 8px;
}
.photo-card {
    aspect-ratio: 1/1;
    overflow: hidden;
    display: block;
    background: var(--sand);
    cursor: zoom-in;
}
.photo-card img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 1.5s var(--ease);
}
.photo-card:hover img {
    transform: scale(1.04);
}

/* ─── 縦/横フィルター（GALLERY詳細上部のチップ） ─── */
.orient-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: var(--space-3);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--line);
}
.orient-chip {
    appearance: none;
    background: transparent;
    border: 1px solid var(--line);
    color: var(--ink);
    font-family: var(--font-brand);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.18em;
    padding: 9px 16px;
    cursor: pointer;
    transition: background var(--duration-fast) var(--ease),
                color var(--duration-fast) var(--ease),
                border-color var(--duration-fast) var(--ease);
}
.orient-chip:hover {
    border-color: var(--ink);
}
.orient-chip.is-active {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
}
.orient-chip .ct {
    display: inline-block;
    margin-left: 6px;
    opacity: 0.55;
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.1em;
}

/* フィルター時、グリッドの列幅とアスペクト比をオリエンテーションに合わせる */
.photo-grid.is-landscape {
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
}
.photo-grid.is-landscape .photo-card {
    aspect-ratio: 4/3;
}
.photo-grid.is-portrait {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.photo-grid.is-portrait .photo-card {
    aspect-ratio: 3/4;
}

/* フィルターで非表示にする写真 */
.photo-card.is-hidden {
    display: none !important;
}

@media (max-width: 900px) {
    .orient-filter {
        gap: 6px;
        padding-bottom: var(--space-2);
        margin-bottom: var(--space-2);
    }
    .orient-chip {
        padding: 8px 12px;
        font-size: 10px;
        letter-spacing: 0.14em;
    }
    .photo-grid.is-landscape {
        grid-template-columns: 1fr;
    }
    .photo-grid.is-portrait {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ─── ページネーション ─── */
.gallery-pagination {
    text-align: center;
    margin-top: var(--space-4);
    font-family: var(--font-brand);
    font-size: 12px;
    letter-spacing: 0.14em;
}
.gallery-pagination .page-numbers {
    display: inline-block;
    padding: 8px 14px;
    margin: 0 2px;
    color: var(--ink-soft);
    border: 1px solid transparent;
}
.gallery-pagination .page-numbers.current {
    color: var(--ink);
    border-color: var(--ink);
}
.gallery-pagination .page-numbers:hover { color: var(--ink); }

/* ─── ライトボックス ─── */
.lightbox {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(0,0,0,0.92);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity 0.6s var(--ease);
}
.lightbox.is-open {
    opacity: 1; pointer-events: auto;
}
.lightbox__media {
    max-width: 90vw; max-height: 85vh;
    display: flex; align-items: center; justify-content: center;
}
.lightbox__media img {
    max-width: 100%; max-height: 85vh;
    object-fit: contain;
    transform: scale(0.96);
    opacity: 0;
    transition: transform 0.8s var(--ease), opacity 0.6s var(--ease);
}
.lightbox.is-open .lightbox__media img {
    transform: scale(1);
    opacity: 1;
}
.lightbox__close,
.lightbox__prev,
.lightbox__next {
    position: absolute;
    background: transparent; border: 1px solid rgba(255,255,255,0.3);
    color: rgba(255,255,255,0.85);
    font-size: 24px; line-height: 1;
    width: 48px; height: 48px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background 0.3s var(--ease), color 0.3s var(--ease);
}
.lightbox__close:hover,
.lightbox__prev:hover,
.lightbox__next:hover {
    background: rgba(255,255,255,0.95); color: var(--ink);
}
.lightbox__close { top: 24px; right: 24px; }
.lightbox__prev  { left: 24px; top: 50%; transform: translateY(-50%); font-size: 32px; }
.lightbox__next  { right: 24px; top: 50%; transform: translateY(-50%); font-size: 32px; }
.lightbox__caption {
    position: absolute;
    bottom: 80px; left: 50%; transform: translateX(-50%);
    color: var(--paper);
    font-family: var(--font-jp);
    font-size: 13px;
    opacity: 0.8;
}
.lightbox__counter {
    position: absolute;
    bottom: 24px; left: 50%; transform: translateX(-50%);
    color: var(--paper);
    font-family: var(--font-brand);
    font-size: 11px;
    letter-spacing: 0.2em;
    opacity: 0.5;
}
@media (max-width: 700px) {
    .lightbox__close { top: 16px; right: 16px; width: 40px; height: 40px; font-size: 20px; }
    .lightbox__prev, .lightbox__next { width: 40px; height: 40px; }
    .lightbox__prev { left: 12px; }
    .lightbox__next { right: 12px; }
}

/* ─── ABOUT: HERO ─── */
.about-hero {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: var(--space-5);
    align-items: flex-start;
}
.about-hero__image {
    aspect-ratio: 3/4;
    overflow: hidden;
    background: var(--sand);
}
.about-hero__image img {
    width: 100%; height: 100%; object-fit: cover;
}
.about-hero__image--placeholder {
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, #2e2e2e 0%, #161616 100%);
    color: rgba(255,255,255,0.3);
    font-family: var(--font-brand); font-size: 11px; letter-spacing: 0.3em;
}
.about-hero__name {
    font-family: var(--font-brand);
    font-weight: 500;
    font-size: clamp(2.4rem, 5vw, 4rem);
    letter-spacing: -0.005em;
    line-height: 1;
    margin: var(--space-2) 0 var(--space-1);
}
.about-hero__ja {
    font-family: var(--font-jp);
    font-weight: 500;
    font-size: 14px;
    color: var(--ink-soft);
    margin-bottom: var(--space-3);
    letter-spacing: 0.05em;
}
.about-hero__bio {
    font-family: var(--font-jp);
    font-size: 14px;
    line-height: 2;
    color: var(--ink);
}
.about-hero__bio p + p { margin-top: var(--space-2); }

/* ─── ABOUT: FACTS ─── */
.facts-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    margin-top: var(--space-2);
}
.facts-row__item {
    padding: var(--space-2) var(--space-2);
    border-right: 1px solid var(--line);
}
.facts-row__item:last-child { border-right: none; }
.facts-row__key {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 10px;
    letter-spacing: 0.24em;
    color: var(--ink-soft);
    margin-bottom: 6px;
}
.facts-row__value {
    font-family: var(--font-jp);
    font-weight: 500;
    font-size: 15px;
    color: var(--ink);
}

/* ─── ABOUT: HISTORY ─── */
.history-block {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: var(--space-5);
    align-items: flex-start;
}
.history-block__head .h-display { margin-top: var(--space-2); }
.history-list {
    list-style: none;
    padding: 0;
    margin: 0;
    font-family: var(--font-jp);
    font-size: 14px;
}
.history-list__item {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: var(--space-3);
    padding: var(--space-2) 0;
    border-bottom: 1px dashed var(--line);
    align-items: flex-start;
}
.history-list__item:last-child { border-bottom: none; }
.history-list__year {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0.06em;
    color: var(--ink);
}
.history-list__main {
    display: block;
    color: var(--ink);
    line-height: 1.7;
}
.history-list__sub {
    display: block;
    font-size: 12px;
    color: var(--ink-soft);
    margin-top: 4px;
    line-height: 1.6;
}

/* ─── CTA ブロック共通 ─── */
.cta-block {
    background: var(--ink);
    color: var(--paper);
    padding: var(--space-5) 0;
}
.cta-block__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    flex-wrap: wrap;
}
.cta-block__title {
    font-family: var(--font-jp);
    font-weight: 500;
    font-size: clamp(1.2rem, 2.4vw, 1.6rem);
    color: var(--paper);
    margin-top: 6px;
}
.cta-block__button {
    display: inline-block;
    background: var(--paper);
    color: var(--ink);
    padding: 14px 32px;
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.2em;
    border: 1px solid var(--paper);
    transition: background var(--duration-base) var(--ease), color var(--duration-base) var(--ease);
}
.cta-block__button:hover {
    background: transparent;
    color: var(--paper);
}

/* ─── VIDEOGRAPHY: HERO（21:9 全幅） ─── */
.vg-hero {
    position: relative;
    margin-top: 0;
    background: var(--ink);
    overflow: hidden;
}
@media (max-width: 900px) {
    .vg-hero {
        margin-top: 80px;
    }
}
.vg-hero__media {
    position: relative;
    aspect-ratio: 21/9;
    width: 100%;
}
.vg-hero__media iframe,
.vg-hero__media video,
.vg-hero__media img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    background: var(--ink);
}
.vg-hero__placeholder {
    position: absolute; inset: 0;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.5);
    font-family: var(--font-brand); font-size: 12px; letter-spacing: 0.3em;
    background: linear-gradient(135deg, #2a2a2a 0%, #0a0a0a 100%);
    gap: 10px;
}
.vg-hero__placeholder small { font-size: 11px; letter-spacing: 0.1em; opacity: 0.7; }
.vg-hero__caption {
    position: absolute;
    left: clamp(24px, 4vw, 56px);
    bottom: clamp(24px, 4vw, 56px);
    background: var(--paper);
    padding: 18px 24px;
    z-index: 2;
}
.vg-hero__en {
    display: block;
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: clamp(20px, 2.6vw, 30px);
    letter-spacing: 0.04em;
    color: var(--ink);
}
.vg-hero__ja {
    display: block;
    font-family: var(--font-jp);
    font-size: 12px;
    color: var(--ink-soft);
    margin-top: 4px;
    letter-spacing: 0.04em;
}

/* （旧）VIDEOGRAPHY ページでヘッダーを透過していたが、視認性のため通常表示に統一 */

/* ─── VIDEOGRAPHY: CONCEPT ─── */
.vg-concept {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: var(--space-4);
    align-items: center;
}
.vg-concept__right {
    font-family: var(--font-jp);
    font-size: 14px;
    line-height: 2;
    color: var(--ink-soft);
}

/* セクション見出し共通 */
.vg-section-head {
    margin-bottom: var(--space-3);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--line);
}
.vg-section-head .h-display { margin-top: var(--space-1); }

/* ─── VIDEOGRAPHY: WORKS ─── */
.works-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
}
@media (max-width: 900px) { .works-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .works-grid { grid-template-columns: 1fr; } }
.work-card {
    display: block;
}
.work-card__media {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: linear-gradient(135deg, #2a2a2a 0%, #0f0f0f 100%);
    margin: 0;
    /* ボタン要素になったので appearance リセット */
    appearance: none;
    border: 0;
    padding: 0;
    width: 100%;
    display: block;
    cursor: pointer;
    color: inherit;
}
.work-card__media:focus-visible {
    outline: 2px solid var(--paper);
    outline-offset: 3px;
}
/* 縦動画はサムネイルも縦比率に */
.work-card--orient-portrait .work-card__media {
    aspect-ratio: 9/16;
}
.work-card__media img,
.work-card__media video,
.work-card__media iframe {
    width: 100%; height: 100%; object-fit: cover;
    position: absolute; inset: 0;
}
.work-card__media img {
    transition: transform 1.5s var(--ease);
}
.work-card:hover .work-card__media img { transform: scale(1.04); }
.work-card__placeholder {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.4);
    font-family: var(--font-brand); font-size: 11px; letter-spacing: 0.2em;
}
.work-card__play {
    position: absolute;
    left: 50%; top: 50%;
    transform: translate(-50%, -50%);
    color: var(--paper);
    background: rgba(0,0,0,0.55);
    width: 56px; height: 56px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    opacity: 0.85;
    transition: opacity var(--duration-base) var(--ease),
                transform var(--duration-base) var(--ease),
                background var(--duration-base) var(--ease);
}
.work-card__play svg { display: block; margin-left: 2px; /* 三角形視覚補正 */ }
.work-card:hover .work-card__play,
.work-card__media:focus-visible .work-card__play {
    opacity: 1;
    background: rgba(0,0,0,0.75);
    transform: translate(-50%, -50%) scale(1.08);
}

/* ─── 動画ライトボックス ─── */
.video-lightbox {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(0,0,0,0.94);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity 0.45s var(--ease);
}
.video-lightbox.is-open {
    opacity: 1; pointer-events: auto;
}
.video-lightbox__stage {
    position: relative;
    max-width: 92vw;
    max-height: 86vh;
    display: flex;
    align-items: center;
    justify-content: center;
}
/* アップロード動画：ネイティブのアスペクト比のまま表示 */
.video-lightbox__stage video {
    display: block;
    max-width: 92vw;
    max-height: 86vh;
    width: auto;
    height: auto;
    background: #000;
    box-shadow: 0 30px 80px rgba(0,0,0,0.6);
    transform: scale(0.96);
    opacity: 0;
    transition: transform 0.55s var(--ease), opacity 0.4s var(--ease);
}
.video-lightbox.is-open .video-lightbox__stage video {
    transform: scale(1);
    opacity: 1;
}
/* iframe（YouTube/Vimeo）：data-orient に応じてサイズ決定 */
.video-lightbox__stage iframe {
    display: block;
    background: #000;
    box-shadow: 0 30px 80px rgba(0,0,0,0.6);
    border: 0;
    transform: scale(0.96);
    opacity: 0;
    transition: transform 0.55s var(--ease), opacity 0.4s var(--ease);
}
.video-lightbox.is-open .video-lightbox__stage iframe {
    transform: scale(1);
    opacity: 1;
}
.video-lightbox.is-landscape .video-lightbox__stage iframe {
    width: min(92vw, calc(86vh * 16 / 9));
    aspect-ratio: 16 / 9;
}
.video-lightbox.is-portrait .video-lightbox__stage iframe {
    height: min(86vh, calc(92vw * 16 / 9));
    aspect-ratio: 9 / 16;
}
.video-lightbox__close {
    position: absolute;
    top: 24px; right: 24px;
    width: 48px; height: 48px;
    background: transparent;
    border: 1px solid rgba(255,255,255,0.3);
    color: rgba(255,255,255,0.85);
    font-size: 24px; line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background 0.3s var(--ease), color 0.3s var(--ease);
}
.video-lightbox__close:hover {
    background: rgba(255,255,255,0.95);
    color: var(--ink);
}
.video-lightbox__caption {
    position: absolute;
    bottom: 24px; left: 50%;
    transform: translateX(-50%);
    color: var(--paper);
    font-family: var(--font-brand);
    font-size: 11px;
    letter-spacing: 0.2em;
    opacity: 0.55;
    pointer-events: none;
    white-space: nowrap;
    max-width: 90vw;
    overflow: hidden;
    text-overflow: ellipsis;
}
@media (max-width: 700px) {
    .video-lightbox__close {
        top: 16px; right: 16px;
        width: 40px; height: 40px;
        font-size: 20px;
    }
}
.work-card__meta {
    display: flex;
    align-items: baseline;
    gap: var(--space-1);
    margin-top: var(--space-1);
}
.work-card__title {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.08em;
    color: var(--ink);
}
.work-card__runtime {
    margin-left: auto;
    font-family: var(--font-brand);
    font-size: 11px;
    color: var(--ink-soft);
    letter-spacing: 0.14em;
}
.work-card__sub {
    font-family: var(--font-jp);
    font-size: 12px;
    color: var(--ink-soft);
    margin-top: 4px;
}

/* ─── VIDEOGRAPHY: SERVICES ─── */
.services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border: 1px solid var(--ink);
}
@media (max-width: 700px) { .services-grid { grid-template-columns: 1fr; } }
.service-card {
    padding: var(--space-3) var(--space-3);
    border-right: 1px solid var(--ink);
    position: relative;
}
.service-card:last-child { border-right: none; }
@media (max-width: 700px) {
    .service-card { border-right: none; border-bottom: 1px solid var(--ink); }
    .service-card:last-child { border-bottom: none; }
}
.service-card__num {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.2em;
    color: var(--ink-soft);
}
.service-card__title {
    font-family: var(--font-jp);
    font-weight: 500;
    font-size: 18px;
    margin: var(--space-1) 0 var(--space-2);
}
.service-card__list {
    list-style: none;
    padding: 0;
    margin: 0;
    font-family: var(--font-jp);
    font-size: 13px;
    line-height: 2;
    color: var(--ink-soft);
}
.service-card__list li::before { content: "—"; color: var(--ink); margin-right: 8px; }

/* ─── VIDEOGRAPHY: FLOW ─── */
.flow-list {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: flow;
}
.flow-step {
    display: grid;
    grid-template-columns: 100px 1fr 120px;
    gap: var(--space-3);
    align-items: flex-start;
    padding: var(--space-3) 0;
    border-bottom: 1px dashed var(--line);
}
.flow-step:last-child { border-bottom: none; }
@media (max-width: 700px) {
    .flow-step { grid-template-columns: 1fr; gap: 8px; }
}
.flow-step__num {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: clamp(28px, 3vw, 36px);
    line-height: 1;
    color: var(--ink);
    letter-spacing: 0.04em;
}
.flow-step__num small {
    display: block;
    font-family: var(--font-brand);
    font-weight: 500;
    font-size: 10px;
    letter-spacing: 0.2em;
    color: var(--ink-soft);
    margin-top: 8px;
}
.flow-step__title {
    font-family: var(--font-jp);
    font-weight: 500;
    font-size: 16px;
    margin-bottom: 6px;
    color: var(--ink);
}
.flow-step__desc {
    font-family: var(--font-jp);
    font-size: 13px;
    line-height: 1.8;
    color: var(--ink-soft);
    margin: 0;
}
.flow-step__duration {
    font-family: var(--font-brand);
    font-size: 11px;
    letter-spacing: 0.18em;
    color: var(--ink-soft);
    text-align: right;
}
@media (max-width: 700px) {
    .flow-step__duration { text-align: left; }
}

/* ─── レスポンシブ ─── */
@media (max-width: 900px) {
    .about-hero { grid-template-columns: 1fr; gap: var(--space-3); }
    .about-hero__image { aspect-ratio: 4/3; }
    .history-block { grid-template-columns: 1fr; gap: var(--space-3); }
    .history-list__item { grid-template-columns: 80px 1fr; gap: var(--space-2); }
    .vg-concept { grid-template-columns: 1fr; gap: var(--space-2); }
    .cta-block__inner { flex-direction: column; align-items: flex-start; text-align: left; }
}

/* ─── CONTACT ページ ─── */
.contact-head {
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--line);
}
.contact-layout {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: var(--space-5);
    align-items: flex-start;
}
@media (max-width: 900px) {
    .contact-layout { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* ─── ご予約の流れ（CONTACT上部） ─── */
.contact-process {
    margin: 0 0 var(--space-5);
    padding: var(--space-3) 0 var(--space-4);
    border-bottom: 1px solid var(--line);
}
.contact-process .eyebrow {
    margin-bottom: var(--space-1);
}
.contact-process__title {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(22px, 2.4vw, 28px);
    letter-spacing: 0.02em;
    margin: 0 0 var(--space-2);
    color: var(--ink);
}
.contact-process__lead {
    font-family: var(--font-jp);
    font-size: 14px;
    line-height: 1.95;
    color: var(--ink);
    margin: 0 0 var(--space-3);
    max-width: 780px;
}
.contact-process__lead b {
    font-weight: 600;
    color: var(--ink);
    background: linear-gradient(transparent 70%, rgba(156,184,212,0.35) 70%);
    padding: 0 2px;
}
.contact-process__steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}
.contact-process__steps li {
    display: flex;
    align-items: baseline;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid var(--line);
    background: var(--paper);
}
.contact-process__steps b {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.22em;
    color: var(--ink-soft);
    flex-shrink: 0;
}
.contact-process__steps span {
    font-family: var(--font-jp);
    font-size: 13px;
    line-height: 1.5;
    color: var(--ink);
}
.contact-process__steps small {
    display: block;
    font-size: 11px;
    color: var(--ink-soft);
    margin-top: 2px;
    letter-spacing: 0;
}
/* PC で改行、SP で改行しないユーティリティ */
.br-pc { display: inline; }
@media (max-width: 900px) {
    .br-pc { display: none; }
    .contact-process {
        padding: var(--space-2) 0 var(--space-3);
        margin-bottom: var(--space-4);
    }
    .contact-process__steps {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }
    .contact-process__steps li {
        padding: 12px 14px;
    }
}
@media (max-width: 500px) {
    .contact-process__steps {
        grid-template-columns: 1fr;
    }
}

/* 連絡先情報サイド */
.contact-info {
    background: var(--paper);
    border: 1px solid var(--line);
    padding: var(--space-3);
}
.contact-info__title {
    font-family: var(--font-jp);
    font-weight: 500;
    font-size: 18px;
    margin: var(--space-1) 0 var(--space-2);
}
.contact-info__lead {
    font-family: var(--font-jp);
    font-size: 13px;
    line-height: 1.9;
    color: var(--ink-soft);
    margin: 0 0 var(--space-2);
}
.contact-info__list {
    margin: 0;
    padding: 0;
}
.contact-info__list dt {
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 10px;
    letter-spacing: 0.2em;
    color: var(--ink-soft);
    padding-top: var(--space-2);
}
.contact-info__list dt:first-child { padding-top: 0; }
.contact-info__list dd {
    font-family: var(--font-jp);
    font-size: 13px;
    color: var(--ink);
    margin: 4px 0 var(--space-2);
    padding-bottom: var(--space-2);
    border-bottom: 1px dashed var(--line);
}
.contact-info__list dd:last-child { border-bottom: none; }
.contact-info__list a {
    border-bottom: 1px solid var(--ink);
    padding-bottom: 1px;
}
.contact-info__note {
    margin-top: var(--space-3);
    padding: var(--space-2);
    background: rgba(255,255,255,0.04);
    border-left: 2px solid var(--ink);
    font-family: var(--font-jp);
    font-size: 12px;
    color: var(--ink-soft);
    line-height: 1.8;
}

/* フォーム共通 */
.contact-form { }
.form-row {
    display: grid;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
}
.form-row--two { grid-template-columns: 1fr 1fr; }
@media (max-width: 600px) { .form-row--two { grid-template-columns: 1fr; } }

.field { margin-bottom: var(--space-3); }
.form-row .field { margin-bottom: 0; }
.field__label {
    display: block;
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.18em;
    color: var(--ink);
    margin-bottom: 8px;
}
.field__label .req { color: var(--note-red); margin-left: 4px; }

.field__input {
    width: 100%;
    border: 1px solid var(--ink);
    background: var(--paper);
    padding: 12px 14px;
    font-family: var(--font-jp);
    font-size: 14px;
    color: var(--ink);
    line-height: 1.6;
    transition: border-color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);
}
.field__input:focus {
    outline: none;
    background: var(--white);
    border-color: var(--ink);
    box-shadow: 0 0 0 3px rgba(0,0,0,0.08);
}
.field__input::placeholder {
    color: var(--ink-faint);
}
.field__input--area {
    resize: vertical;
    min-height: 160px;
    line-height: 1.85;
}

/* ラジオ：チップ風 */
.field__radios {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.radio-chip {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}
.radio-chip input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.radio-chip span {
    font-family: var(--font-jp);
    font-size: 13px;
    color: var(--ink-soft);
    border: 1px solid var(--line);
    padding: 8px 16px;
    border-radius: 999px;
    transition: background var(--duration-fast) var(--ease), color var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
}
.radio-chip:hover span { border-color: var(--ink); color: var(--ink); }
.radio-chip input:checked + span {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
}

/* 同意チェック */
.field--agree { margin-top: var(--space-2); }
.agree-check {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-family: var(--font-jp);
    font-size: 13px;
    color: var(--ink);
}
.agree-check input {
    width: 18px; height: 18px;
    accent-color: var(--ink);
    cursor: pointer;
}

/* エラー */
.field.has-error .field__input,
.field.has-error .field__radios,
.field.has-error .agree-check {
    border-color: var(--note-red);
}
.field.has-error .field__input {
    background: rgba(196, 74, 61, 0.04);
}
.field__error {
    font-family: var(--font-jp);
    font-size: 12px;
    color: var(--note-red);
    margin: 6px 0 0;
    line-height: 1.6;
}
.form-error-banner {
    background: rgba(196, 74, 61, 0.08);
    border: 1px solid var(--note-red);
    color: var(--note-red);
    padding: var(--space-2);
    font-family: var(--font-jp);
    font-size: 13px;
    margin-bottom: var(--space-3);
}

/* 送信ボタン */
.form-submit {
    margin-top: var(--space-3);
}
.form-submit__button {
    background: var(--ink);
    color: var(--paper);
    border: 1px solid var(--ink);
    padding: 16px 36px;
    font-family: var(--font-brand);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.24em;
    cursor: pointer;
    transition: background var(--duration-base) var(--ease), color var(--duration-base) var(--ease);
}
.form-submit__button:hover {
    background: var(--paper);
    color: var(--ink);
}

/* 送信完了メッセージ */
.form-success {
    background: var(--paper);
    border: 1px solid var(--ink);
    padding: var(--space-5);
    text-align: center;
    box-shadow: 4px 4px 0 0 var(--ink);
    max-width: 720px;
    margin: 0 auto;
}
.form-success__title {
    font-family: var(--font-jp);
    font-weight: 500;
    font-size: 20px;
    margin: 0 0 var(--space-2);
    color: var(--ink);
}
.form-success p {
    font-family: var(--font-jp);
    font-size: 14px;
    line-height: 1.9;
    color: var(--ink-soft);
    margin: 0;
}
.form-success__note {
    margin-top: var(--space-3) !important;
    padding-top: var(--space-2);
    border-top: 1px dashed var(--line);
    font-size: 12px !important;
    color: var(--ink-faint) !important;
}
.form-success__note a { color: var(--accent); border-bottom: 1px solid currentColor; }

/* ─── ユーティリティ ─── */
/* モバイル時のみ表示する改行 */
.br-sp { display: none; }
@media (max-width: 700px) {
    .br-sp { display: inline; }
}

/* ─── プライバシーポリシー ─── */
.privacy-doc {
    font-family: var(--font-jp);
    font-size: 14px;
    line-height: 2;
    color: var(--ink);
}
.privacy-doc h2 {
    font-family: var(--font-jp);
    font-weight: 500;
    font-size: 17px;
    margin: var(--space-4) 0 var(--space-2);
    padding-bottom: 8px;
    border-bottom: 1px solid var(--line);
    color: var(--ink);
}
.privacy-doc h2:first-child { margin-top: 0; }
.privacy-doc p { margin: 0 0 var(--space-2); color: var(--ink-soft); }
.privacy-doc ul { margin: 0 0 var(--space-2) 0; padding-left: 1.4em; color: var(--ink-soft); }
.privacy-doc ul li { padding: 3px 0; }
.privacy-doc .privacy-contact {
    margin: var(--space-2) 0;
    padding: var(--space-2);
    background: rgba(255,255,255,0.04);
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 10px 16px;
}
.privacy-doc .privacy-contact dt {
    font-family: var(--font-brand);
    font-size: 11px;
    letter-spacing: 0.18em;
    color: var(--ink-soft);
}
.privacy-doc .privacy-contact dd { margin: 0; color: var(--ink); }
.privacy-doc .privacy-date {
    margin-top: var(--space-4);
    padding-top: var(--space-2);
    border-top: 1px dashed var(--line);
    font-size: 12px;
    color: var(--ink-faint);
    text-align: right;
}

/* ─── 14. 管理画面側の調整（投稿一覧サムネ） ─── */
.column-thumb { width: 90px; }
.column-thumb img { border-radius: 2px; }


/* ════════════════════════════════════════════════════════════
   ▼ 黒バージョン専用 上書きブロック（DARK THEME OVERRIDES）
   ──────────────────────────────────────────────────────────
   既存 CSS は明色テーマ前提で書かれているため、暗背景・
   コントラスト調整が必要なコンポーネントだけここで上書き。
   ════════════════════════════════════════════════════════════ */

/* ページ全体: 暗背景に上書き */
body {
    background: var(--bg);
    color: var(--ink);
    font-family: var(--font-jp);
}

::selection { background: var(--accent); color: var(--bg); }

/* ════════════════════════════════════════════════════════════
   タイポグラフィ（HTML モックに完全準拠）
   ════════════════════════════════════════════════════════════ */

/* === EYEBROW（mock .kicker） === Manrope 11/500/0.32em uppercase + 横線アクセント */
.eyebrow {
    font-family: var(--font-brand) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.32em !important;
    text-transform: uppercase !important;
    color: var(--accent) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
}
.eyebrow::before {
    content: "";
    display: inline-block;
    width: 24px; height: 1px;
    background: var(--accent);
    flex-shrink: 0;
}

/* === DISPLAY 見出し（mock .display / .secHead h2）=== Cormorant Garamond 36px/400/0.03em */
.h-display,
h1.h-display, h2.h-display, h3.h-display {
    font-family: var(--font-display);
    font-size: 36px;
    line-height: 1;
    font-weight: 400;
    letter-spacing: 0.03em;
}
.h-display em {
    font-style: italic;
    color: var(--accent);
    font-weight: 400;
}

/* === 日本語長文見出し（mock .aboutBlock/.vgConcept/.vgPanel h2）=== Noto Serif JP 36px/500/0.06em（clamp で狭幅時に縮小）*/
.about-block__copy .h-display,
.vg-concept .h-display,
.about-hero__copy .h-display,
.video-block__copy .h-display,
.cta-block__title {
    font-family: var(--font-jp-serif);
    font-size: clamp(28px, 3.5vw + 0.5rem, 36px);
    line-height: 1.5;
    font-weight: 500;
    letter-spacing: 0.06em;
    color: var(--ink);
}
.about-block__copy .h-display em,
.about-hero__copy .h-display em {
    font-style: normal;
    color: var(--accent);
}

/* === HERO h1（mock .hero h1）=== Cormorant Garamond 96px/300/0.04em */
.hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.6rem, 7vw, 6rem);
    font-weight: 300;
    line-height: 0.95;
    letter-spacing: 0.04em;
    color: var(--ink);
}

/* === HERO サブ（mock .hero .sub）=== Manrope 13px/0.45em uppercase */
.hero__sub {
    font-family: var(--font-brand);
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.45em;
    text-transform: uppercase;
    color: var(--ink-soft);
    opacity: 1;
}

/* === 本文 日本語（mock .body-jp）=== Noto Sans JP 16px / 1.9 line-height / 0.04em */
.lead,
.lead p,
.about-hero__bio,
.about-hero__bio p,
.vg-concept__right,
.vg-concept__right p,
.section__lead {
    font-family: var(--font-jp);
    font-size: 16px;
    line-height: 1.9;
    letter-spacing: 0.04em;
    color: var(--ink-soft);
    font-weight: 400;
}

/* === ボタン（mock .btn）=== Manrope 12px/500/0.24em uppercase */
.cta-block__button,
.link-arrow,
.form-submit__button,
.contact-info__cta,
.gallery-result__reset {
    font-family: var(--font-brand);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.24em;
    text-transform: uppercase;
}

/* === ナビゲーション（mock .siteHeader nav a）=== Manrope 11px/500/0.22em uppercase */
.site-nav__item a {
    font-family: var(--font-brand);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-soft);
}
.site-nav__item a:hover { color: var(--ink); opacity: 1; }
.site-nav__item.is-current a { color: var(--ink); }

/* === サイトロゴ（mock .siteHeader .brand）=== Cormorant Garamond 28px/500/0.06em */
.site-logo__brand {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 24px;
    letter-spacing: 0.06em;
    color: var(--ink);
}
.site-logo__sub {
    font-family: var(--font-brand);
    font-size: 9px;
    font-weight: 400;
    letter-spacing: 0.3em;
    color: var(--ink-faint);
    text-transform: uppercase;
}

/* === FACTS / HISTORY / 数字（mock .stats .num）=== Cormorant Garamond 48px */
.facts-row__value,
.work-card__runtime {
    font-family: var(--font-display);
}

/* === eyebrow 内 small（FIELD 等の補助ラベル）の色調整 === */
.eyebrow small {
    font-family: var(--font-brand);
    color: var(--ink-faint);
}

/* ─── ヘッダー：暗背景 + ライン ─── */
.site-header { border-bottom: 1px solid var(--line); }

/* ─── ヒーローのテキスト：写真上なので必ず明色 ─── */
.hero__title, .hero__sub, .hero__caption { color: var(--ink); }
.hero__dot { background: rgba(243,239,230,0.3); }
.hero__dot.is-active { background: var(--ink); }

/* ─── ABOUT ブロックのコピー側：暗背景に統一 ─── */
.section--about { background: var(--bg); }
.about-block__copy { background: transparent; color: var(--ink); }

/* ─── カテゴリカード：暗背景上の半透明オーバーレイ ─── */
.cat-card { background: var(--bg-card); }

/* ─── 動画ブロック（TOP の VIDEOGRAPHY プレビュー）：暗背景維持 ─── */
.section--video { background: var(--bg); }
.video-block__media { background: var(--bg-card); }
.video-block__media iframe,
.video-block__media video { background: var(--bg); }
.video-block__copy {
    background: var(--bg-2);
    color: var(--ink);
}
.video-block__copy .eyebrow { color: var(--ink); opacity: 0.55; }
.video-block__copy .h-display { color: var(--ink); }
.video-block__copy .lead { color: var(--ink); opacity: 0.82; }
.video-block__copy .link-arrow {
    color: var(--ink);
    border-bottom-color: rgba(243,239,230,0.4);
}

/* ─── CTA バンド：暗背景にして、ボタンはアクセントブルー ─── */
.cta-block {
    background: var(--bg-2);
    color: var(--ink);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
.cta-block__title { color: var(--ink); }
.cta-block .eyebrow { color: var(--ink); opacity: 0.6; }
.cta-block__button {
    background: var(--accent);
    color: var(--bg);
    border-color: var(--accent);
}
.cta-block__button:hover {
    background: transparent;
    color: var(--accent);
}

/* ─── サイトフッター：暗背景 ─── */
.site-footer {
    background: var(--bg-2);
    color: var(--ink);
    border-top: 1px solid var(--line);
}
.site-footer a { color: var(--ink); opacity: 0.7; }
.site-footer a:hover { opacity: 1; color: var(--accent); }

/* ─── 各種カード／フォーム要素：暗背景にフィット ─── */
.gallery-filter,
.facts-row,
.service-card,
.theme-card,
.work-card {
    background: var(--bg-card);
    border-color: var(--line);
}

/* VIDEOGRAPHY 制作フロー：内側に余白を取り、カード同士に隙間 */
.flow-step {
    background: var(--bg-card);
    border-color: var(--line);
    border-bottom: none !important;
    border-radius: 4px;
    padding: var(--space-3) var(--space-4);
    margin-bottom: var(--space-2);
}
.flow-step:last-child { margin-bottom: 0; }
@media (max-width: 700px) {
    .flow-step { padding: var(--space-3); }
}

/* ABOUT 経歴リスト：内側に余白を取り、カード同士に隙間 */
.history-list__item {
    background: var(--bg-card);
    border-color: var(--line);
    border-bottom: none !important;
    border-radius: 4px;
    padding: var(--space-3) var(--space-4);
    margin-bottom: var(--space-1);
}
.history-list__item:last-child { margin-bottom: 0; }
@media (max-width: 700px) {
    .history-list__item { padding: var(--space-2) var(--space-3); }
}
.filter-chip {
    background: transparent;
    color: var(--ink);
    border-color: var(--line);
}
.filter-chip.is-active {
    background: var(--accent);
    color: var(--bg);
    border-color: var(--accent);
}

/* フォーム入力欄：暗カード風 */
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form input[type="url"],
.contact-form input[type="date"],
.contact-form select,
.contact-form textarea {
    background: var(--bg-card);
    color: var(--ink);
    border: 1px solid var(--line);
}
.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: var(--ink-faint);
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
    outline: none;
    background: var(--bg-soft);  /* 暗背景を維持（白くしない）。テキスト色は --ink のまま */
    color: var(--ink);
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(156, 184, 212, 0.18);  /* アクセント色の薄いリング */
}
.contact-form label {
    color: var(--ink-soft);
}

/* ─── サブ的な明色背景 → 暗背景に置き換え ─── */
.contact-info__note,
.privacy-doc .privacy-contact {
    background: var(--bg-card);
    border-left-color: var(--accent);
}

/* スキップリンク：アクセント色で目立たせる */
.skip-link {
    background: var(--accent);
    color: var(--bg);
}

/* モバイルメニュー：暗背景 */
@media (max-width: 900px) {
    .site-nav {
        background-color: var(--bg) !important;
    }
    body.is-nav-open .site-header {
        background: var(--bg) !important;
    }
    .site-nav__item.is-cta a {
        background: var(--accent);
        color: var(--bg);
        border-color: var(--accent);
    }
}

/* CONTACT サイドバー / フォーム成功メッセージ等：暗背景に */
.contact-info,
.form-success {
    background: var(--bg-card);
    border-color: var(--line);
    color: var(--ink);
}

/* VIDEOGRAPHY ヒーローのキャプション：暗 → アクセント色テキスト */
.vg-hero__caption {
    background: var(--bg);
    color: var(--ink);
    border: 1px solid var(--line);
}
.vg-hero__en { color: var(--ink); }
.vg-hero__ja { color: var(--ink-soft); }

/* 送信ボタン hover の反転：アクセントで上書き */
.form-submit__button:hover {
    background: var(--accent) !important;
    color: var(--bg) !important;
    border-color: var(--accent) !important;
}

/* カテゴリカードの hover ラベル：アクセント色に */
.cat-card:hover .cat-card__more {
    background: var(--accent);
    color: var(--bg);
}

/* テーマ番号ラベル（左上 "01" 等）：暗背景にクリーム文字 */
.theme-card__num {
    background: var(--bg);
    color: var(--ink);
    border: 1px solid var(--line);
}

/* ─── ABOUT 見出し: 強制サイズ指定（モバイルで確実に2行に） ─── */
.about-block__copy .h-display {
    font-size: 30px !important;
}
@media (min-width: 900px) {
    .about-block__copy .h-display {
        font-size: clamp(28px, 2.8vw, 36px) !important;
        white-space: nowrap;
        font-feature-settings: "palt" 1;
    }
}

/* ─── SNSリンク（Instagram） ─── */
/* ヘッダー: ナビ末尾に小さくアウトラインアイコン */
.site-nav__item.is-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px;
    opacity: 0.85;
    color: var(--ink);
    border: none;
}
.site-nav__item.is-social a:hover {
    opacity: 1;
}
.site-nav__item.is-social a::after {
    display: none !important; /* current下線を出さない */
}
.site-nav__item.is-social .icon-social {
    display: block;
    width: 18px;
    height: 18px;
}
@media (max-width: 900px) {
    /* モバイルのオーバーレイ内では他のメニュー項目と並ぶ大きさに */
    .site-nav__item.is-social .icon-social {
        width: 26px;
        height: 26px;
    }
    .site-nav__item.is-social a {
        padding: 8px;
    }
}

/* フッター: ブランドブロック下のSNS行 */
.site-footer__social {
    list-style: none;
    margin: 20px 0 0;
    padding: 0;
    display: flex;
    gap: 18px;
    align-items: center;
}
.site-footer__social a {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--paper);
    opacity: 0.7;
    font-family: var(--font-brand);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.2em;
    transition: opacity var(--duration-fast) var(--ease);
}
.site-footer__social a:hover {
    opacity: 1;
}
.site-footer__social svg {
    flex-shrink: 0;
    transition: transform var(--duration-fast) var(--ease);
}
.site-footer__social a:hover svg {
    transform: translateY(-1px);
}
.site-footer__social-label {
    display: inline-block;
}
@media (max-width: 900px) {
    .site-footer__social {
        margin-top: 16px;
        gap: 14px;
    }
}

/* ─── CONTACT ページ ─── 暗背景でのコントラスト調整 ─── */

/* Contact. 見出しの em（青いイタリック）→ 隣の「ご予約の流れ」と同色（クリーム）に統一 */
.contact-head .h-display em {
    color: var(--ink);
}

/* ご予約の流れ：4ステップ枠はクリーム背景→暗カード背景に。文字が見えるよう色も明示 */
.contact-process__steps li {
    background: var(--bg-card);
    border-color: var(--line);
}
.contact-process__steps b { color: var(--ink); opacity: 0.7; }
.contact-process__steps span { color: var(--ink); }
.contact-process__steps small { color: var(--ink-soft); }

/* 同意チェックのラベル：ブラウザのチェック状態描画でラベル背景に色が乗り、
   クリーム文字が消える事例があるため、ラベル自体に暗背景を明示して上書きする */
.field--agree { margin-top: var(--space-3); }
.agree-check {
    display: inline-flex !important;
    align-items: center;
    gap: 12px;
    background-color: var(--bg-card) !important;
    color: var(--ink) !important;
    padding: 10px 14px;
    border: 1px solid var(--line);
}
.agree-check > span,
.agree-check > span * {
    color: var(--ink) !important;
    background: transparent !important;
}
.agree-check input[type="checkbox"] {
    accent-color: var(--accent);
    width: 16px;
    height: 16px;
    margin: 0;
}
/* プライバシーポリシーへのリンク：アクセント色＋下線で「リンクと分かる」見た目 */
.agree-check__link {
    color: var(--accent) !important;
    border-bottom: 1px solid currentColor;
    padding-bottom: 1px;
    transition: opacity var(--duration-fast) var(--ease);
}
.agree-check__link:hover {
    opacity: 0.7;
}

/* 送信ボタン：クリーム背景+クリーム文字で見えないため、アクセント青で反転 */
.form-submit__button {
    background: var(--accent) !important;
    color: var(--bg) !important;
    border-color: var(--accent) !important;
}
.form-submit__button:hover {
    background: transparent !important;
    color: var(--accent) !important;
    border-color: var(--accent) !important;
}

/* ─── GALLERY: 縦/横フィルター（ALL / 横 / 縦）─── */
/* アクティブ時にクリーム背景+クリーム文字で真っ白になるので、アクセント青に反転 */
.orient-chip.is-active {
    background: var(--accent);
    color: var(--bg);
    border-color: var(--accent);
}
.orient-chip:hover {
    border-color: var(--accent);
}

/* ラジオチップ（お問い合わせ種別）も同じ問題があるので同様に反転 */
.radio-chip input:checked + span {
    background: var(--accent);
    color: var(--bg);
    border-color: var(--accent);
}
.radio-chip:hover span {
    border-color: var(--accent);
    color: var(--ink);
}

/* 黒バージョン上書きブロック ここまで */
