/*
Theme Name:       Balloon Party Studio
Theme URI:        https://example.com/balloon-party-studio
Author:           Balloon Party Studio
Author URI:       https://example.com
Description:      面向气球派对与活动场景布置业务的现代 WordPress 区块主题（FSE）。基于 theme.json + templates/parts + patterns 构建，温暖、明亮、梦幻、高级，不依赖任何页面构建器。
Version:          1.1.0
Tested up to:     6.9
Requires at least: 6.4
Requires PHP:     7.4
License:          GNU General Public License v2 or later
License URI:      http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:      balloon-party-studio
Tags:             full-site-editing, block-patterns, block-styles, wide-blocks, custom-colors, custom-logo, featured-images, threaded-comments, translation-ready
*/

/* =========================================================================
   说明
   ------------------------------------------------------------------------
   主要视觉样式由 theme.json 输出。
   本文件仅承担三件事：
   1. 自定义 block styles 的具体 CSS 实现（is-style-eyebrow 等）
   2. theme.json 无法覆盖的微交互（hover/focus/transitions）
   3. 几个组件级的辅助类（.bps-*）
   ========================================================================= */

/* ---------- Reset & Base微调 ---------- */

html {
	scroll-behavior: smooth;
	scroll-padding-top: 80px;
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after {
		animation-duration: 0.001ms !important;
		transition-duration: 0.001ms !important;
	}
}

::selection {
	background-color: var(--wp--preset--color--primary-soft);
	color: var(--wp--preset--color--contrast);
}

/* Accessible focus ring */
:where(a, button, .wp-block-button__link, input, select, textarea):focus-visible {
	outline: 2px solid var(--wp--preset--color--accent);
	outline-offset: 3px;
	border-radius: 4px;
}

/* Skip link for accessibility */
.skip-link {
	position: absolute;
	left: -9999px;
	z-index: 9999;
	background: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--base);
	padding: 0.6rem 1rem;
	border-radius: 0 0 8px 0;
	text-decoration: none;
}
.skip-link:focus {
	left: 0;
	top: 0;
}

/* ---------- Custom block styles: is-style-eyebrow ----------
   小型分类标签（例如 "OUR SERVICES"、"01 · STEP"）
*/
.is-style-eyebrow {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--small);
	font-weight: 500;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--wp--preset--color--accent);
}

/* ---------- Custom block styles: is-style-card-soft ----------
   带阴影的圆角卡片
*/
.is-style-card-soft {
	background-color: var(--wp--preset--color--base);
	border-radius: 20px;
	box-shadow: 0 4px 20px rgba(46, 35, 38, 0.05);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.is-style-card-soft:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 32px rgba(46, 35, 38, 0.09);
}

/* ---------- Custom block styles: is-style-card-bordered ----------
   带细边线的卡片（适合服务列表）
*/
.is-style-card-bordered {
	background-color: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--accent-soft);
	border-radius: 20px;
	transition: border-color 0.3s ease, transform 0.3s ease;
}
.is-style-card-bordered:hover {
	border-color: var(--wp--preset--color--primary);
	transform: translateY(-2px);
}

/* ---------- Custom block styles: is-style-quote-elegant ----------
   高级评价引文，无传统左边线、上方有装饰引号
*/
.wp-block-quote.is-style-quote-elegant {
	border-left: none;
	padding-left: 0;
	position: relative;
	padding-top: 2.5rem;
}
.wp-block-quote.is-style-quote-elegant::before {
	content: "\201C";
	position: absolute;
	top: -0.3em;
	left: 0;
	font-family: var(--wp--preset--font-family--serif);
	font-size: 5rem;
	line-height: 1;
	color: var(--wp--preset--color--primary);
	opacity: 0.7;
}

/* ---------- 服务流程：连接线 ---------- */
.bps-process .wp-block-columns {
	position: relative;
}
@media (min-width: 782px) {
	.bps-process .wp-block-columns::before {
		content: "";
		position: absolute;
		top: 1.6rem;
		left: 8%;
		right: 8%;
		height: 1px;
		background-image: linear-gradient(
			to right,
			var(--wp--preset--color--accent-soft) 0,
			var(--wp--preset--color--accent-soft) 6px,
			transparent 6px,
			transparent 12px
		);
		background-size: 12px 1px;
		z-index: 0;
	}
	.bps-process .wp-block-column {
		position: relative;
		z-index: 1;
		background-color: var(--wp--preset--color--base);
		padding: 0 .6rem;
	}
}

