/* ================================================================
   Floating Booking Button - フロントエンドスタイル
   ================================================================ */

/* ----------------------------------------------------------------
   CSS カスタムプロパティ（デフォルト値）
   実際の値は wp_head から出力されるインラインスタイルで上書きされる
   ---------------------------------------------------------------- */
:root {
	--fbb-bg:        #06C755;
	--fbb-color:     #FFFFFF;
	--fbb-font-size: 16px;
	--fbb-padding-v: 14px;
	--fbb-padding-h: 24px;
	--fbb-offset-x:  24px;
	--fbb-offset-y:  24px;
}

/* ----------------------------------------------------------------
   ラッパー（fixed 配置）
   ---------------------------------------------------------------- */
.fbb-wrapper {
	position: fixed;
	z-index: 9999;
	transition: opacity 0.3s ease, transform 0.3s ease;
	/* GPU レイヤー昇格でスクロール時のちらつきを防ぐ */
	will-change: opacity, transform;
}

/* 四隅のポジション */
.fbb-position-bottom-right { bottom: var(--fbb-offset-y); right:  var(--fbb-offset-x); }
.fbb-position-bottom-left  { bottom: var(--fbb-offset-y); left:   var(--fbb-offset-x); }
.fbb-position-top-right    { top:    var(--fbb-offset-y); right:  var(--fbb-offset-x); }
.fbb-position-top-left     { top:    var(--fbb-offset-y); left:   var(--fbb-offset-x); }

/* ----------------------------------------------------------------
   ボタン本体
   ---------------------------------------------------------------- */
.fbb-button {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: var(--fbb-padding-v) var(--fbb-padding-h);
	background-color: var(--fbb-bg);
	color: var(--fbb-color);
	font-size: var(--fbb-font-size);
	font-weight: bold;
	line-height: 1.4;
	border-radius: 50px;
	text-decoration: none !important;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
	cursor: pointer;
	/* アニメーションと hover のトランジション */
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

/* ページロード時のスライドイン（位置に連動） */
.fbb-position-bottom-right .fbb-button,
.fbb-position-bottom-left  .fbb-button {
	animation: fbb-slide-in-up 0.4s ease-out forwards;
}

.fbb-position-top-right .fbb-button,
.fbb-position-top-left  .fbb-button {
	animation: fbb-slide-in-down 0.4s ease-out forwards;
}

/* hover: 3px 浮き上がり */
.fbb-button:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.30);
	color: var(--fbb-color) !important;
	text-decoration: none !important;
}

/* active: 押した感触 */
.fbb-button:active {
	transform: scale(0.97);
	transition-duration: 0.1s;
}

/* フォーカス（キーボード操作アクセシビリティ） */
.fbb-button:focus-visible {
	outline: 3px solid #005fcc;
	outline-offset: 3px;
}

/* ----------------------------------------------------------------
   アイコン
   ---------------------------------------------------------------- */
.fbb-icon {
	font-size: 1.1em;
	line-height: 1;
	flex-shrink: 0;
}

/* ----------------------------------------------------------------
   非表示クラス（スクロール閾値制御）
   ---------------------------------------------------------------- */
.fbb-hidden {
	opacity: 0 !important;
	pointer-events: none !important;
}

/* 下から出るときは下にずらして非表示 */
.fbb-position-bottom-right.fbb-hidden,
.fbb-position-bottom-left.fbb-hidden {
	transform: translateY(20px);
}

/* 上から出るときは上にずらして非表示 */
.fbb-position-top-right.fbb-hidden,
.fbb-position-top-left.fbb-hidden {
	transform: translateY(-20px);
}

/* ----------------------------------------------------------------
   モバイル / PC 非表示
   ---------------------------------------------------------------- */
@media (max-width: 768px) {
	.fbb-hide-mobile {
		display: none !important;
	}
}

@media (min-width: 769px) {
	.fbb-hide-desktop {
		display: none !important;
	}
}

/* ----------------------------------------------------------------
   キーフレーム
   ---------------------------------------------------------------- */
@keyframes fbb-slide-in-up {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fbb-slide-in-down {
	from {
		opacity: 0;
		transform: translateY(-30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ----------------------------------------------------------------
   ショートコード埋め込み版（fixed ではなくインライン）
   ---------------------------------------------------------------- */
.fbb-button.fbb-shortcode {
	position: static;
	display: inline-flex;
	animation: none;
}
