@charset "utf-8";
/**
 * ============================================================================
 * com-vendor-lightbox.css
 * ============================================================================
 * 
 * 【目的】
 * Lightbox プラグインのスタイルを提供。
 * 画像を拡大表示するライトボックス機能。
 * 
 * 【使用ページ】
 * Lightbox を使用する全ページ
 * - 写真ギャラリー
 * - 由緒写真
 * - 祭事写真
 * など
 * 
 * 【依存関係】
 * - JavaScript: /js/lightbox.min.js
 * - 画像:
 *   - /i/lightbox/loading.gif
 *   - /i/lightbox/prev.png
 *   - /i/lightbox/next.png
 *   - /i/lightbox/close.png
 * 
 * 【読み込み順序】
 * 10番目以降（最後）
 * 
 * 【主要な機能】
 * 1. オーバーレイ (.lightboxOverlay)
 *    - 背景を黒の半透明に
 *    - z-index: 9999
 * 
 * 2. ライトボックス (.lightbox)
 *    - 拡大画像表示
 *    - z-index: 10000
 * 
 * 3. ナビゲーション (.lb-nav)
 *    - 前へ/次へボタン
 *    - ホバーで表示
 * 
 * 4. データコンテナ (.lb-dataContainer)
 *    - キャプション、閉じるボタン
 * 
 * 【注意事項】
 * - このファイルは外部ライブラリ（Lightbox）のスタイルです
 * - 画像パスは /i/lightbox/ に依存
 * - iOS 対応のため html.lb-disable-scrolling が必要
 * - ミニファイ後は vendor-lightbox.css にリネームされます
 * 
 * 【変更履歴】
 * 2025-10-20: lightbox.css から改名・ドキュメント追加
 * 
 * 【ライセンス】
 * Lightbox by Lokesh Dhakar
 * https://lokeshdhakar.com/projects/lightbox2/
 * 
 * ============================================================================
 */


/* ============================================================================
   html.lb-disable-scrolling - スクロール無効化
   ----------------------------------------------------------------------------
   Lightbox 表示中はスクロールを無効化します。
   
   【iOS 対応】
   position: fixed が必須（overflow: hidden だけでは不十分）
   ============================================================================ */

html.lb-disable-scrolling {
  overflow: hidden;
  /* Position fixed required for iOS. Just putting overflow: hidden; on the body is not enough. */
  position: fixed;
  height: 100vh;
  width: 100vw;
}


/* ============================================================================
   .lightboxOverlay - オーバーレイ
   ----------------------------------------------------------------------------
   画像拡大時の背景オーバーレイ。
   
   【スタイル】
   - 背景色: 黒
   - 透明度: 0.8
   - z-index: 9999
   ============================================================================ */

.lightboxOverlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9999;
  background-color: black;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
  opacity: 0.8;
  display: none;
}


/* ============================================================================
   .lightbox - ライトボックス本体
   ----------------------------------------------------------------------------
   拡大画像を表示するコンテナ。
   
   【スタイル】
   - z-index: 10000（オーバーレイより上）
   - 中央寄せ
   ============================================================================ */

.lightbox {
  position: absolute;
  left: 0;
  width: 100%;
  z-index: 10000;
  text-align: center;
  line-height: 0;
  font-weight: normal;
}

.lightbox .lb-image {
  display: block;
  height: auto;
  max-width: inherit;
  max-height: none;
  border-radius: 3px;

  /* Image border */
  border: 4px solid white;
}

.lightbox a img {
  border: none;
}


/* ============================================================================
   .lb-outerContainer - 外側コンテナ
   ----------------------------------------------------------------------------
   画像の外側のコンテナ。
   トランジション中の背景色を提供。
   ============================================================================ */

.lb-outerContainer {
  position: relative;
  width: 250px;
  height: 250px;
  margin: 0 auto;
  border-radius: 4px;

  /* Background color behind image.
     This is visible during transitions. */
  background-color: white;
}

.lb-outerContainer:after {
  content: "";
  display: table;
  clear: both;
}


/* ============================================================================
   .lb-loader - ローディング表示
   ----------------------------------------------------------------------------
   画像読み込み中の表示。
   
   【画像】
   /i/lightbox/loading.gif
   ============================================================================ */

.lb-loader {
  position: absolute;
  top: 43%;
  left: 0;
  height: 25%;
  width: 100%;
  text-align: center;
  line-height: 0;
}

.lb-cancel {
  display: block;
  width: 32px;
  height: 32px;
  margin: 0 auto;
  background: url(/i/lightbox/loading.gif) no-repeat;
}


/* ============================================================================
   .lb-nav - ナビゲーション
   ----------------------------------------------------------------------------
   前へ/次へのナビゲーションボタン。
   
   【動作】
   - デフォルト: 透明（opacity: 0）
   - ホバー: 表示（opacity: 1）
   
   【画像】
   - 前へ: /i/lightbox/prev.png
   - 次へ: /i/lightbox/next.png
   ============================================================================ */

.lb-nav {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 10;
}

.lb-container > .nav {
  left: 0;
}

.lb-nav a {
  outline: none;
  background-image: url('data:image/gif;base64,R0lGODlhAQABAPAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==');
}

.lb-prev, .lb-next {
  height: 100%;
  cursor: pointer;
  display: block;
}

.lb-nav a.lb-prev {
  width: 34%;
  left: 0;
  float: left;
  background: url(/i/lightbox/prev.png) left 48% no-repeat;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
  opacity: 0;
  -webkit-transition: opacity 0.6s;
  -moz-transition: opacity 0.6s;
  -o-transition: opacity 0.6s;
  transition: opacity 0.6s;
}

.lb-nav a.lb-prev:hover {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
  opacity: 1;
}

.lb-nav a.lb-next {
  width: 64%;
  right: 0;
  float: right;
  background: url(/i/lightbox/next.png) right 48% no-repeat;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
  opacity: 0;
  -webkit-transition: opacity 0.6s;
  -moz-transition: opacity 0.6s;
  -o-transition: opacity 0.6s;
  transition: opacity 0.6s;
}

.lb-nav a.lb-next:hover {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
  opacity: 1;
}


/* ============================================================================
   .lb-dataContainer - データコンテナ
   ----------------------------------------------------------------------------
   キャプションと閉じるボタンを表示。
   ============================================================================ */

.lb-dataContainer {
  margin: 0 auto;
  padding-top: 5px;
  width: 100%;
  border-bottom-left-radius: 4px;
  border-bottom-right-radius: 4px;
}

.lb-dataContainer:after {
  content: "";
  display: table;
  clear: both;
}

.lb-data {
  padding: 0 4px;
  color: #ccc;
}

.lb-data .lb-details {
  width: 85%;
  float: left;
  text-align: left;
  line-height: 1.1em;
}

.lb-data .lb-caption {
  font-size: 13px;
  font-weight: bold;
  line-height: 1em;
}

.lb-data .lb-caption a {
  color: #4ae;
}

.lb-data .lb-number {
  display: block;
  clear: left;
  padding-bottom: 1em;
  font-size: 12px;
  color: #999999;
}

.lb-data .lb-close {
  display: block;
  float: right;
  width: 30px;
  height: 30px;
  background: url(/i/lightbox/close.png) top right no-repeat;
  text-align: right;
  outline: none;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
  opacity: 0.7;
  -webkit-transition: opacity 0.2s;
  -moz-transition: opacity 0.2s;
  -o-transition: opacity 0.2s;
  transition: opacity 0.2s;
}

.lb-data .lb-close:hover {
  cursor: pointer;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
  opacity: 1;
}