/* ---------- 数字编号样式（取代 emoji） ---------- */
.bps-numeral {
	font-family: var(--wp--preset--font-family--serif);
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1;
	color: var(--wp--preset--color--accent);
	letter-spacing: 0.02em;
}

/* ---------- 价格卡片：大数字 ---------- */
.bps-price-number {
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(2rem, 4vw, 2.6rem);
	font-weight: 500;
	line-height: 1.1;
}
.bps-price-number .bps-price-unit {
	font-family: var(--wp--preset--font-family--sans);
	font-size: 1rem;
	font-weight: 400;
	color: var(--wp--preset--color--muted);
	margin-left: .25rem;
}

/* ---------- 价格卡片"推荐"高亮 ---------- */
.bps-price-card-featured {
	position: relative;
}
.bps-price-card-featured::before {
	content: "推荐";
	position: absolute;
	top: -.7rem;
	left: 50%;
	transform: translateX(-50%);
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--base);
	font-size: .72rem;
	font-weight: 500;
	letter-spacing: 0.16em;
	padding: 0.3rem 0.9rem;
	border-radius: 999px;
}

/* ---------- 评价：作者头像圆 ---------- */
.bps-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--wp--preset--color--primary-soft);
	color: var(--wp--preset--color--accent);
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.1rem;
	font-weight: 500;
}

/* ---------- 5 星评分 ---------- */
.bps-rating {
	display: inline-flex;
	gap: 0.15rem;
	color: var(--wp--preset--color--accent);
	font-size: .95rem;
	letter-spacing: 0.1em;
}

/* ---------- FAQ details/summary 美化 ---------- */
.bps-faq details {
	background-color: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--accent-soft);
	border-radius: 14px;
	padding: 1.1rem 1.4rem;
	margin-bottom: 0.8rem;
	transition: border-color .3s ease, background-color .3s ease;
}
.bps-faq details[open] {
	border-color: var(--wp--preset--color--primary);
	background-color: var(--wp--preset--color--surface);
}
.bps-faq summary {
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.1rem;
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	color: var(--wp--preset--color--contrast);
}
.bps-faq summary::-webkit-details-marker { display: none; }
.bps-faq summary::after {
	content: "+";
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.5rem;
	color: var(--wp--preset--color--accent);
	transition: transform .3s ease;
	line-height: 1;
}
.bps-faq details[open] summary::after {
	content: "−";
}
.bps-faq details > *:not(summary) {
	margin-top: 0.9rem;
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
	line-height: 1.85;
}

/* ---------- 联系表单占位字段 ---------- */
.bps-form-field {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	margin-bottom: 1rem;
}
.bps-form-field label {
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--muted);
	letter-spacing: 0.02em;
}
.bps-form-field input,
.bps-form-field select,
.bps-form-field textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid var(--wp--preset--color--accent-soft);
	border-radius: 10px;
	background: var(--wp--preset--color--base);
	font-family: inherit;
	font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--contrast);
	transition: border-color .25s ease;
}
.bps-form-field input:focus,
.bps-form-field select:focus,
.bps-form-field textarea:focus {
	outline: none;
	border-color: var(--wp--preset--color--primary);
}

/* ---------- 导航 hover ---------- */
.wp-block-navigation .wp-block-navigation-item__content {
	transition: opacity .2s ease, color .2s ease;
}
.wp-block-navigation .wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--accent);
}

/* ---------- Outline button line refinement ---------- */
.wp-block-button.is-style-outline > .wp-block-button__link {
	border-width: 1.5px;
	transition: background-color .25s ease, color .25s ease, border-color .25s ease;
}
.wp-block-button.is-style-outline > .wp-block-button__link:hover {
	background-color: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--base);
	border-color: var(--wp--preset--color--contrast);
}

/* ---------- 通用 cover 文本可读性 ---------- */
.wp-block-cover .wp-block-heading,
.wp-block-cover h1,
.wp-block-cover h2 {
	text-wrap: balance;
}

/* ---------- 图片圆角默认 ---------- */
.wp-block-post-featured-image img {
	border-radius: 16px;
}
