/* ===== 自動個人履歷頁專用樣式（現代科技風格） ===== */

html {
	height: 100%;
	overflow: hidden;
}

:root {
	font-size: 16px;
	--x-pg-bg: #f8f9fb;
	--x-pg-nav: #0f172a;
	--x-pg-nav-accent: #334155;
	--x-pg-surface: #ffffff;
	--x-pg-border: #e8ecf1;
	--x-pg-text: #1e293b;
	--x-pg-text-muted: #64748b;
	--x-pg-radius: 12px;
	--x-pg-radius-sm: 8px;
	--x-pg-radius-lg: 16px;
	--x-pg-radius-xl: 20px;
	--x-pg-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
	--x-pg-shadow-md: 0 4px 16px -2px rgba(15, 23, 42, 0.06), 0 2px 8px -2px rgba(15, 23, 42, 0.04);
	--x-pg-shadow-lg: 0 10px 32px -4px rgba(15, 23, 42, 0.08), 0 4px 16px -4px rgba(15, 23, 42, 0.04);
	--x-pg-shadow-card: 0 2px 8px rgba(0, 0, 0, 0.04), 0 8px 24px -4px rgba(0, 0, 0, 0.06);
	--x-pg-shadow-card-hover: 0 4px 12px rgba(0, 0, 0, 0.05), 0 12px 32px -4px rgba(0, 0, 0, 0.08);
	--x-pg-shadow-elevated: 0 4px 16px rgba(0, 0, 0, 0.05), 0 16px 40px -8px rgba(0, 0, 0, 0.1);
	--x-pg-scrollbar-thumb: rgba(15, 23, 42, 0.12);
	--x-pg-scrollbar-thumb-hover: rgba(15, 23, 42, 0.2);
	--x-pg-edit-accent: #434f84;
	--x-pg-section-gap: 2px;
	--x-pg-scroll-padding: 1rem;
	--x-pg-inner-padding: 1rem;
	--x-pg-row-inner-padding: 1rem;
	--x-pg-title-font-size: 1.25rem;
	--x-pg-title-font-weight: 600;
	--x-pg-title-border-width: 2px;
	--x-pg-title-border-color: var(--x-pg-border);
	--x-pg-row-border: none;
	--x-pg-divider-color: transparent;
}

.te-space {
	display: block;
	width: 100%;
	padding: 0;
	margin: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
}

.h-20px {
	height: 20px !important;
	min-height: 20px !important;
}

.h-40px {
	height: 40px !important;
	min-height: 40px !important;
}

.h-60px {
	height: 60px !important;
	min-height: 60px !important;
}

.h-80px {
	height: 80px !important;
	min-height: 80px !important;
}

.h-100px {
	height: 100px !important;
	min-height: 100px !important;
}

.h-120px {
	height: 120px !important;
	min-height: 120px !important;
}

/* 按鈕 loading indicator：依 data-kt-indicator 切換，僅 "on" 時顯示 progress（請稍候） */
.btn[data-kt-indicator] .indicator-label,
.btn.indicator .indicator-label {
	display: inline-flex;
	align-items: center;
}
.btn[data-kt-indicator] .indicator-progress,
.btn.indicator .indicator-progress {
	display: none !important;
	align-items: center;
}
.btn[data-kt-indicator="off"] .indicator-progress,
.btn[data-kt-indicator]:not([data-kt-indicator="on"]) .indicator-progress,
.btn.indicator:not([data-kt-indicator="on"]) .indicator-progress {
	display: none !important;
}
.btn[data-kt-indicator="on"] .indicator-label,
.btn.indicator[data-kt-indicator="on"] .indicator-label {
	display: none;
}
.btn[data-kt-indicator="on"] .indicator-progress,
.btn.indicator[data-kt-indicator="on"] .indicator-progress {
	display: inline-flex !important;
}

/* 來自xlead.css */
.carousel-indicators [data-bs-target] {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: 0;
  }
  
  .carousel-indicators [data-bs-target].active {
	width: 40px;
	border-radius: 10px;
  
  }
  .top-n-5px{
	top: -5px;
  }
  .top-n-10px {
	top: -10px;
  }
  .top-n-15px {
	top: -15px;
  }
  
  .top-70px {
	top: 70px;
  }
  
  .top-20px {
	top: 20px;
  }
  .start-5px{
	left: 5px;
  }
  .start-8px{
	left: 8px;
  }
  input[type="number"] {
	MozAppearance: textfield;
	WebkitAppearance: none;
	appearance: textfield;
  }
  
  
  .ellipsis {
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	white-space: normal;
	overflow: hidden;
  }
  
  .ellipsis1 {
	-webkit-line-clamp: 1;
  }
  
  .ellipsis2 {
	-webkit-line-clamp: 2 !important;
  }
  
  .ellipsis3 {
	-webkit-line-clamp: 3;
  }
  
  .ellipsis4 {
	-webkit-line-clamp: 4;
  }
  
  hr,
  .text-97 {
	color: #979797;
  }
  
  .message.error {
	background-color: #d83030;
	width: 100%;
	z-index: 101;
	position: relative;
	padding: .85rem;
	color: #fff;
	text-align: center;
	font-weight: 900;
	font-size: 1.5rem;
  }
  
  .lh-reset {
	line-height: initial;
  }
  .fz12 {
	font-size: 12px !important;
  }
  
  .fz13 {
	font-size: 13 !important;
  }
  
  .w-22px {
	width: 22px !important;
  }

  .w-40px {
	width: 40px !important;
  }

  .w-60px {
	width: 60px !important;
  }

  .w-80px {
	width: 80px !important;
  }

  .w-100px {
	width: 100px !important;
  }

  .w-120px {
	width: 120px !important;
  }
  
  .w-70 {
	width: 70%;
  }
  
  .mw-60 {
	max-width: 60% !important;
  }
  
  .mw-70 {
	max-width: 70% !important;
  }
p:last-child{
	margin-bottom: 0;
  }
/* 來自 xlead.css結束 */

.show-dev-info {
	position: fixed;
	top: 12px;
	right: 12px;
	z-index: 2147483647;
	background: rgba(0, 0, 0, 0.75);
	color: #fff;
	padding: 6px 10px;
	border-radius: 999px;
	font-size: 12px;
	line-height: 1;
}
.x-pg-app-body {
	background-color: var(--x-pg-bg);
	padding: 0;
	margin: 0;
	height: 100%;
	min-height: 100vh;
	overflow: hidden;
}

#root {
	display: flex;
	flex-direction: column;
	height: 100%;
	min-height: 100vh;
	overflow: hidden;
}

/* ── 有 main-nav 時：鎖定 window scroll + 讓 #root 精確填滿 nav 以下空間 ──
   問題根源：#root 的 flex:1 會讓它長至 100vh，但 sticky nav 佔了 ~60px，
   導致 root 底部 60px 超出 viewport 且內部捲動無法觸及（版權等底部內容被切）。
   同時 html 沒有 overflow:hidden 時，瀏覽器允許 window 捲動，sticky nav 就會蓋住 toolbar。
   修法：鎖定 html 捲動 + 把 #root 高度設為 100vh - nav高度(60px)，完全填滿可視區域。 */
html:has(.x-pg-app-body) {
	overflow: hidden; /* 阻止 window scroll，防止 sticky nav 蓋住 toolbar */
}
html:has(.x-pg-app-body) #root {
	height: calc(100vh - 60px); /* 60px ≈ .main-nav 高度（padding 12+12 + logo 34 + border 1） */
	min-height: 0;               /* 覆蓋 min-height:100vh，讓高度精確由 calc 決定 */
}

/* ===== 捲軸：淡色、細、支援 iOS（-webkit） ===== */
.x-pg-app-body ::-webkit-scrollbar,
.x-pg-edit-section form::-webkit-scrollbar,
.x-pg-edit-scroll::-webkit-scrollbar,
.x-pg-page-scroll::-webkit-scrollbar,
.x-pg-nav-top .dropdown-menu::-webkit-scrollbar,
.x-pg-main-nav .dropdown-menu::-webkit-scrollbar,
.x-pg-collapse-content::-webkit-scrollbar,
.x-pg-alert-dialog-body::-webkit-scrollbar {
	width: 6px;
	height: 6px;
}
.x-pg-app-body ::-webkit-scrollbar-track,
.x-pg-edit-section form::-webkit-scrollbar-track,
.x-pg-edit-scroll::-webkit-scrollbar-track,
.x-pg-page-scroll::-webkit-scrollbar-track,
.x-pg-nav-top .dropdown-menu::-webkit-scrollbar-track,
.x-pg-main-nav .dropdown-menu::-webkit-scrollbar-track,
.x-pg-alert-dialog-body::-webkit-scrollbar-track {
	background: transparent;
}
.x-pg-app-body ::-webkit-scrollbar-thumb,
.x-pg-edit-section form::-webkit-scrollbar-thumb,
.x-pg-edit-scroll::-webkit-scrollbar-thumb,
.x-pg-page-scroll::-webkit-scrollbar-thumb,
.x-pg-nav-top .dropdown-menu::-webkit-scrollbar-thumb,
.x-pg-main-nav .dropdown-menu::-webkit-scrollbar-thumb,
.x-pg-alert-dialog-body::-webkit-scrollbar-thumb {
	background: var(--x-pg-scrollbar-thumb);
	border-radius: 3px;
	-webkit-border-radius: 3px;
}
.x-pg-app-body ::-webkit-scrollbar-thumb:hover,
.x-pg-edit-section form::-webkit-scrollbar-thumb:hover,
.x-pg-edit-scroll::-webkit-scrollbar-thumb:hover,
.x-pg-page-scroll::-webkit-scrollbar-thumb:hover,
.x-pg-alert-dialog-body::-webkit-scrollbar-thumb:hover {
	background: var(--x-pg-scrollbar-thumb-hover);
}
.x-pg-edit-section form,
.x-pg-edit-scroll,
.x-pg-page-scroll,
.x-pg-nav-top .dropdown-menu,
.x-pg-main-nav .dropdown-menu,
.x-pg-alert-dialog-body {
	-webkit-overflow-scrolling: touch;
}

/* 共用隱藏工具（避免被 Bootstrap 斷點類別覆蓋） */
.x-pg-hidden {
	display: none !important;
}

/* ===== 固定工具列（白底，參考 linenamecard.com） ===== */
.x-pg-main-nav {
	z-index: 1050;
	background-color: #fff;
	box-shadow: 0 1px 0 0 rgba(0, 0, 0, 0.03), 0 2px 6px -2px rgba(0, 0, 0, 0.05), 0 4px 16px -4px rgba(0, 0, 0, 0.06);
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

/* Bootstrap 5 Modal 層級：需高於固定導覽列（1050） */
.modal-backdrop {
	z-index: 1060;
}
.modal {
	z-index: 1065;
}

/* quest-drop-modal 須高於 x-pg-main-nav (1050)；若仍被蓋住，請將 modal 以 portal 掛到 body */
.quest-drop-modal {
	z-index: 9999 !important;
	position: fixed !important;
}

.x-pg-nav-top {
	flex-shrink: 0;
	background-color: #fff;
	padding: 0.625rem 1.25rem;
	min-height: auto;
}
.x-pg-nav-top .x-pg-nav-brand {
	color: var(--x-pg-text);
	font-size: 1.1rem;
	font-weight: 600;
}
.x-pg-nav-top .x-pg-nav-brand:hover {
	color: var(--x-pg-text);
}
.x-pg-nav-top .x-pg-nav-account {
	color: var(--x-pg-text) !important;
}
.x-pg-nav-top .x-pg-nav-account:hover {
	color: var(--x-pg-nav-accent) !important;
}
.x-pg-nav-top #btnDevState,
.x-pg-nav-top #btnDevState i,
.x-pg-nav-top #btnDevState span,
.x-pg-nav-top .custom-dropdown-toggle,
.x-pg-nav-top .custom-dropdown-toggle i,
.x-pg-nav-top .custom-dropdown-toggle span {
	color: var(--x-pg-text);
}
.x-pg-nav-buttons {
	flex-shrink: 0;
	background: var(--x-pg-surface);
	border-top: 1px solid var(--x-pg-border);
	box-shadow: var(--x-pg-shadow);
}

.x-pg-nav-buttons .btn {
	font-size: 0.9375rem;
	font-weight: 500;
	padding: 0.5rem 0.875rem;
	border-radius: var(--x-pg-radius-sm);
	transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.x-pg-nav-buttons .btn i {
	font-size: 1.05em;
}

.x-pg-nav-buttons .btn-outline-light i {
	color: var(--x-pg-nav);
	transition: color 0.15s ease;
}

.x-pg-nav-buttons .btn-outline-light:hover i {
	color: #fff;
}

@media (min-width: 992px) {
	.x-pg-nav-buttons > div {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 0.5rem;
		max-width: 1400px;
		margin: 0 auto;
	}
	.x-pg-nav-buttons .btn-outline-light {
		border-color: var(--x-pg-border);
		color: var(--x-pg-text);
	}
	.x-pg-nav-buttons .btn-outline-light:hover {
		background-color: var(--x-pg-nav-accent);
		border-color: var(--x-pg-nav-accent);
		color: #fff;
	}
	.x-pg-nav-buttons #publishLinkGroup .btn-outline-primary {
		border-color: var(--x-pg-nav);
		color: var(--x-pg-nav);
	}
	.x-pg-nav-buttons #publishLinkGroup .btn-outline-primary i {
		color: var(--x-pg-nav);
		transition: color 0.15s ease;
	}
	.x-pg-nav-buttons #publishLinkGroup .btn-outline-primary:hover {
		background-color: var(--x-pg-nav);
		border-color: var(--x-pg-nav);
		color: #fff;
	}
	.x-pg-nav-buttons #publishLinkGroup .btn-outline-primary:hover i {
		color: #fff;
	}
}

@media (max-width: 991px) {
	.x-pg-nav-top {
		padding: 0.75rem 1rem !important;
	}
	
	.x-pg-nav-top .x-pg-logo-container span {
		font-size: 1rem !important;
	}
	
	.x-pg-nav-top .x-pg-logo-container img {
		height: 32px !important;
		margin-right: 8px !important;
	}
	
	.x-pg-nav-buttons {
		padding: 0.75rem 1rem !important;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		background-color: #fff !important;
		border-top: 1px solid rgba(0, 0, 0, 0.1) !important;
	}
	
	.x-pg-nav-buttons .btn {
		font-size: 0.95rem;
		padding: 0.4rem 0.75rem;
		white-space: nowrap;
		flex-shrink: 0;
	}
	
	.x-pg-nav-buttons .btn-outline-light {
		border-color: var(--x-pg-nav) !important;
		color: var(--x-pg-nav) !important;
	}
	.x-pg-nav-buttons .btn-outline-light:hover {
		background-color: var(--x-pg-nav) !important;
		color: #fff !important;
	}
	
	.x-pg-nav-buttons .btn i {
		margin-right: 0.25rem;
	}
}

.x-pg-logo-container {
	display: flex;
	align-items: center;
	text-decoration: none;
}

.x-pg-logo-container img {
	height: 40px;
	margin-right: 12px;
	object-fit: contain;
}

.x-pg-logo-container span {
	color: #fff;
	font-size: 1.25rem;
	font-weight: 600;
}

/* ===== 插入和移動控制 ===== */
.x-pg-insert-controls {
	margin-top: 1rem;
}

/* Dropdown 選單 z-index 提高，避免被導航欄遮擋 */
.x-pg-main-nav .dropdown-menu {
	z-index: 1060 !important;
}

/* 帳戶下拉選單：不超出螢幕，限制高度與水平範圍 */
.x-pg-nav-top .dropdown-menu {
	max-height: calc(100vh - 100px);
	overflow-y: auto;
	max-width: min(280px, calc(100vw - 1rem));
	left: auto;
	right: 0;
}

/* 發佈區「連結」下拉選單位置（仿帳戶 Custom Dropdown，不蓋住按鈕） */
.x-pg-nav-buttons #publishLinkGroup {
	position: relative;
}

.x-pg-nav-buttons #publishLinkGroup .dropdown-menu {
	position: absolute;
	right: 0;
	top: calc(100% + 0.5rem);
	margin-top: 0;
}

.x-pg-section-toolbar {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0;
	padding: 0.875rem 1.25rem;
	margin: 0;
	background: #e0efff;
	border-bottom: 1px solid rgba(30, 64, 175, 0.12);
	box-shadow: 0 1px 0 0 rgba(255, 255, 255, 0.6) inset;
	flex-shrink: 0;
}
.x-pg-edit-section .x-pg-edit-form-zone {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	background: #fff;
	border-radius: 0;
}
.x-pg-edit-panel-tabs.nav-tabs {
	border-bottom: 1px solid var(--bs-gray-200);
	padding: 0 0 0 0.5rem;
	gap: 0;
}
.x-pg-edit-panel-tabs .nav-link {
	border: none;
	border-bottom: 2px solid transparent;
	border-radius: 0;
	padding: 0.5rem 0.75rem;
	font-size: 0.875rem;
	color: var(--bs-gray-600);
	background: transparent;
}
.x-pg-edit-panel-tabs .nav-link:hover {
	color: var(--x-pg-nav, #5463a5);
	border-color: transparent;
}
.x-pg-edit-panel-tabs .nav-link.active {
	color: var(--x-pg-nav, #5463a5);
	font-weight: 600;
	border-bottom-color: var(--x-pg-nav, #5463a5);
	background: transparent;
}
.x-pg-section-toolbar-label {
	font-weight: 600;
	font-size: 0.9375rem;
	letter-spacing: 0.01em;
	color: #1e3a5f;
}
.x-pg-section-toolbar-actions {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
	padding: 1rem;
	border-radius: 16px;
	background: #fff;
}
.x-pg-section-toolbar-divider {
	margin: 0.5rem 0 0.625rem;
	border: none;
	border-top: 1px solid rgba(30, 64, 175, 0.18);
	width: 100%;
}
.x-pg-section-toolbar-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.125rem;
	height: 2.125rem;
	padding: 0;
	border: none;
	border-radius: 8px;
	font-size: 0.9375rem;
	cursor: pointer;
	transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}
.x-pg-section-toolbar-btn:disabled {
	opacity: 0.45;
	cursor: not-allowed;
	filter: grayscale(0.3);
}
.x-pg-section-toolbar-btn-up,
.x-pg-section-toolbar-btn-down {
	background-color: #1d4ed8;
	color: #fff;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
.x-pg-section-toolbar-btn-up:hover:not(:disabled),
.x-pg-section-toolbar-btn-down:hover:not(:disabled) {
	background-color: #1e40af;
	box-shadow: 0 2px 8px rgba(29, 78, 216, 0.35);
	transform: translateY(-0.5px);
}
.x-pg-section-toolbar-btn-up:active:not(:disabled),
.x-pg-section-toolbar-btn-down:active:not(:disabled) {
	transform: translateY(0);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}
.x-pg-section-toolbar-btn-delete {
	background-color: #dc3545;
	color: #fff;
	border: none;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}
.x-pg-section-toolbar-btn-delete:hover {
	background-color: #bb2d3b;
	box-shadow: 0 2px 8px rgba(220, 53, 69, 0.35);
	transform: translateY(-0.5px);
	color: #fff;
}
.x-pg-section-toolbar-btn-delete:active {
	transform: translateY(0);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}
.x-pg-section-toolbar-switch {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}
.x-pg-section-toolbar-switch .form-check-input {
	cursor: pointer;
}
.x-pg-section-toolbar-switch .form-check-label {
	cursor: pointer;
	color: #1e3a5f;
	font-weight: 500;
	margin-bottom: 0;
}
.x-pg-switch {
	display: inline-flex;
	align-items: center;
	cursor: pointer;
	user-select: none;
	vertical-align: middle;
}
.x-pg-switch .x-pg-switch-track {
	display: inline-block;
	width: 2.25rem;
	height: 1.25rem;
	border-radius: 999px;
	background-color: #ced4da;
	transition: background-color 0.2s ease;
	position: relative;
}
.x-pg-switch[aria-checked="true"] .x-pg-switch-track {
	background-color: #34c759;
}
.x-pg-switch .x-pg-switch-thumb {
	position: absolute;
	top: 2px;
	left: 2px;
	width: calc(1.25rem - 4px);
	height: calc(1.25rem - 4px);
	border-radius: 50%;
	background-color: #fff;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
	transition: transform 0.2s ease;
}
.x-pg-switch[aria-checked="true"] .x-pg-switch-thumb {
	transform: translateX(1rem);
}
.x-pg-switch:focus {
	outline: none;
}
.x-pg-switch:focus-visible .x-pg-switch-track {
	box-shadow: 0 0 0 2px #0d6efd;
}
.x-pg-switch[aria-checked="false"] .x-pg-switch-track {
	background-color: #d7dee7;
}
.x-pg-section-toolbar-btn-add {
	background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%);
	color: #fff;
	box-shadow: 0 1px 3px rgba(37, 99, 235, 0.25);
}
.x-pg-section-toolbar-btn-add:hover {
	background: linear-gradient(180deg, #3b82f6 0%, #2563eb 100%);
	box-shadow: 0 2px 10px rgba(37, 99, 235, 0.4);
	transform: translateY(-0.5px);
}
.x-pg-section-toolbar-btn-add:active {
	transform: translateY(0);
}
.x-pg-edit-placeholder {
	padding: 2rem 1rem;
}

.x-pg-section-order-list {
	padding: 1rem 1.25rem;
}
.x-pg-section-order-list-title {
	font-weight: 600;
	font-size: 0.9375rem;
	color: #1e3a5f;
	margin-bottom: 0.25rem;
}
.x-pg-section-order-list-hint {
	margin-bottom: 0.75rem;
}
.x-pg-section-order-list-items {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.x-pg-section-order-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 0.75rem;
	background: #fff;
	border: 1px solid rgba(0, 0, 0, 0.08);
	border-radius: 8px;
	cursor: default;
	transition: box-shadow 0.15s ease, opacity 0.15s ease;
}
.x-pg-section-order-item[draggable="true"] {
	cursor: grab;
}
.x-pg-section-order-item[draggable="true"]:active {
	cursor: grabbing;
}
.x-pg-section-order-item.is-dragging {
	opacity: 0.5;
}
.x-pg-section-order-item.is-drop-target {
	box-shadow: 0 0 0 2px rgba(29, 78, 216, 0.4);
}
.x-pg-section-order-item-handle {
	display: inline-flex;
	align-items: center;
	color: #6b7280;
	font-size: 1rem;
	flex-shrink: 0;
}
.x-pg-section-order-item-handle .bi-grip-vertical {
	pointer-events: none;
}
.x-pg-section-order-item-label {
	flex: 1;
	min-width: 0;
	font-size: 0.875rem;
	color: #374151;
}
.x-pg-section-order-item:not([draggable="true"]) .x-pg-section-order-item-label {
	font-weight: 500;
}

.x-pg-edit-section-draggable {
	transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}
.x-pg-edit-section-draggable[draggable="true"] {
	cursor: grab;
}
.x-pg-edit-section-draggable[draggable="true"]:active {
	cursor: grabbing;
}
.x-pg-edit-section-draggable.is-dragging {
	opacity: 0.5;
}
.x-pg-edit-section-draggable.is-drop-target {
	position: relative;
	padding-top: 60px;
}
.x-pg-edit-section-draggable.is-drop-target::before {
	content: "插入於此";
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	min-height: 56px;
	border: 2px dashed #2563eb;
	border-radius: 6px;
	background-color: rgba(37, 99, 235, 0.08);
	font-size: 0.875rem;
	color: #2563eb;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 500;
}

.x-pg-edit-section-drop-end {
	min-height: 56px;
	margin-top: 6px;
	border-radius: 8px;
	border: 2px dashed rgba(0, 0, 0, 0.1);
	transition: border-color 0.2s ease, background-color 0.2s ease, min-height 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.875rem;
	color: #6b7280;
}
.x-pg-edit-section-drop-end.is-drop-target {
	border-color: #2563eb;
	background-color: rgba(37, 99, 235, 0.12);
	min-height: 56px;
	color: #2563eb;
}
.x-pg-edit-section-drop-end.is-drop-target::after {
	content: "插入於此";
}

.x-pg-insert-block-trigger {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	margin: 10px 0;
	padding: 12px 1rem;
	border: 2px dashed rgba(0, 0, 0, 0.2);
	border-radius: 8px;
	background: rgba(0, 0, 0, 0.02);
	color: #6b7280;
	font-size: 0.875rem;
	cursor: pointer;
	transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}
.x-pg-insert-block-trigger:hover {
	border-color: #2563eb;
	background-color: rgba(37, 99, 235, 0.06);
	color: #1d4ed8;
}
.x-pg-insert-block-trigger:focus {
	outline: none;
}
.x-pg-insert-block-trigger:focus-visible {
	outline: 2px solid #2563eb;
	outline-offset: 2px;
}
.x-pg-insert-block-trigger i {
	font-size: 1.1rem;
}

.x-pg-edit-empty-state {
	padding: 0 0.25rem;
}
.x-pg-theme-color-inline {
	padding-top: 1rem;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}
.x-pg-theme-color-inline .x-pg-section-order-list-title {
	font-weight: 600;
	font-size: 0.9375rem;
	color: #1e3a5f;
	margin-bottom: 0.5rem;
}
.x-pg-theme-preset-btn {
	cursor: pointer;
	padding: 0;
	flex-shrink: 0;
	transition: transform 0.15s, box-shadow 0.15s;
}
.x-pg-theme-preset-btn:hover {
	transform: scale(1.08);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}
.x-pg-theme-color-content .x-pg-style-block:last-child {
	margin-bottom: 1rem;
}
.x-pg-theme-color-mode-cards {
	margin-top: 0.25rem;
}
.x-pg-theme-mode-preset,
.x-pg-theme-mode-custom {
	width: 48px;
	height: 24px;
	border-radius: 2px;
	background: linear-gradient(135deg, #e5e7eb 0%, #cbd5e1 100%);
}
.x-pg-theme-mode-custom {
	background:
		linear-gradient(135deg, rgba(129, 140, 248, 0.3) 0%, rgba(236, 72, 153, 0.3) 100%),
		#ffffff;
}

/* ===== Icon 顏色 ===== */
.x-pg-form-block i,
.x-pg-form-group i,
.x-pg-experience-item i,
.x-pg-description-toolbar i,
.x-pg-page-section i {
	color: #fff;
}
.x-pg-form-group i.bi-file-earmark-image{
	color: var(--x-pg-nav);
}
.x-pg-edit-section .x-pg-form-group i.bi-file-earmark-image {
	color: var(--x-pg-edit-accent);
}

.x-pg-form-block .btn i,
.x-pg-form-group .btn i {
	color: inherit;
	padding-right: 0;
}
.x-pg-form-group .btn-outline-primary,
.x-pg-form-block .btn-outline-primary {
	color: var(--x-pg-nav);
	border-color: var(--x-pg-nav);
}
.x-pg-form-group .btn-outline-primary:hover i,
.x-pg-form-block .btn-outline-primary:hover i {
	color: #fff;
}
.x-pg-form-group .btn-outline-primary:hover,
.x-pg-form-block .btn-outline-primary:hover {
	background-color: var(--x-pg-nav);
	border-color: var(--x-pg-nav);
	color: #fff;
}

.x-pg-description-toolbar button i {
	color: var(--x-pg-text-muted);
}

.x-pg-description-toolbar button:hover i {
	color: var(--x-pg-nav);
}

.x-pg-tabgroup {
	margin-bottom: 1.5rem;
	padding: 0;
	background: transparent;
	box-shadow: none;
}
.x-pg-tabgroup-nav {
	margin-bottom: 0.75rem;
	border-bottom: 1px solid var(--x-pg-border, #e8ecf1);
	display: flex;
	justify-content: center;
	gap: 2rem;
}
.x-pg-tabgroup-body {
	padding: 0;
}

.x-pg-tabgroup-nav .nav-link {
	border: none;
	border-bottom: 2px solid transparent;
	border-radius: 0;
	background: transparent;
	color: var(--x-pg-text-muted, #6c757d);
	padding: 0.35rem 0.75rem;
	font-size: 0.9rem;
	cursor: pointer;
	margin-bottom: -1px;
}
.x-pg-tabgroup-nav .nav-link:hover {
	color: var(--bs-body-color);
}
.x-pg-tabgroup-nav .nav-link.active {
	color: var(--bs-primary);
	border-bottom-color: var(--bs-primary);
	font-weight: 500;
}

.x-pg-tabgroup-edit {
	margin-bottom: 1.5rem;
	border: 1px solid rgba(148, 163, 184, 0.7);
	border-radius: 8px;
	background-color: #f9fafb;
}
.x-pg-tabgroup-edit-header {
	background-color: #4b5563;
	color: #ffffff;
	border-bottom: 1px solid rgba(55, 65, 81, 0.9);
}
.x-pg-tabgroup-title-input {
	max-width: 200px;
}
.x-pg-tabgroup-edit-body {
	padding: 0.75rem 4px 1rem;
	position: relative;
}
.x-pg-tabbody-drag-overlay {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	z-index: 10;
	pointer-events: none;
}
.x-pg-tabbody-drag-overlay.x-pg-tabbody-drag-overlay-active {
	pointer-events: auto;
}
.x-pg-tabgroup-edit-body .x-pg-edit-section-draggable {
	position: relative;
	z-index: 3;
}
.x-pg-tab-move-actions {
	display: flex;
	flex-direction: column;
	gap: 0;
	line-height: 1;
}
.x-pg-tab-move-actions .x-pg-tab-move-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.15rem 0.25rem;
	line-height: 1;
}
.x-pg-tab-move-actions .x-pg-tab-move-btn:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}
.x-pg-tabgroup-drop-zone {
	position: relative;
	z-index: 2;
	min-height: 56px;
	margin: 0.25rem 0;
	padding: 0.5rem 0.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px dashed rgba(148, 163, 184, 0.5);
	border-radius: 6px;
	background: rgba(241, 245, 249, 0.8);
	color: #64748b;
	font-size: 0.875rem;
	transition: border-color 0.15s, background-color 0.15s;
	pointer-events: auto;
}
.x-pg-tabgroup-drop-zone.is-drop-target {
	border-color: var(--bs-primary, #0d6efd);
	background: rgba(13, 110, 253, 0.08);
	color: var(--bs-primary, #0d6efd);
}
.x-pg-tabgroup-edit-body .x-pg-tabgroup-drop-zone.x-pg-tabgroup-drop-zone-idle {
	min-height: 6px;
	margin: 2px 0;
	padding: 0;
	border-color: transparent;
	background: transparent;
	color: transparent;
	font-size: 0;
	overflow: hidden;
}
.x-pg-tabgroup-edit-body .x-pg-tabgroup-drop-zone.x-pg-tabgroup-drop-zone-idle.is-drop-target {
	min-height: 56px;
	padding: 0.5rem 0.75rem;
	margin: 0.25rem 0;
	border-color: var(--bs-primary, #0d6efd);
	background: rgba(13, 110, 253, 0.08);
	color: var(--bs-primary, #0d6efd);
	font-size: 0.875rem;
	overflow: visible;
}
.x-pg-tabgroup-drop-above {
	min-height: 56px;
	margin: 0.25rem 0;
	padding: 0.5rem 0.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px dashed rgba(148, 163, 184, 0.5);
	border-radius: 6px;
	background: rgba(241, 245, 249, 0.8);
	color: #64748b;
	font-size: 0.875rem;
}
.x-pg-tabgroup-drop-above.is-drop-target {
	border-color: var(--bs-primary, #0d6efd);
	background: rgba(13, 110, 253, 0.08);
	color: var(--bs-primary, #0d6efd);
}
.x-pg-tabgroup-edit.is-dragging {
	opacity: 0.7;
}
.x-pg-tabgroup-edit.is-drop-target {
	box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.6);
}
.x-pg-tabgroup-actions .x-pg-tabgroup-icon {
	color: #4b5563;
}
.x-pg-tabgroup-actions .x-pg-tabgroup-icon i {
	color: inherit;
}
.x-pg-tabgroup-actions .x-pg-tabgroup-icon:hover {
	background-color: rgba(55, 65, 81, 0.08);
	color: #111827;
}

.x-pg-tabgroup-area {
	margin-bottom: 1rem;
	border: 1px solid rgba(148, 163, 184, 0.6);
	border-radius: 8px;
	overflow: hidden;
	background-color: #f1f5f9;
}
.x-pg-tabgroup-area-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.5rem 0.75rem;
	background: linear-gradient(135deg, #e0e7ff 0%, #c7d2fe 100%);
	color: #3730a3;
	font-weight: 600;
	border-bottom: 1px solid rgba(148, 163, 184, 0.4);
}
.x-pg-tabgroup-area-title {
	font-size: 0.95rem;
	flex: 1;
	text-align: center;
}
.x-pg-tabgroup-settings-panel {
	padding: 0.75rem 1rem;
	background-color: #fff;
	border-bottom: 1px solid rgba(148, 163, 184, 0.3);
}

.x-pg-event-intro-block {
	padding: 0;
}
.x-pg-event-intro-leading {
	color: var(--x-pg-text-muted);
	font-size: 0.8125rem;
	letter-spacing: 0.02em;
	margin-bottom: 0.35rem;
}
.x-pg-event-intro-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 0.5rem;
}
.x-pg-event-intro-title {
	margin-bottom: 0;
	font-weight: 700;
	font-size: 1.3125rem;
	line-height: 1.35;
	letter-spacing: -0.01em;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-event-intro-section-label {
	color: var(--x-pg-text-muted);
	font-size: 0.8125rem;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	margin-top: 0.5rem;
	margin-bottom: 0;
}
.x-pg-event-intro-divider {
	margin: 0.625rem 0 1rem;
	border: 0;
	height: 1px;
	background: linear-gradient(to right, transparent, var(--x-pg-border, #e2e8f0) 8%, var(--x-pg-border, #e2e8f0) 92%, transparent);
	opacity: 0.9;
}
.x-pg-event-intro-html {
	position: relative;
	font-size: 0.9375rem;
	line-height: 1.65;
	color: var(--x-pg-text, #334155);
	padding: 1rem 0 0;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none' stroke='%2364748b' stroke-opacity='0.12' stroke-width='0.6'%3E%3Ccircle cx='20' cy='16' r='2'/%3E%3Ccircle cx='48' cy='28' r='1.5'/%3E%3Ccircle cx='12' cy='44' r='1'/%3E%3Ccircle cx='60' cy='52' r='2'/%3E%3Ccircle cx='36' cy='68' r='1.2'/%3E%3Cpath d='M8 24 Q24 16 40 24 T72 32'/%3E%3Cpath d='M4 48 Q28 56 52 48'/%3E%3C/g%3E%3C/svg%3E");
	background-repeat: repeat;
	background-size: 80px 80px;
	background-position: 0 0;
}
.x-pg-event-intro-html p:last-child {
	margin-bottom: 0;
}
.x-pg-row.x-pg-row-event-intro {
	position: relative;
}
.x-pg-event-intro-row-inner {
	position: relative;
}
.x-pg-event-intro-badge {
	position: absolute;
	top: 2.25rem;
	left: 0;
	z-index: 2;
	width: 2rem;
	height: 5.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border-radius: 0 0.375rem 0.375rem 0;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.15em;
	writing-mode: vertical-rl;
	text-orientation: upright;
	background: linear-gradient(180deg, #dc2626 0%, #b91c1c 100%);
	color: #fff;
	box-shadow: 2px 0 8px rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(0, 0, 0, 0.06) inset;
	line-height: 1.2;
}
.x-pg-event-intro-badge::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 0 0.375rem 0.375rem 0;
	border: 1px solid rgba(255, 255, 255, 0.25);
	pointer-events: none;
}
.x-pg-event-intro-meta-list {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--x-pg-border, #e2e8f0);
}
.x-pg-event-intro-meta-row {
	display: flex;
	gap: 0.625rem;
	align-items: baseline;
	margin-bottom: 0.375rem;
}
.x-pg-event-intro-meta-row:last-child {
	margin-bottom: 0;
}
.x-pg-event-intro-meta-label {
	min-width: 4.75rem;
	font-size: 0.8125rem;
	color: var(--x-pg-text-muted, #64748b);
}
.x-pg-event-intro-meta-label.text-muted {
	color: var(--x-pg-text-muted, #64748b);
}
.x-pg-event-intro-meta-value {
	font-size: 0.9375rem;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-event-intro-meta-separator {
	margin: 0 0.25rem;
}
.x-pg-event-intro-meta-list-wrapper {
	position: relative;
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--x-pg-border, #e2e8f0);
}
.x-pg-event-intro-meta-list-wrapper .x-pg-event-intro-meta-list {
	margin-top: 0;
	padding-top: 0;
	border-top: none;
}
.x-pg-event-intro-content > .d-flex.position-relative.w-100 .countdown-preview-hint,
.x-pg-event-intro-meta-list-wrapper .countdown-preview-hint,
.form-block-preview-session .countdown-preview-hint {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: 11px;
	line-height: 1.2;
	background: rgba(0, 0, 0, 0.25);
	color: #fff;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	cursor: default;
}
.x-pg-event-intro-content > .d-flex.position-relative.w-100 .countdown-preview-hint i,
.x-pg-event-intro-meta-list-wrapper .countdown-preview-hint i,
.form-block-preview-session .countdown-preview-hint i {
	font-size: 13px;
	opacity: 0.9;
}
.x-pg-event-intro-content > .d-flex.position-relative.w-100 .countdown-preview-hint span,
.x-pg-event-intro-meta-list-wrapper .countdown-preview-hint span,
.form-block-preview-session .countdown-preview-hint span {
	white-space: nowrap;
}
.x-pg-event-intro-content > .d-flex.position-relative.w-100 .countdown-preview-hint {
	position: static;
	right: auto;
	top: auto;
	transform: none;
	margin-top: 0.5rem;
}
.x-pg-event-intro-content {
	position: relative;
	min-height: 1.5rem;
}
.x-pg-preview-content-wrapper .x-pg-event-intro-content[data-editor-preview-section="true"] {
	padding: 0.5rem 0.75rem;
	margin: -0.5rem -0.75rem 0;
	border-radius: 0;
	outline: 1px solid transparent;
	box-shadow: none;
	transition: outline 0.2s ease, box-shadow 0.2s ease;
}
.form-block-preview-session .countdown-preview-hint{
	top:20px;
	right:8px;
}
.form-block-preview-session .countdown-preview-hint.form-block-preview-hint-pill {
	background: rgba(0, 0, 0, 0.25) !important;
	color: #fff !important;
}
.form-block-preview-session .countdown-preview-hint.form-block-preview-hint-pill i,
.form-block-preview-session .countdown-preview-hint.form-block-preview-hint-pill span {
	color: #fff !important;
}
.form-block-preview-session .countdown-preview-hint.form-block-preview-hint-pill-gift {
	background: #b8bcc1 !important;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
}
/* 表單區塊模擬示意：姓名、電郵、立即送出 + 模擬示意 icon */
.mock-form-inner {
	
}
.mock-form-inner .survey-toolbar{
	border-top: none !important;
	justify-content: center;
}
.mock-form-inner .mock-form-group {
	margin-bottom: 12px;
}
.mock-form-inner .mock-form-group label {
	display: block;
	margin-bottom: 4px;
	font-size: 14px;
}
.mock-form-inner .mock-input {
	width: 100%;
	padding: 8px 10px;
	border-radius: 4px;
	border: 1px solid rgba(0, 0, 0, 0.2);
	font-size: 14px;
	background: rgba(255, 255, 255, 0.5);
}
.mock-form-inner .mock-submit-btn {
	margin-top: 8px;
	padding: 10px 16px;
	border-radius: 4px;
	border: none;
	background: linear-gradient(135deg, #ff7a32, #ff4b4b);
	color: #fff;
	font-size: 15px;
	font-weight: 600;
	cursor: default;
}
/* tooltip 改由 JS 掛到 body（position:fixed）避免被外層 overflow:hidden 裁切，此處不再用 ::after/::before */
.countdown-preview-hint-tooltip-fixed {
	position: fixed;
	z-index: 99999;
	padding: 6px 10px;
	border-radius: 6px;
	background: rgba(0, 0, 0, 0.85);
	color: #fff;
	font-size: 11px;
	line-height: 1.4;
	white-space: normal;
	max-width: 280px;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
	pointer-events: none;
	transform: translateX(-100%);
}
.countdown-preview-hint-tooltip-fixed::before {
	content: "";
	position: absolute;
	right: 10px;
	top: 0;
	transform: translateY(-100%);
	border-width: 5px;
	border-style: solid;
	border-color: transparent transparent rgba(0, 0, 0, 0.85) transparent;
}

/* ===== 兩欄佈局容器（整頁不捲動，僅編輯表單與預覽內容區可捲動） ===== */
.x-pg-layout-container {
	display: flex !important;
	flex-direction: row;
	gap: 1.5rem;
	flex: 1;
	min-height: 0;
	height: calc(100vh - 140px);
	padding: 1rem;
	overflow: hidden;
	
	margin: 100px auto 0;
	width: 100%;
	box-sizing: border-box;
}

@media (max-width: 991px) {
	.x-pg-layout-container {
		margin-top: 100px;
		height: calc(100vh - 100px);
		padding: 0;
	}
}

@media (max-width: 1199px) {
	.x-pg-layout-container {
		flex-direction: column;
		height: calc(100vh - 100px);
		min-height: 0;
		padding: 0.5rem;
		margin-top: 100px;
	}
}

/* ===== 左編輯 + 右即時預覽（捲動編輯時預覽自動對齊） ===== */
.x-pg-layout-container.x-pg-edit-left-preview-right {
	display: flex;
	flex-direction: column;
	padding: 0;
	margin: 0;
	height: calc(100vh - 50.5px);
	min-height: 0;
	overflow: hidden;
	width: 100%;
	flex: 1;
	gap: 0;
}
.x-pg-unified-toolbar {
	flex-shrink: 0;
	background: var(--x-pg-surface);
	border-bottom: 1px solid var(--x-pg-border);
	box-shadow: var(--x-pg-shadow);
	min-height: 52px;
}
.x-pg-unified-toolbar.x-pg-toolbar-right {
	border: 1px solid rgba(0, 0, 0, 0.06);
	margin-bottom: 0.5rem;
	padding-left: 1rem;
	padding-right: 1rem;
	box-shadow: var(--x-pg-shadow-card);
}
.x-pg-edit-left-preview-right .x-pg-preview-main .x-pg-unified-toolbar.x-pg-toolbar-right {
	width: 100%;
	box-sizing: border-box;
}
.x-pg-unified-toolbar .x-pg-toolbar-btn {
	border-radius: var(--x-pg-radius-sm);
	font-size: 0.8125rem;
	padding: 0.35rem 0.65rem;
	height: 31px;
	min-height: 31px;
	display: inline-flex;
	align-items: center;
}
.x-pg-toolbar-divider {
	width: 1px;
	height: 24px;
	background: var(--x-pg-border);
	flex-shrink: 0;
}
.x-pg-layout-body {
	flex: 1;
	min-height: 0;
	overflow: hidden;
	display: flex;
	flex-direction: row;
	gap: 0;
	padding: 0;
	background: var(--x-pg-bg);
}
.x-pg-edit-left-preview-right .x-pg-edit-section {
	flex: 0 0 400px;
	width: 400px;
	min-width: 280px;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: #fff;
	border-right: 1px solid rgba(0, 0, 0, 0.08);
}

.x-pg-cropper-circle .cropper-view-box,
.x-pg-cropper-circle .cropper-face {
	border-radius: 50%;
}
.x-pg-cropper-rounded .cropper-view-box,
.x-pg-cropper-rounded .cropper-face {
	border-radius: 12px;
}
.x-pg-cropper-transparent {
	background-color: #f8fafc;
	background-image: linear-gradient(45deg, #e5e7eb 25%, transparent 25%),
		linear-gradient(-45deg, #e5e7eb 25%, transparent 25%),
		linear-gradient(45deg, transparent 75%, #e5e7eb 75%),
		linear-gradient(-45deg, transparent 75%, #e5e7eb 75%);
	background-size: 20px 20px;
	background-position: 0 0, 0 10px, 10px -10px, -10px 0;
}
.x-pg-cropper-transparent .cropper-canvas,
.x-pg-cropper-transparent .cropper-view-box {
	background-color: transparent;
}
.x-pg-cropper-transparent .cropper-bg {
	background: transparent;
}
.x-pg-edit-left-preview-right .x-pg-edit-scroll {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}
.x-pg-edit-left-preview-right .x-pg-edit-form-zone {
	border-radius: 0;
}
.x-pg-edit-left-preview-right .x-pg-preview-main {
	flex: 1;
	min-width: 0;
	min-height: 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: transparent;
}
.x-pg-edit-left-preview-right .x-pg-preview-main .x-pg-preview-content-wrapper {
	flex: 1;
	min-height: 0;
}
.x-pg-edit-left-preview-right .x-pg-preview-content-wrapper {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	overflow-x: auto;
	display: flex;
	position: relative;
	justify-content: center;
	align-items: flex-start;
	padding:  1rem 2rem 2rem 2rem;
	scrollbar-gutter: stable both-edges;
	-webkit-overflow-scrolling: touch;
	background: var(--x-pg-bg);
}
.x-pg-edit-left-preview-right .x-pg-device-selector-wrap {
	align-items: center;
	height: 31px;
}
.x-pg-edit-left-preview-right .x-pg-device-selector-label {
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--x-pg-text-muted);
	line-height: 1;
}
.x-pg-edit-left-preview-right .x-pg-device-selector {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: var(--x-pg-border);
	border-radius: 6px;
	padding: 4px 8px;
	height: 30px;
}
.x-pg-edit-left-preview-right .x-pg-unified-toolbar .device-btn {
	color: var(--x-pg-text-muted);
	background: transparent;
	border: none;
	border-radius: 4px;
	padding: 0 0.4rem;
	height: 20px;
	min-width: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.x-pg-edit-left-preview-right .x-pg-unified-toolbar .device-btn i {
	color: inherit;
	font-size: 0.9rem;
}
.x-pg-edit-left-preview-right .x-pg-unified-toolbar .device-btn:hover {
	background: rgba(0, 0, 0, 0.06);
	color: var(--x-pg-text);
}
.x-pg-edit-left-preview-right .x-pg-unified-toolbar .device-btn.active {
	background: #d1e7dd;
	color: #0f5132;
	border: 1px solid #0f5132;
	box-shadow: none;
}
.x-pg-edit-left-preview-right .x-pg-unified-toolbar .device-btn.active i {
	color: #0f5132;
}
.x-pg-edit-left-preview-right .x-pg-preview-frame {
	flex-shrink: 0;
	background: var(--x-pg-surface);
	border-radius: 0;
	box-shadow: var(--x-pg-shadow-card);
	overflow: hidden;
	transition: width 0.2s ease;
	min-height: 400px;
	min-height: max(400px, 100%);
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
	transform: translateZ(0);
}
.x-pg-edit-left-preview-right .x-pg-preview-content-wrapper {
	align-items: stretch;
}
.x-pg-edit-left-preview-right .x-pg-preview-content-wrapper:has(.x-pg-preview-frame.desktop) {
	overflow-x: hidden;
}
.x-pg-edit-left-preview-right .x-pg-preview-frame.desktop {
	width: 100%;
	max-width: none;
}
.x-pg-edit-left-preview-right .x-pg-preview-frame.tablet {
	width: 768px;
}
.x-pg-edit-left-preview-right .x-pg-preview-frame.mobile {
	width: 375px;
}
.x-pg-edit-left-preview-right .x-pg-page-scroll {
	flex: 1 1 auto;
	min-height: 0;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	padding: 0;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
}
.x-pg-section-outer {
	width: 100%;
	box-sizing: border-box;
}
.x-pg-edit-left-preview-right .x-pg-page-scroll .x-pg-page-inner {
	flex: 1 0 auto;
	min-height: 0;
	box-sizing: border-box;
	margin-left: 0;
	margin-right: 0;
}
.x-pg-edit-left-preview-right [data-preview-section] {
	cursor: pointer;
	outline: none;
}
.x-pg-edit-left-preview-right [data-preview-section]:not(.x-pg-preview-navbar):not(.x-pg-floating-actions):not(.x-pg-navbar-block-outer) {
	position: relative;
}
/* hover / boundary-active：用 ::after inset shadow，避免被 overflow 裁切左右邊 */
/* 已選中（x-pg-preview-highlight）的 section hover 不顯示綠色 */
.x-pg-preview-content-wrapper [data-preview-section]:not(.x-pg-preview-navbar):not(.x-pg-floating-actions):not(.x-pg-preview-highlight):hover::after,
.x-pg-preview-content-wrapper [data-preview-section]:not(.x-pg-preview-navbar):not(.x-pg-floating-actions):not(.x-pg-preview-highlight).x-pg-preview-boundary-active::after {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	box-shadow: inset 0 0 0 1px rgba(34, 197, 94, 0.45);
	z-index: 10;
}

.x-pg-edit-left-preview-right .x-pg-floating-actions[data-preview-section="floatingActions"] {
	position: fixed;
	width: auto;
	min-width: 0;
}
.x-pg-preview-content-wrapper .x-pg-floating-actions[data-preview-section="floatingActions"]:hover,
.x-pg-preview-content-wrapper .x-pg-floating-actions[data-preview-section="floatingActions"].x-pg-preview-boundary-active {
	box-shadow: none;
	outline: 2px solid rgba(34, 197, 94, 0.45);
	outline-offset: 6px;
	border-radius: 999px;
}
.x-pg-preview-content-wrapper .x-pg-floating-actions[data-preview-section="floatingActions"].x-pg-preview-highlight,
.x-pg-preview-content-wrapper .x-pg-floating-actions[data-preview-section="floatingActions"].x-pg-preview-highlight:hover {
	box-shadow: none;
	outline: 2px solid rgba(99, 102, 241, 0.8);
	outline-offset: 6px;
	border-radius: 999px;
}
.x-pg-preview-content-wrapper .x-pg-floating-actions[data-editor-preview-section="true"]::before,
.x-pg-preview-content-wrapper .x-pg-floating-actions[data-editor-preview-section="true"]:hover::before,
.x-pg-preview-content-wrapper .x-pg-floating-actions[data-editor-preview-section="true"].x-pg-preview-boundary-active::before,
.x-pg-preview-content-wrapper .x-pg-floating-actions[data-editor-preview-section="true"].x-pg-preview-highlight::before {
	top: auto;
	left: auto;
	right: calc(100% + 0.35rem);
	bottom: 0;
	transform: none;
	max-width: 7rem;
}
.x-pg-preview-content-wrapper [data-editor-preview-section="true"]::before {
	content: none;
}
.x-pg-preview-content-wrapper [data-editor-preview-section="true"]:hover::before,
.x-pg-preview-content-wrapper [data-editor-preview-section="true"].x-pg-preview-boundary-active::before,
.x-pg-preview-content-wrapper [data-editor-preview-section="true"].x-pg-preview-highlight::before {
	content: attr(data-section-label);
	position: absolute;
	top: 0;
	left: 0;
	transform: translate(-1px, -1px);
	z-index: 3;
	display: inline-flex;
	align-items: center;
	max-width: calc(100% - 0.5rem);
	padding: 0.22rem 0.55rem;
	border-radius: 0;
	background: rgba(15, 23, 42, 0.86);
	color: #fff;
	font-size: 0.72rem;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: 0.01em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	pointer-events: none;
	box-shadow: 0 2px 8px rgba(15, 23, 42, 0.16);
}
.x-pg-preview-content-wrapper [data-editor-preview-section="true"]:hover::before,
.x-pg-preview-content-wrapper [data-editor-preview-section="true"].x-pg-preview-boundary-active::before {
	background: rgba(22, 163, 74, 0.92);
}
.x-pg-preview-content-wrapper [data-editor-preview-section="true"].x-pg-preview-highlight::before {
	background: rgba(99, 102, 241, 0.94);
}
.x-pg-preview-action-toolbar {
	position: absolute;
	z-index: 6;
	display: inline-flex;
	align-items: stretch;
	gap: 0;
	transform: translate(-100%, -1px);
	background: rgba(255, 255, 255, 0.98);
	border: 1px solid rgba(226, 232, 240, 0.95);
	border-radius: 0;
	box-shadow: 0 6px 18px rgba(15, 23, 42, 0.12);
	overflow: hidden;
}
.x-pg-preview-action-toolbar--edit-only {
	transform: translate(calc(-100% - 0.35rem), -0.35rem);
	border-radius: 999px;
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.16);
}
.x-pg-preview-action-btn {
	width: 32px;
	height: 32px;
	padding: 0;
	border: 0;
	border-right: 1px solid rgba(226, 232, 240, 0.95);
	border-radius: 0;
	background: transparent;
	color: #334155;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.18s ease, color 0.18s ease, opacity 0.18s ease;
}
.x-pg-preview-action-toolbar--edit-only .x-pg-preview-action-btn {
	width: 28px;
	height: 28px;
}
.x-pg-preview-action-toolbar--edit-only .x-pg-preview-action-btn i {
	font-size: 0.82rem;
}
.x-pg-preview-action-btn:last-child {
	border-right: 0;
}
.x-pg-preview-action-btn:hover:not(:disabled) {
	background: rgba(241, 245, 249, 0.96);
}
.x-pg-preview-action-btn:disabled {
	opacity: 0.38;
	cursor: not-allowed;
}
.x-pg-preview-action-btn .bi-chevron-up,
.x-pg-preview-action-btn .bi-chevron-down {
	color: #16a34a;
}
.x-pg-preview-action-btn-delete {
	color: #dc2626;
}
.x-pg-preview-action-btn-delete:hover:not(:disabled) {
	background: rgba(254, 242, 242, 0.98);
}
.x-pg-preview-action-btn i {
	font-size: 0.9rem;
	line-height: 1;
	pointer-events: none;
}
.x-pg-edit-left-preview-right .x-pg-page-scroll {
	padding: 0;
}
.x-pg-edit-left-preview-right .x-pg-page-scroll [data-preview-section] {
	margin-top: 0;
	margin-bottom: 0;
}
.x-pg-edit-left-preview-right .x-pg-page-scroll [data-preview-section]:first-child {
	margin-top: 0;
}
.x-pg-edit-left-preview-right .x-pg-page-scroll [data-preview-section]:last-child {
	margin-bottom: 0;
}

/* ===== 編輯區 ===== */
.x-pg-edit-section {
	background: transparent;
	padding: 0;
	margin: 0;
	overflow: hidden;
	flex: 1;
	min-width: 0;
	height: 100%;
	display: flex;
	flex-direction: column;
	position: relative;
	padding-top: .5rem;
}

.x-pg-edit-header-bar {
	background: var(--x-pg-edit-accent);
	color: #fff;
	padding: 0.75rem 1.25rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-shrink: 0;
	margin: 0;
	border-radius: var(--x-pg-radius) var(--x-pg-radius) 0 0;
	box-shadow: 0 2px 8px rgba(67, 79, 132, 0.2);
}

.x-pg-edit-title {
	font-size: 0.9375rem;
	font-weight: 600;
	color: #fff;
	display: flex;
	align-items: center;
	letter-spacing: -0.01em;
}

.x-pg-edit-title i {
	font-size: 1.05rem;
	color: #fff;
}

.x-pg-edit-section form {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	padding: 0 1.5rem 1.5rem;
}
.x-pg-edit-section .form-control {
	border-radius: var(--x-pg-radius-sm);
}

.x-pg-edit-section .btn-outline-primary,
.x-pg-edit-section .btn-outline-primary i {
	color: var(--x-pg-edit-accent);
	border-color: var(--x-pg-edit-accent);
}
.x-pg-edit-section .btn-outline-primary:hover,
.x-pg-edit-section .btn-outline-primary:hover i {
	color: #fff;
	background-color: var(--x-pg-edit-accent);
	border-color: var(--x-pg-edit-accent);
}

/* 所有 switch 開關使用 iOS 標準綠色 */
.form-check.form-switch .form-check-input:checked {
	background-color: #34c759;
	border-color: #34c759;
}
.form-check.form-switch .form-check-input:focus {
	border-color: #34c759;
	box-shadow: 0 0 0 0.25rem rgba(52, 199, 89, 0.25);
}
.form-check.form-switch .form-check-input:focus-visible {
	outline: 0;
}
.x-pg-edit-section .form-check-input:focus-visible {
	outline: 0;
}

.x-pg-edit-section .x-pg-form-group .form-control:focus,
.x-pg-edit-section .x-pg-form-group input:focus,
.x-pg-edit-section .x-pg-form-group textarea:focus {
	border-color: var(--x-pg-edit-accent);
	box-shadow: 0 0 0 3px rgba(67, 79, 132, 0.15);
}

@media (max-width: 1199px) {
	.x-pg-edit-section {
		width: 100%;
		flex: 1;
		min-height: 0;
		height: auto;
		overflow: hidden;
	}
}

/* ===== 自定義折疊樣式 ===== */
.x-pg-collapse-container {
	padding-bottom: 80px;
}

.x-pg-collapse-item {
	border: 1px solid var(--x-pg-border);
	border-radius: var(--x-pg-radius);
	margin-bottom: 0.75rem;
	background: var(--x-pg-surface);
	overflow: hidden;
	box-shadow: var(--x-pg-shadow);
}
.x-pg-collapse-item.x-pg-edit-highlight {
	border-color: #6366f1;
	box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.25);
	outline: none;
}
.x-pg-collapse-item.x-pg-edit-highlight:focus {
	outline: none;
}

.x-pg-collapse-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: .5rem 1.25rem;
	background-color: var(--bs-gray-100);
	color: var(--bs-gray-800);
	cursor: default;
	user-select: none;
	font-weight: 600;
	border-bottom: 1px solid var(--bs-gray-200);
	transition: background-color 0.2s;
}
.x-pg-collapse-header-title {
	display: inline-flex;
	align-items: center;
}
.x-pg-collapse-header-title,
.x-pg-collapse-header .x-pg-collapse-icon {
	cursor: pointer;
}
.x-pg-collapse-header-title:hover,
.x-pg-collapse-header .x-pg-collapse-icon:hover {
	opacity: 0.85;
}
.x-pg-collapse-header:hover {
	background-color: var(--bs-gray-200);
}

.x-pg-collapse-header .x-pg-collapse-icon {
	cursor: pointer;
	transition: background-color 0.2s, color 0.2s;
	border-radius: 0.25rem;
	padding: 0.15em;
}
.x-pg-collapse-header .x-pg-collapse-icon:hover {
	background-color: #e2e8f0;
	color: var(--x-pg-text);
}

.x-pg-collapse-item.active .x-pg-collapse-header {
	background-color: #f8fafc;
	color: var(--x-pg-text);
	border-bottom-color: var(--x-pg-border);
}

.x-pg-collapse-item.active .x-pg-collapse-header i {
	color: var(--x-pg-text-muted);
}

.x-pg-collapse-header > span:not(.x-pg-collapse-header-actions) {
	display: flex;
	align-items: center;
	flex: 1;
	min-width: 0;
}

.x-pg-collapse-header-actions {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	background: none;
}

.x-pg-collapse-header i {
	color: var(--x-pg-text-muted);
}
.x-pg-collapse-header .btn.text-danger i {
	color: inherit;
}
.x-pg-collapse-header .btn-danger i,
.x-pg-section-toolbar .btn-danger i,
.btn-danger i {
	color: #fff;
}

/* 小 icon 按鈕（如刪除圖示）hover 效果 */
.btn.btn-sm.btn-link.p-0.text-danger {
	transition: color 0.2s ease, background-color 0.2s ease, transform 0.15s ease;
	border-radius: 0.25rem;
}
.btn.btn-sm.btn-link.p-0.text-danger:hover,
.btn.btn-sm.btn-link.p-0.text-danger:focus-visible {
	color: #b02a37;
	background-color: rgba(220, 53, 69, 0.12);
	transform: scale(1.08);
}

.x-pg-collapse-header .x-pg-move-icon,
.x-pg-collapse-header .x-pg-lock-icon {
	padding: 0.2em;
	border-radius: 0.25rem;
}
.x-pg-move-icon-wrap,
.x-pg-drag-handle {
	cursor: grab;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--x-pg-text-muted);
	transition: background-color 0.2s, color 0.2s;
	user-select: none;
	padding: 0.2em;
	border-radius: 0.25rem;
}
.x-pg-move-icon-wrap:hover,
.x-pg-drag-handle:hover {
	background-color: #e2e8f0;
	color: var(--x-pg-text);
}
.x-pg-move-icon-wrap:active,
.x-pg-drag-handle:active {
	cursor: grabbing;
}
.x-pg-collapse-header .x-pg-move-icon {
	pointer-events: none;
}
.x-pg-collapse-icon {
	display: inline-block;
	transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.x-pg-collapse-icon.is-expanded {
	transform: rotate(180deg);
}

.x-pg-collapse-content {
	max-height: 0;
	overflow: hidden;
	padding: 0 1.25rem;
}

.x-pg-collapse-content.show {
	max-height: 5000px;
	padding: 0rem 1.25rem;
}
.x-pg-section-edit-content {
	padding: 0rem 1.25rem;
}


/* ===== 預覽區標記 ===== */
/* 選中（highlight）：紫色邊框，統一加在 x-pg-section-outer（data-preview-section）上 */
[data-preview-section].x-pg-preview-highlight::after {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	box-shadow: inset 0 0 0 1px rgba(99, 102, 241, 0.85);
	z-index: 10;
}
/* hover 在已選中的 section 上，維持紫色（覆蓋綠色 ::after） */
[data-preview-section].x-pg-preview-highlight:hover::after {
	box-shadow: inset 0 0 0 1px rgba(99, 102, 241, 0.85);
}
.x-pg-preview-highlight::before {
	display: none;
}
.x-pg-page-section .x-pg-event-intro-content.x-pg-preview-highlight {
	outline: 1px solid rgba(34, 197, 94, 0.45);
	box-shadow: none;
}
.x-pg-preview-content-wrapper .x-pg-event-intro-content[data-editor-preview-section="true"]:hover,
.x-pg-preview-content-wrapper .x-pg-event-intro-content[data-editor-preview-section="true"].x-pg-preview-boundary-active,
.x-pg-preview-content-wrapper .x-pg-event-intro-content[data-editor-preview-section="true"].x-pg-preview-highlight {
	outline: 1px solid rgba(34, 197, 94, 0.45);
	box-shadow: none;
}
.x-pg-preview-content-wrapper .x-pg-event-intro-content[data-editor-preview-section="true"]:hover::before,
.x-pg-preview-content-wrapper .x-pg-event-intro-content[data-editor-preview-section="true"].x-pg-preview-boundary-active::before,
.x-pg-preview-content-wrapper .x-pg-event-intro-content[data-editor-preview-section="true"].x-pg-preview-highlight::before {
	background: rgba(22, 163, 74, 0.92);
}

/* ===== 拖曳排序 ===== */
.x-pg-sortable-item {
	cursor: default;
}

.x-pg-sortable-item .x-pg-collapse-header .x-pg-collapse-icon {
	cursor: pointer;
}

/* 只在移動模式開啟時顯示移動游標 */
.x-pg-move-mode-active.x-pg-sortable-item {
	cursor: move;
}
.x-pg-sortable-disabled {
	cursor: default;
}

.ui-sortable-helper {
	opacity: 0.8;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	transform: rotate(2deg);
}

.ui-sortable-placeholder {
	height: 60px;
	background-color: var(--bs-gray-100);
	border: 2px dashed var(--bs-primary);
	border-radius: 0.5rem;
	margin: 0.5rem 0;
	visibility: visible !important;
}

@media (max-width: 768px) {
	.x-pg-edit-section {
		padding: 1rem;
	}
}

/* ===== 預覽區（僅編輯器左編右預覽時之預覽區內 section） ===== */
/* 不設 margin，改由各 section 的 inline style（getSectionMarginStyle）控制外邊界，與 header 一致 */
.x-pg-edit-left-preview-right .x-pg-page-scroll .x-pg-page-section {
	padding: 0;
	overflow: visible;
	display: flex !important;
	flex-direction: column;
	flex: 1;
	min-width: 0;
	height: auto;
	width: 100%;
}

@media (max-width: 1199px) {
	.x-pg-edit-left-preview-right .x-pg-page-scroll .x-pg-page-section {
		width: 100%;
		flex: 1;
		min-height: 0;
		height: auto;
		overflow: visible;
	}
}

@media (max-width: 991px) {
	.x-pg-layout-container {
		flex-direction: column;
		height: calc(100vh - 100px);
		padding: 0;
		margin-top: 100px;
		gap: 0;
	}
	.x-pg-layout-container.x-pg-edit-left-preview-right {
		flex-direction: column;
	}
	.x-pg-layout-body {
		flex-direction: column;
		padding: 0.5rem;
	}
	.x-pg-edit-left-preview-right .x-pg-edit-section {
		flex: 1 1 auto;
		min-width: 0;
		min-height: 200px;
		width: 100%;
		border-radius: var(--x-pg-radius-lg);
	}
	.x-pg-edit-left-preview-right .x-pg-preview-main {
		flex: 1 1 auto;
		min-height: 200px;
		border-radius: var(--x-pg-radius);
	}
	.x-pg-edit-section {
		width: 100%;
		flex: 1;
		min-height: 0;
		margin-bottom: 0;
		overflow: hidden;
		border-radius: 0;
		display: flex;
		flex-direction: column;
	}
	.x-pg-preview-section {
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		width: 100%;
		height: 60px;
		max-height: 60px;
		border-radius: 0;
		box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
		z-index: 1000;
		transition: height 0.3s ease, max-height 0.3s ease;
		overflow: hidden;
		margin-bottom: 0;
	}
	
	.x-pg-preview-section.preview-expanded {
		height: 100vh;
		max-height: 100vh;
		top: 0;
		border-radius: 0;
		z-index: 1051;
	}
	
	.x-pg-preview-section:not(.preview-expanded) .x-pg-page-scroll {
		display: none;
	}
	
	.x-pg-preview-header-bar {
		cursor: pointer;
		user-select: none;
	}
	
	.x-pg-preview-section:not(.preview-expanded) .x-pg-preview-header-bar {
		height: 60px;
		display: flex;
		align-items: center;
		justify-content: space-between;
	}
}

.x-pg-preview-header-bar {
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	color: #fff;
	padding: 0.75rem 1rem;
	border-radius: 0.625rem 0.625rem 0 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-shrink: 0;
	margin: 0;
}

@media (max-width: 991px) {
	.x-pg-preview-header-bar {
		min-height: 60px;
	}
}

.x-pg-preview-header-bar .x-pg-preview-title {
	font-weight: 600;
	font-size: 0.875rem;
	color: #fff;
	display: flex;
	align-items: center;
}

.x-pg-preview-header-bar i {
	color: #fff;
	font-size: 1rem;
}

.x-pg-preview-header-bar .btn-link {
	text-decoration: none;
	padding: 0.25rem 0.5rem;
}

.x-pg-preview-header-bar .btn-link:hover {
	opacity: 0.8;
}

/* ===== 基礎樣式 ===== */
.x-pg-form-container {
	max-width: 1400px;
	margin: 0 auto;
	padding: 2rem;
}
.x-pg-form {
	background: var(--x-pg-surface);
}

/* ===== 表單區塊 ===== */
.x-pg-form-block {
	background: #fff;
	border-radius: 0.625rem;
	
}

.x-pg-form-block__title {
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--bs-gray-800);
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 2px solid var(--bs-gray-200);
}

.x-pg-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
	margin-bottom: 1.5rem;
}

@media (max-width: 768px) {
	.x-pg-form-row {
		grid-template-columns: 1fr;
	}
}
@media (max-width: 992px) {
	.x-pg-edit-section .x-pg-form-row-header {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	.x-pg-edit-section .x-pg-form-row-header .x-pg-form-group:first-child {
		width: 100%;
	}
	.x-pg-edit-section .x-pg-form-row-header > div:last-child {
		width: 100%;
	}
}

.x-pg-form-row-colors {
	overflow: visible;
	border-bottom: 1px dashed var(--bs-border-color, #dee2e6);
	padding-bottom: 0.75rem;
	margin-bottom: 0.75rem;
}
.x-pg-color-picker-with-opacity {
	display: inline-flex;
	align-items: flex-start;
	gap: 0.35rem;
	flex-wrap: nowrap;
}
.x-pg-color-picker-with-opacity .x-pg-color-picker-wrap {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
}
.x-pg-color-picker-with-opacity .form-control-color {
	width: 28px;
	height: 28px;
	padding: 2px;
	border-radius: var(--x-pg-radius-sm);
	cursor: pointer;
}
.x-pg-color-picker-with-opacity .x-pg-color-opacity-bar {
	display: flex;
	align-items: center;
	gap: 4px;
	width: 100%;
	min-width: 60px;
}
.x-pg-color-picker-with-opacity .x-pg-color-opacity-bar .form-range {
	width: 44px;
	height: 6px;
	margin: 0;
	flex-shrink: 0;
}
.x-pg-color-picker-with-opacity .x-pg-color-opacity-pct {
	font-size: 0.7rem;
	color: var(--x-pg-text-muted, #6c757d);
	min-width: 24px;
	line-height: 1;
}
.x-pg-font-color-picker {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 32px;
}
.x-pg-font-color-input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
	width: 0;
	height: 0;
}
.x-pg-font-color-button {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 32px;
	border: 1px solid #ced4da;
	border-radius: var(--x-pg-radius-sm);
	background-color: #ffffff;
	cursor: pointer;
	padding: 0;
}
.x-pg-font-color-button:hover {
	background-color: #f3f3f3;
}
.x-pg-font-color-letter {
	font-size: 18px;
	line-height: 1;
	color: #000000;
}
.x-pg-font-color-underline {
	margin-top: 3px;
	width: 70%;
	height: 3px;
	border-radius: 2px;
	background-color: #ffffff;
}
.x-pg-section-form-tabs {
	margin-top: 0.25rem;
}
.x-pg-section-form-tabs .x-pg-form-tabs {
	display: flex;
	gap: 0;
	border-bottom: 1px solid var(--x-pg-border, #e8ecf1);
	margin-bottom: 0.75rem;
	padding-bottom: 0;
}
.x-pg-section-form-tabs .x-pg-form-tabs .nav-link {
	border: none;
	border-bottom: 2px solid transparent;
	border-radius: 0;
	background: transparent;
	color: var(--x-pg-text-muted, #6c757d);
	padding: 0.4rem 0.75rem;
	font-size: 0.875rem;
	cursor: pointer;
	margin-bottom: -1px;
}
.x-pg-section-form-tabs .x-pg-form-tabs .nav-link:hover {
	color: var(--bs-body-color);
}
.x-pg-section-form-tabs .x-pg-form-tabs .nav-link.active {
	color: var(--bs-primary);
	border-bottom-color: var(--bs-primary);
	font-weight: 500;
}
.x-pg-section-form-tabs .x-pg-form-tab-content {
	min-height: 0;
}
.x-pg-style-tab .x-pg-form-group {
	margin-bottom: 1rem;
}
.x-pg-style-tab .x-pg-form-group:last-child {
	margin-bottom: 0;
}
.x-pg-style-tab {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.x-pg-style-tab .x-pg-style-block:last-child {
	margin-bottom: 1rem;
}
.x-pg-style-block {
	background: var(--x-pg-bg, #f8f9fb);
	border: 1px solid var(--x-pg-border, #e8ecf1);
	border-radius: var(--x-pg-radius-sm);
	padding: 0.75rem 1rem;
}
.x-pg-style-block-title {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 600;
	font-size: 0.875rem;
	color: var(--x-pg-text, #1e293b);
	margin-bottom: 0.5rem;
}
.x-pg-style-block-title i {
	font-size: 1.1rem;
}
.x-pg-style-hint {
	font-size: 0.75rem;
	color: var(--x-pg-text-muted, #6c757d);
	margin-bottom: 0.5rem;
	margin-top: 0;
}
.x-pg-cta-style-block {
	border-radius: var(--x-pg-radius, 12px);
	padding: 0.875rem 1rem;
}
.x-pg-cta-style-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 0.875rem;
}
.x-pg-cta-style-shape {
	flex-shrink: 0;
}
.x-pg-cta-style-row {
	gap: 0.9rem;
	flex-wrap: nowrap;
	justify-content: space-between;
}
.x-pg-cta-popover-color {
	width: 56px;
	height: 44px;
	padding: 0.2rem;
}
.x-pg-cta-radius-trigger {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}
.x-pg-cta-radius-icon {
	position: relative;
	display: inline-block;
	width: 14px;
	height: 14px;
	border: 1.6px solid currentColor;
	border-radius: 5px;
	flex-shrink: 0;
}
.x-pg-cta-radius-icon::after {
	content: "";
	position: absolute;
	inset: 3px;
	border: 1.2px solid currentColor;
	border-radius: 3px;
	opacity: 0.35;
}
.x-pg-cta-style-row .x-pg-style-row-item {
	flex-shrink: 0;
}
@media (max-width: 575.98px) {
	.x-pg-cta-style-header {
		flex-direction: column;
		align-items: stretch;
	}
	.x-pg-cta-style-shape {
		width: 100%;
	}
	.x-pg-cta-style-row {
		flex-wrap: wrap;
		justify-content: flex-start;
	}
}
.x-pg-style-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1rem;
}
.x-pg-style-row-nowrap {
	flex-wrap: nowrap;
	gap: 0.75rem;
}
.x-pg-style-row-nowrap .x-pg-style-row-label {
	font-size: 0.75rem;
	white-space: nowrap;
}
.x-pg-style-row-item {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.x-pg-style-row-label {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-color-picker-preview-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border: 1px solid var(--x-pg-border, #e8ecf1);
	border-radius: 0.25rem;
	background: linear-gradient(45deg, #e2e8f0 25%, transparent 25%), linear-gradient(-45deg, #e2e8f0 25%, transparent 25%), linear-gradient(45deg, transparent 75%, #e2e8f0 75%), linear-gradient(-45deg, transparent 75%, #e2e8f0 75%);
	background-size: 6px 6px;
	background-position: 0 0, 0 3px, 3px -3px, -3px 0;
	cursor: pointer;
	transition: border-color 0.2s, box-shadow 0.2s;
}
.x-pg-color-picker-preview-wrap:hover {
	border-color: var(--x-pg-nav, #5463a5);
	box-shadow: 0 0 0 2px rgba(84, 99, 165, 0.2);
}
.x-pg-color-picker-preview {
	display: block;
	width: 22px;
	height: 22px;
	border-radius: 0.2rem;
	border: 1px solid rgba(0, 0, 0, 0.1);
}
.x-pg-color-picker-popover {
	background: #fff !important;
}
.x-pg-color-picker-popover .x-pg-color-current-row {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.25rem;
}
.x-pg-color-picker-popover .x-pg-color-current-swatch {
	display: inline-block;
	width: 20px;
	height: 20px;
	border-radius: 0.25rem;
	border: 1px solid rgba(0, 0, 0, 0.15);
	flex-shrink: 0;
}
.x-pg-color-picker-popover .x-pg-color-current-row .text-break {
	max-width: 180px;
	font-size: 0.75rem;
	word-break: break-all;
}
.x-pg-color-picker-popover .x-pg-color-picker-native {
	width: 40px;
	height: 40px;
	padding: 2px;
	cursor: pointer;
}
.x-pg-color-picker-popover .x-pg-rbgcp-wrap {
	background: #fff !important;
	max-width: 240px;
}
.x-pg-color-picker-popover .x-pg-rbgcp-wrap input[type="range"],
.x-pg-color-picker-popover .x-pg-rbgcp-wrap input[type="range"]::-webkit-slider-thumb,
.x-pg-color-picker-popover .x-pg-rbgcp-wrap input[type="range"]::-moz-range-thumb {
	cursor: pointer !important;
}
.x-pg-color-picker-popover-custom .x-pg-color-range {
	cursor: pointer;
}
.x-pg-color-picker-popover-custom input[type="range"] {
	cursor: pointer;
}
.x-pg-color-picker-popover .x-pg-rbgcp-root {
	background: #fff !important;
}
.x-pg-color-picker-popover .x-pg-rbgcp-root .rbgcp-control-btn-wrapper,
.x-pg-color-picker-popover .x-pg-rbgcp-root .rbgcp-input {
	background: #fff !important;
	color: #333 !important;
}
.x-pg-preset-color-btn {
	width: 20px;
	height: 20px;
	padding: 0;
	border: 1px solid rgba(0, 0, 0, 0.15);
	border-radius: 0.25rem;
	cursor: pointer;
	transition: transform 0.15s, box-shadow 0.15s;
}
.x-pg-preset-color-btn:hover {
	transform: scale(1.1);
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}
/* 調色盤 Popover 現代版：美觀、行銷友善 */
.x-pg-color-picker-popover-modern {
	background: #fff !important;
	border-radius: 12px;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12), 0 2px 8px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.06);
	padding: 0;
	overflow: hidden;
}
.x-pg-color-picker-popover-modern .x-pg-cp-header {
	padding: 12px 14px 10px;
	background: linear-gradient(180deg, #f8fafc 0%, #fff 100%);
	border-bottom: 1px solid #f1f5f9;
}
.x-pg-color-picker-popover-modern .x-pg-cp-title {
	font-size: 0.8125rem;
	font-weight: 600;
	color: #334155;
	letter-spacing: 0.01em;
}
.x-pg-color-picker-popover-modern .x-pg-cp-current {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	flex-wrap: wrap;
}
.x-pg-color-picker-popover-modern .x-pg-cp-current-label {
	font-size: 0.75rem;
	color: #64748b;
	font-weight: 500;
}
.x-pg-color-picker-popover-modern .x-pg-cp-swatch {
	width: 24px;
	height: 24px;
	border-radius: 8px;
	border: 1px solid rgba(0, 0, 0, 0.12);
	flex-shrink: 0;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
.x-pg-color-picker-popover-modern .x-pg-cp-code {
	font-size: 0.75rem;
	color: #475569;
	word-break: break-all;
	flex: 1;
	min-width: 0;
	font-family: ui-monospace, monospace;
}
.x-pg-color-picker-popover-modern .x-pg-cp-mode {
	display: flex;
	gap: 4px;
	padding: 0 14px 12px;
}
.x-pg-color-picker-popover-modern .x-pg-cp-mode-btn {
	flex: 1;
	padding: 6px 10px;
	font-size: 0.8125rem;
	font-weight: 500;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	background: #fff;
	color: #64748b;
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.x-pg-color-picker-popover-modern .x-pg-cp-mode-btn:hover {
	background: #f8fafc;
	border-color: #cbd5e1;
	color: #334155;
}
.x-pg-color-picker-popover-modern .x-pg-cp-mode-btn.active {
	background: #334155;
	border-color: #334155;
	color: #fff;
}
.x-pg-color-picker-popover-modern .x-pg-cp-slider {
	padding: 0 14px 10px;
}
.x-pg-color-picker-popover-modern .x-pg-cp-label {
	display: block;
	font-size: 0.75rem;
	font-weight: 500;
	color: #64748b;
	margin-bottom: 4px;
}
.x-pg-color-picker-popover-modern .x-pg-cp-gradient-hint {
	font-size: 0.75rem;
	color: #64748b;
	padding: 0 14px 12px;
	line-height: 1.4;
}
.x-pg-color-picker-popover-modern .x-pg-cp-presets {
	padding: 10px 14px 12px;
	border-top: 1px solid #f1f5f9;
}
.x-pg-color-picker-popover-modern .x-pg-cp-presets-label {
	display: block;
	font-size: 0.75rem;
	font-weight: 500;
	color: #64748b;
	margin-bottom: 8px;
}
.x-pg-color-picker-popover-modern .x-pg-cp-presets-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.x-pg-color-picker-popover-modern .x-pg-cp-presets-grid .x-pg-preset-color-btn {
	width: 22px;
	height: 22px;
	border-radius: 6px;
}
.x-pg-color-picker-popover-modern .x-pg-cp-footer {
	padding: 12px 14px 14px;
	background: #f8fafc;
	border-top: 1px solid #f1f5f9;
}
.x-pg-color-picker-popover-modern .x-pg-cp-format-label {
	margin-bottom: 6px;
}
.x-pg-color-picker-popover-modern .x-pg-cp-format-row {
	display: flex;
	gap: 8px;
	align-items: stretch;
}
.x-pg-color-picker-popover-modern .x-pg-cp-format-select {
	width: 72px;
	flex-shrink: 0;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	font-size: 0.8125rem;
	font-weight: 500;
	color: #334155;
	cursor: pointer;
}
.x-pg-color-picker-popover-modern .x-pg-cp-code-input {
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	font-size: 0.8125rem;
	font-family: ui-monospace, monospace;
	flex: 1;
	min-width: 0;
}
.x-pg-color-picker-popover-modern .x-pg-cp-code-input:focus {
	border-color: #94a3b8;
	box-shadow: 0 0 0 2px rgba(148, 163, 184, 0.2);
}
/* Figma 式調色盤：2D 色相圖 + 彩虹條 + HEX/RGB + 頁面顏色 */
.x-pg-color-picker-popover-figma {
	position: relative;
	background: #fff !important;
	border-radius: 12px;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12), 0 2px 8px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.06);
	padding: 0;
	overflow: hidden;
}
.x-pg-color-picker-popover-figma .x-pg-cp-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 12px 14px 10px;
	background: linear-gradient(180deg, #f8fafc 0%, #fff 100%);
	border-bottom: 1px solid #f1f5f9;
}
.x-pg-color-picker-popover-figma .x-pg-cp-title {
	font-size: 0.8125rem;
	font-weight: 600;
	color: #334155;
	letter-spacing: 0.01em;
}
.x-pg-color-picker-popover-figma .x-pg-cp-header .x-pg-cp-swatch {
	width: 22px;
	height: 22px;
	border-radius: 6px;
	border: 1px solid rgba(0, 0, 0, 0.15);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
	flex-shrink: 0;
}
.x-pg-color-picker-popover-figma .x-pg-cp-mode {
	display: flex;
	gap: 4px;
	padding: 0 14px 12px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-mode-btn {
	flex: 1;
	padding: 6px 10px;
	font-size: 0.8125rem;
	font-weight: 500;
	border: 1px solid #e2e8f0;
	border-radius: 8px;
	background: #fff;
	color: #64748b;
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.x-pg-color-picker-popover-figma .x-pg-cp-mode-btn:hover {
	background: #f8fafc;
	border-color: #cbd5e1;
	color: #334155;
}
.x-pg-color-picker-popover-figma .x-pg-cp-mode-btn.active {
	background: #334155;
	border-color: #334155;
	color: #fff;
}
.x-pg-color-picker-popover-figma .x-pg-cp-2d-row {
	display: flex;
	gap: 8px;
	padding: 0 14px 10px;
	align-items: stretch;
}
.x-pg-color-picker-popover-figma .x-pg-cp-2d-box {
	width: 180px;
	height: 140px;
	border-radius: 8px;
	cursor: pointer;
	position: relative;
	flex-shrink: 0;
	border: 1px solid #e2e8f0;
	overflow: hidden;
	user-select: none;
}
.x-pg-color-picker-popover-figma .x-pg-cp-2d-knob {
	position: absolute;
	width: 14px;
	height: 14px;
	border: 2px solid #fff;
	border-radius: 50%;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
	transform: translate(-50%, -50%);
	pointer-events: none;
}
.x-pg-color-picker-popover-figma .x-pg-cp-hue-bar {
	width: 14px;
	height: 140px;
	flex-shrink: 0;
	border-radius: 8px;
	cursor: pointer;
	position: relative;
	border: 1px solid #e2e8f0;
	user-select: none;
}
.x-pg-color-picker-popover-figma .x-pg-cp-hue-knob {
	position: absolute;
	left: 50%;
	width: 18px;
	height: 4px;
	margin-left: -9px;
	border: 2px solid #fff;
	border-radius: 2px;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
	pointer-events: none;
	transform: translateY(-50%);
}
.x-pg-color-picker-popover-figma .x-pg-cp-alpha-bar {
	width: 14px;
	height: 140px;
	flex-shrink: 0;
	border-radius: 8px;
	cursor: pointer;
	position: relative;
	border: 1px solid #e2e8f0;
	user-select: none;
	background-color: #fff;
}
.x-pg-color-picker-popover-figma .x-pg-cp-alpha-knob {
	position: absolute;
	left: 50%;
	width: 18px;
	height: 4px;
	margin-left: -9px;
	border: 2px solid #fff;
	border-radius: 2px;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
	pointer-events: none;
	transform: translateY(-50%);
}
.x-pg-color-picker-popover-figma .x-pg-cp-slider {
	padding: 0 14px 10px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-label {
	display: block;
	font-size: 0.75rem;
	font-weight: 500;
	color: #64748b;
	margin-bottom: 4px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-hex-rgb {
	padding: 0 14px 12px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-hex-row {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-hex-row .x-pg-cp-label {
	margin-bottom: 0;
	width: 32px;
	flex-shrink: 0;
}
.x-pg-color-picker-popover-figma .x-pg-cp-hex-row .x-pg-cp-code-input {
	flex: 1;
	min-width: 0;
}
.x-pg-color-picker-popover-figma .x-pg-cp-rgb-row {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-wrap: nowrap;
}
.x-pg-color-picker-popover-figma .x-pg-cp-rgb-row .x-pg-cp-label {
	margin-bottom: 0;
	width: 12px;
	flex-shrink: 0;
	text-align: center;
	font-size: 0.6875rem;
}
.x-pg-color-picker-popover-figma .x-pg-cp-rgb-input {
	width: 46px;
	min-width: 46px;
	text-align: center;
	padding: 2px 6px;
	font-size: 0.75rem;
	border-radius: 6px;
	border: 1px solid #e2e8f0;
	appearance: textfield;
	-moz-appearance: textfield;
}
.x-pg-color-picker-popover-figma .x-pg-cp-rgb-input::-webkit-outer-spin-button,
.x-pg-color-picker-popover-figma .x-pg-cp-rgb-input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
.x-pg-color-picker-popover-figma .x-pg-cp-rgb-input.x-pg-cp-a-input {
	width: 50px;
	min-width: 50px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-rgb-input:focus {
	border-color: #94a3b8;
	box-shadow: 0 0 0 2px rgba(148, 163, 184, 0.2);
	outline: none;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-hint {
	font-size: 0.75rem;
	color: #64748b;
	padding: 0 14px 12px;
	line-height: 1.4;
}
.x-pg-color-picker-popover-figma .x-pg-cp-presets {
	padding: 10px 14px 12px;
	border-top: 1px solid #f1f5f9;
}
.x-pg-color-picker-popover-figma .x-pg-cp-presets-label {
	display: block;
	font-size: 0.75rem;
	font-weight: 500;
	color: #64748b;
	margin-bottom: 8px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-presets-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-presets-grid .x-pg-preset-color-btn {
	width: 22px;
	height: 22px;
	border-radius: 6px;
	cursor: pointer;
}
.x-pg-color-picker-popover-figma .x-pg-cp-footer {
	padding: 12px 14px 14px;
	background: #f8fafc;
	border-top: 1px solid #f1f5f9;
}
.x-pg-color-picker-popover-figma .x-pg-cp-format-label {
	margin-bottom: 6px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-code-input {
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	font-size: 0.8125rem;
	font-family: ui-monospace, monospace;
}
.x-pg-color-picker-popover-figma .x-pg-cp-code-input:focus {
	border-color: #94a3b8;
	box-shadow: 0 0 0 2px rgba(148, 163, 184, 0.2);
}
.x-pg-color-picker-popover-figma input[type="range"].x-pg-color-range {
	cursor: pointer;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-type-row {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 0 14px 10px;
	flex-wrap: wrap;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-type-row .x-pg-cp-label {
	margin-bottom: 0;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-type-select {
	width: 72px;
	flex-shrink: 0;
	font-size: 0.8125rem;
	border-radius: 6px;
	border: 1px solid #e2e8f0;
	cursor: pointer;
}
.x-pg-color-picker-popover-figma .x-pg-cp-angle-label {
	width: 36px;
	margin-left: 4px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-angle-range {
	flex: 1;
	min-width: 60px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-angle-input {
	width: 48px;
	flex-shrink: 0;
	text-align: center;
	font-size: 0.8125rem;
}
.x-pg-color-picker-popover-figma .x-pg-cp-angle-unit {
	font-size: 0.75rem;
	color: #64748b;
	flex-shrink: 0;
}
.x-pg-bgimg-mode-cards {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.x-pg-bgimg-mode-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.35rem;
	padding: 0.5rem 0.6rem;
	min-width: 56px;
	border-radius: var(--x-pg-radius-sm);
	border: 2px solid var(--x-pg-border, #e8ecf1);
	background: #fff;
	color: var(--x-pg-text, #1e293b);
	font-size: 0.75rem;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.x-pg-bgimg-mode-card:hover {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
}
.x-pg-bgimg-mode-card.active {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
	box-shadow: none;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-bgimg-mode-preview {
	width: 44px;
	height: 28px;
	border-radius: 4px;
	background: linear-gradient(135deg, #a5b4fc 0%, #38bdf8 50%, #0ea5e9 100%);
	background-color: #e5e7eb;
	flex-shrink: 0;
}
.x-pg-bgimg-preview-cover {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.x-pg-bgimg-preview-contain {
	background-size: 60% 60%;
	background-position: center;
	background-repeat: no-repeat;
}
.x-pg-bgimg-preview-center {
	background-size: 35% 35%;
	background-position: center;
	background-repeat: no-repeat;
}
.x-pg-bgimg-preview-repeat {
	background-size: 14px 14px;
	background-position: 0 0;
	background-repeat: repeat;
}
.x-pg-style-block .x-pg-bgimg-overlay-btn {
	border-radius: 999px;
	border: 2px solid var(--x-pg-border, #e8ecf1);
	background-color: #fff;
	color: var(--x-pg-text, #1e293b);
	font-size: 0.8rem;
	padding: 0.2rem 0.9rem;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s, box-shadow 0.2s, color 0.2s;
}
.x-pg-style-block .x-pg-bgimg-overlay-btn.active {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
	color: var(--bs-primary);
	box-shadow: none;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-bar-wrap {
	padding: 0 14px 10px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-bar-wrap .x-pg-cp-label {
	margin-bottom: 6px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-bar {
	height: 26px;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	cursor: pointer;
	position: relative;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-stop-dot {
	position: absolute;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	border: 2px solid #fff;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.3);
	transform: translate(-50%, -50%);
	top: 50%;
	cursor: pointer;
	pointer-events: auto;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-stop-dot.selected {
	box-shadow: 0 0 0 2px #334155;
	z-index: 1;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-stops-list {
	padding: 0 14px 10px;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-stop-row {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 4px 6px;
	border-radius: 6px;
	border: 1px solid #e2e8f0;
	background: #fff;
}
.x-pg-color-picker-popover-figma .x-pg-cp-gradient-stop-row.selected {
	border-color: #334155;
	background: #f8fafc;
}
.x-pg-color-picker-popover-figma .x-pg-cp-stop-swatch {
	width: 20px;
	height: 20px;
	border-radius: 4px;
	border: 1px solid rgba(0, 0, 0, 0.15);
	padding: 0;
	cursor: pointer;
	flex-shrink: 0;
}
.x-pg-color-picker-popover-figma .x-pg-cp-stop-percent {
	font-size: 0.75rem;
	color: #475569;
	min-width: 28px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-stop-delete {
	font-size: 1rem;
	line-height: 1;
	cursor: pointer;
}
.x-pg-color-picker-popover-figma .x-pg-cp-stop-color-overlay {
	position: absolute;
	inset: 0;
	background: rgba(255, 255, 255, 0.96);
	z-index: 10;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding: 10px;
	border-radius: 12px;
	overflow-y: auto;
}
.x-pg-color-picker-popover-figma .x-pg-cp-stop-color-overlay-content {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	padding: 10px 12px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	width: 100%;
	max-width: 260px;
}
/* 色標調色 overlay 內容：2d 圓圈 + 透明度拉桿（以 overlay-content 為範圍，確保一定套用） */
.x-pg-cp-stop-color-overlay-content .x-pg-cp-2d-row {
	display: flex;
	gap: 8px;
	padding: 0 0 8px;
	align-items: stretch;
	margin-bottom: 0;
}
.x-pg-cp-stop-color-overlay-content .x-pg-cp-2d-box {
	width: 160px;
	height: 100px;
	position: relative;
	overflow: visible;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	flex-shrink: 0;
	cursor: pointer;
	user-select: none;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% 100%;
}
.x-pg-cp-stop-color-overlay-content .x-pg-cp-2d-knob {
	display: block;
	position: absolute;
	width: 14px;
	height: 14px;
	border: 2px solid #fff;
	border-radius: 50%;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
	transform: translate(-50%, -50%);
	pointer-events: none;
	z-index: 1;
	box-sizing: border-box;
}
.x-pg-cp-stop-color-overlay-content .x-pg-cp-hue-bar {
	width: 12px;
	height: 100px;
	position: relative;
	flex-shrink: 0;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	cursor: pointer;
	user-select: none;
}
.x-pg-cp-stop-color-overlay-content .x-pg-cp-hue-knob {
	display: block;
	position: absolute;
	left: 50%;
	width: 18px;
	height: 4px;
	margin-left: -9px;
	border: 2px solid #fff;
	border-radius: 2px;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
	pointer-events: none;
	transform: translateY(-50%);
	z-index: 1;
	box-sizing: border-box;
}
.x-pg-cp-stop-color-overlay-content .x-pg-cp-alpha-bar {
	width: 12px;
	height: 100px;
	position: relative;
	flex-shrink: 0;
	border-radius: 8px;
	border: 1px solid #e2e8f0;
	cursor: pointer;
	user-select: none;
	background-color: #fff;
}
.x-pg-cp-stop-color-overlay-content .x-pg-cp-alpha-knob {
	display: block;
	position: absolute;
	left: 50%;
	width: 18px;
	height: 4px;
	margin-left: -9px;
	border: 2px solid #fff;
	border-radius: 2px;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
	pointer-events: none;
	transform: translateY(-50%);
	z-index: 1;
	box-sizing: border-box;
}
.x-pg-color-picker-popover-figma .x-pg-cp-stop-color-overlay-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 8px;
}
.x-pg-color-picker-popover-figma .x-pg-cp-stop-color-overlay-header .x-pg-cp-label {
	margin-bottom: 0;
}
.x-pg-color-picker-popover-figma .x-pg-cp-overlay-close {
	flex-shrink: 0;
}
.x-pg-color-picker-popover-figma .x-pg-cp-preset-gradient-btn {
	width: 100%;
	aspect-ratio: 1.6;
	max-width: 44px;
	max-height: 28px;
	border-radius: 6px;
	border: 1px solid rgba(0, 0, 0, 0.12);
	cursor: pointer;
	transition: transform 0.15s, box-shadow 0.15s;
}
.x-pg-color-picker-popover-figma .x-pg-cp-preset-gradient-btn:hover {
	transform: scale(1.05);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}
.x-pg-style-color-row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
}
.x-pg-style-color-row .x-pg-color-picker-with-opacity {
	display: inline-flex;
}
.x-pg-style-color-row .x-pg-color-picker-wrap {
	flex-direction: row;
	gap: 0.35rem;
}
.x-pg-style-color-row .x-pg-color-picker-wrap .form-control-color {
	width: 28px;
	height: 28px;
}
.x-pg-style-opacity-label {
	font-size: 0.8125rem;
	color: var(--x-pg-text-muted, #6c757d);
	margin-left: 0.25rem;
}
.x-pg-style-opacity-slider {
	flex: 1;
	min-width: 80px;
	max-width: 140px;
	height: 6px;
	margin: 0;
}
.x-pg-style-opacity-pct {
	font-size: 0.8125rem;
	color: var(--x-pg-text-muted, #6c757d);
	min-width: 28px;
	text-align: right;
}
.x-pg-opacity-trigger {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	cursor: pointer;
	padding: 0.2rem 0.4rem;
	border-radius: var(--x-pg-radius-sm);
	transition: background 0.15s;
}
.x-pg-opacity-trigger:hover {
	background: rgba(0, 0, 0, 0.06);
}
.x-pg-opacity-popover .form-range {
	margin: 0;
	height: 6px;
}
.x-pg-style-width-cards {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}
.x-pg-width-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.35rem;
	padding: 0.6rem 1rem;
	border: 2px solid var(--x-pg-border, #e8ecf1);
	border-radius: var(--x-pg-radius-sm);
	background: #fff;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
	font-size: 0.8125rem;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-width-card:hover {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
}
.x-pg-width-card.active {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
	box-shadow: none;
}
.x-pg-insert-block-card {
	display: flex;
	align-items: flex-start;
	text-align: left;
	padding: 0.5rem 0.75rem;
	min-height: 4rem;
	border: 2px solid var(--x-pg-border, #e8ecf1);
	border-radius: var(--x-pg-radius-sm);
	background: #fff;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s;
	font-size: inherit;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-insert-block-card:hover:not(:disabled) {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
}
.x-pg-insert-block-card:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}
.x-pg-insert-block-card .x-pg-insert-block-desc {
	font-size: 0.8125rem;
	line-height: 1.3;
	color: var(--x-pg-text-muted, #64748b);
}
.x-pg-width-card-icon {
	width: 48px;
	height: 24px;
	border-radius: 2px;
	background: var(--x-pg-border, #e5e7eb);
}
.x-pg-width-card-icon.x-pg-width-standard {
	width: 48px;
	height: 24px;
	background:
		linear-gradient(90deg, #e5e7eb 0%, #e5e7eb 15%, transparent 15%, transparent 85%, #e5e7eb 85%, #e5e7eb 100%),
		#ffffff;
}
.x-pg-width-card-icon.x-pg-width-full {
	width: 48px;
	height: 24px;
	background:
		linear-gradient(90deg, #e5e7eb 0%, #e5e7eb 5%, transparent 5%, transparent 95%, #e5e7eb 95%, #e5e7eb 100%),
		#ffffff;
}

.x-pg-page-scroll[data-theme="default"] {
	--x-pg-bg: #f8f9fb;
	--x-pg-nav: #0f172a;
	--x-pg-nav-accent: #334155;
	--x-pg-surface: #ffffff;
	--x-pg-border: #e8ecf1;
	--x-pg-text: #1e293b;
	--x-pg-text-muted: #64748b;
	--x-pg-radius: 12px;
	--x-pg-radius-sm: 8px;
	--x-pg-radius-lg: 16px;
	--x-pg-radius-xl: 20px;
	--x-pg-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
	--x-pg-shadow-md: 0 4px 16px -2px rgba(15, 23, 42, 0.06), 0 2px 8px -2px rgba(15, 23, 42, 0.04);
	--x-pg-shadow-lg: 0 10px 32px -4px rgba(15, 23, 42, 0.08), 0 4px 16px -4px rgba(15, 23, 42, 0.04);
	--x-pg-shadow-card: 0 2px 8px rgba(0, 0, 0, 0.04);
	--x-pg-shadow-card-hover: 0 4px 12px rgba(0, 0, 0, 0.05), 0 12px 32px -4px rgba(0, 0, 0, 0.08);
	--x-pg-shadow-elevated: 0 4px 16px rgba(0, 0, 0, 0.05), 0 16px 40px -8px rgba(0, 0, 0, 0.1);
	--x-pg-scrollbar-thumb: rgba(15, 23, 42, 0.12);
	--x-pg-scrollbar-thumb-hover: rgba(15, 23, 42, 0.2);
	--x-pg-edit-accent: #434f84;
	--x-pg-section-gap: 2px;
	--x-pg-scroll-padding: 1em;
	--x-pg-inner-padding: 1em;
	--x-pg-row-inner-padding: 1em;
	--x-pg-title-font-size: 1.25em;
	--x-pg-title-font-weight: 600;
	--x-pg-title-border-width: 2px;
	--x-pg-title-border-color: var(--x-pg-border);
	--x-pg-row-border: none;
	--x-pg-divider-color: transparent;
	background-color: var(--x-pg-bg);
}
.x-pg-style-preview-card[data-theme="default"] {
	background-color: var(--x-pg-bg);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28'%3E%3Ccircle cx='14' cy='14' r='0.8' fill='%2364748b' fill-opacity='0.08'/%3E%3C/svg%3E");
	background-repeat: repeat;
	background-size: 28px 28px;
}
.x-pg-page-style-cards .x-pg-width-card.x-pg-style-preview-card {
	min-width: 88px;
	min-height: 72px;
}
.x-pg-style-preview-card .x-pg-style-preview-card-inner {
	width: 100%;
	height: 12px;
	border-radius: 4px 4px 0 0;
	background-color: var(--x-pg-nav);
	flex-shrink: 0;
}
.x-pg-style-preview-card .x-pg-style-preview-card-block {
	width: 100%;
	min-height: 24px;
	flex: 1;
	border-radius: 0 0 4px 4px;
	background-color: var(--x-pg-surface);
	border: 1px solid var(--x-pg-border);
	border-top: none;
	flex-shrink: 0;
}
.x-pg-carousel-style-cards {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.x-pg-carousel-option-card {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 0.5rem;
	padding: 0.4rem 0.75rem;
	border: 2px solid var(--x-pg-border, #e8ecf1);
	border-radius: var(--x-pg-radius-sm);
	background: #fff;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
	font-size: 0.8125rem;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-carousel-option-card:hover {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
}
.x-pg-carousel-option-card.active {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
	box-shadow: none;
}
.x-pg-carousel-option-icon {
	width: 40px;
	height: 24px;
	border-radius: 2px;
	flex-shrink: 0;
}
.x-pg-carousel-fill-preview {
	background: var(--x-pg-border, #e5e7eb);
}
.x-pg-carousel-spaced-preview {
	background:
		linear-gradient(90deg, #e5e7eb 0%, #e5e7eb 12%, transparent 12%, transparent 88%, #e5e7eb 88%, #e5e7eb 100%),
		#ffffff;
}
.x-pg-carousel-ratio-preview {
	border-radius: 2px;
	background: var(--x-pg-border, #e5e7eb);
	flex-shrink: 0;
}
.x-pg-carousel-ratio-4-3 { width: 32px; height: 24px; }
.x-pg-carousel-ratio-16-9 { width: 36px; height: 20px; }
.x-pg-carousel-ratio-3-2 { width: 33px; height: 22px; }
.x-pg-carousel-ratio-2-1 { width: 32px; height: 16px; }

/* Carousel image grid */
.x-pg-carousel-img-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(88px, 1fr));
	gap: 0.5rem;
	margin-bottom: 0.75rem;
}

/* Carousel image card */
.x-pg-carousel-img-card {
	border: 1.5px solid var(--x-pg-border, #e2e8f0);
	border-radius: 0.375rem;
	overflow: hidden;
	cursor: pointer;
	background: #fff;
	transition: border-color 0.15s, box-shadow 0.15s;
	display: flex;
	flex-direction: column;
}
.x-pg-carousel-img-card:hover {
	border-color: var(--bs-primary, #6366f1);
	box-shadow: 0 0 0 2px rgba(99,102,241,0.15);
}
.x-pg-carousel-img-card--link-open {
	border-color: var(--bs-primary, #6366f1);
	box-shadow: 0 0 0 2px rgba(99,102,241,0.2);
}
.x-pg-carousel-img-card-thumb {
	width: 100%;
	aspect-ratio: 4/3;
	background: #f1f5f9;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.x-pg-carousel-img-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.x-pg-carousel-img-card-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.2rem;
	color: #94a3b8;
}
.x-pg-carousel-img-card-empty i {
	font-size: 1.4rem;
	color: #94a3b8;
}
.x-pg-carousel-img-card-empty span {
	font-size: 0.6rem;
	font-weight: 500;
}
.x-pg-carousel-img-card-uploading {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

/* Card bottom bar */
.x-pg-carousel-img-card-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.25rem 0.35rem 0.25rem 0.5rem;
	border-top: 1px solid var(--x-pg-border, #e8ecf1);
	background: #f8fafc;
	gap: 0.2rem;
}
.x-pg-carousel-img-card-num {
	font-size: 0.65rem;
	font-weight: 500;
	color: #64748b;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	flex: 1;
	min-width: 0;
}
.x-pg-carousel-img-card-actions {
	display: flex;
	align-items: center;
	gap: 0.1rem;
	flex-shrink: 0;
}
.x-pg-carousel-img-action-btn {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border: none;
	background: transparent;
	border-radius: 4px;
	cursor: pointer;
	font-size: 0.75rem;
	color: #64748b;
	transition: background 0.12s, color 0.12s;
	padding: 0;
}
.x-pg-carousel-img-action-btn i {
	color: #64748b;
}
.x-pg-carousel-img-action-btn:hover {
	background: #e2e8f0;
	color: #334155;
}
.x-pg-carousel-img-action-btn:hover i {
	color: #334155;
}
.x-pg-carousel-img-action-btn--active,
.x-pg-carousel-img-action-btn--active i {
	background: rgba(99,102,241,0.1);
	color: #6366f1;
}
.x-pg-carousel-img-action-btn--linked,
.x-pg-carousel-img-action-btn--linked i {
	color: #22c55e;
}
.x-pg-carousel-img-action-btn--linked:hover,
.x-pg-carousel-img-action-btn--linked:hover i {
	color: #16a34a;
}
.x-pg-carousel-img-action-btn--linked:hover {
	background: #dcfce7;
}
.x-pg-carousel-img-action-btn--delete:hover {
	background: #fee2e2;
	color: #dc2626;
}
.x-pg-carousel-img-action-btn--delete:hover i {
	color: #dc2626;
}

/* Link active dot badge */
.x-pg-carousel-link-dot {
	position: absolute;
	top: 2px;
	right: 2px;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: #22c55e;
	border: 1px solid #fff;
}

/* Add new card */
.x-pg-carousel-add-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.2rem;
	aspect-ratio: 4/3;
	border: 2px dashed #cbd5e1;
	border-radius: 0.375rem;
	cursor: pointer;
	background: #f8fafc;
	transition: border-color 0.15s, background 0.15s;
	padding: 0.25rem;
}
.x-pg-carousel-add-card:hover {
	border-color: #6366f1;
	background: rgba(99, 102, 241, 0.04);
}
.x-pg-carousel-add-card i.x-pg-carousel-add-card-icon {
	font-size: 1.1rem;
	color: #6366f1;
}
.x-pg-carousel-add-card:hover i.x-pg-carousel-add-card-icon {
	color: #4f46e5;
}
.x-pg-carousel-add-card-label {
	font-size: 0.7rem;
	font-weight: 600;
	color: #334155;
}
.x-pg-carousel-add-card-hint {
	font-size: 0.6rem;
	color: #94a3b8;
	letter-spacing: 0.01em;
}

/* Inline link edit panel */
.x-pg-carousel-link-panel {
	border: 1px solid var(--bs-primary, #6366f1);
	border-radius: 0.5rem;
	background: #fff;
	margin-bottom: 1rem;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(99,102,241,0.1);
}
.x-pg-carousel-link-panel-header {
	display: flex;
	align-items: center;
	gap: 0.3rem;
	padding: 0.4rem 0.75rem;
	background: #f1f5f9;
	border-bottom: 1px solid var(--x-pg-border, #e8ecf1);
	font-size: 0.8rem;
	font-weight: 600;
	color: #1e293b;
}
.x-pg-carousel-link-panel-header i {
	color: var(--bs-primary, #6366f1);
}
.x-pg-carousel-link-panel-close {
	margin-left: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border: none;
	background: transparent;
	border-radius: 4px;
	cursor: pointer;
	font-size: 0.7rem;
	color: #94a3b8;
	transition: background 0.12s, color 0.12s;
}
.x-pg-carousel-link-panel-close:hover {
	background: #e2e8f0;
	color: #1e293b;
}
.x-pg-carousel-link-panel-body {
	padding: 0.65rem 0.75rem;
}
.x-pg-carousel-link-toggle {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	cursor: pointer;
	font-size: 0.8rem;
	color: #64748b;
	user-select: none;
}
.x-pg-carousel-link-toggle i {
	font-size: 1.2rem;
	color: #cbd5e1;
	transition: color 0.15s;
}
.x-pg-carousel-link-toggle.active i {
	color: var(--bs-primary, #6366f1);
}
.x-pg-carousel-link-toggle.active span {
	color: #1e293b;
	font-weight: 500;
}

.x-pg-row-separator {
	border-radius: 0;
	box-shadow: none;
}
.x-pg-section-outer[data-preview-section^="separatorBlock_"] .x-pg-x-container.x-pg-container-full .x-pg-row-separator,
.x-pg-section-outer[data-preview-section^="separatorBlock_"] .x-pg-x-container.x-pg-container-full .x-pg-page-section-inner.x-pg-separator-inner {
	max-width: none;
	width: 100%;
}
.x-pg-separator-line {
	width: 100%;
	height: 0;
	box-sizing: border-box;
}
.x-pg-separator-inner {
	padding: 0.25rem 0;
	min-height: 0;
}
.x-pg-separator-option-preview {
	width: 36px;
	height: 0;
	flex-shrink: 0;
}
.x-pg-separator-color-input {
	width: 2.5rem;
	height: 2rem;
	padding: 2px;
	border: 1px solid var(--x-pg-border, #e8ecf1);
	border-radius: var(--x-pg-radius-sm);
	cursor: pointer;
	background: transparent;
}

.x-pg-image-text-block {
	display: flex;
	align-items: stretch;
	gap: 1.25rem;
	flex-wrap: nowrap;
}
.x-pg-image-text-block--image-right {
	flex-direction: row-reverse;
}
.x-pg-image-text-block-img {
	flex: 0 0 42%;
	min-width: 0;
	border-radius: var(--x-pg-radius, 0.5rem);
	overflow: hidden;
}
.x-pg-image-text-block-img-inner,
.x-pg-image-text-block-img-inner--free,
.x-pg-image-text-block-img-inner--fill {
	width: 100%;
	height: 100%;
}
.x-pg-image-text-block-text {
	flex: 1 1 auto;
	min-width: 0;
}
@media (max-width: 767px) {
	.x-pg-image-text-block,
	.x-pg-image-text-block--image-right {
		flex-direction: column;
	}
	.x-pg-image-text-block-img {
		flex: 0 0 auto;
		width: 100%;
	}
}

.x-pg-container-highlight {
	box-shadow: 0 0 0 2px #6dcff6;
	border-radius: 0.75rem;
	transition: box-shadow 0.2s ease-out;
}

.x-pg-container-hover-outline {
	box-shadow: 0 0 0 2px #6dcff6;
	border-radius: 0.75rem;
	animation: x-pg-container-outline-blink .8s ease-in-out infinite;
}
@keyframes x-pg-container-outline-blink {
	0%, 100% { box-shadow: 0 0 0 2px rgba(109, 207, 246, 1); }
	50% { box-shadow: 0 0 0 2px rgba(109, 207, 246, 0.25); }
}
.x-pg-padding-popover {
	overflow: visible !important;
}
.x-pg-padding-popover .form-select {
	overflow: visible;
}
.x-pg-form-group {
	margin-bottom: 1.5rem;
	width: 100%;
}

.x-pg-form-group .form-control,
.x-pg-form-group input[type="text"],
.x-pg-form-group input[type="email"],
.x-pg-form-group input[type="tel"],
.x-pg-form-group input[type="url"],
.x-pg-form-group textarea {
	width: 100%;
	box-sizing: border-box;
	border-radius: var(--x-pg-radius-sm);
	border-color: var(--x-pg-border);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.x-pg-form-group .form-control:focus,
.x-pg-form-group input:focus,
.x-pg-form-group textarea:focus {
	border-color: var(--x-pg-nav-accent);
	box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.08);
}

.x-pg-edit-section input::placeholder,
.x-pg-edit-section textarea::placeholder {
	color: #9ca3af;
}

.x-pg-textarea-autogrow {
	overflow-y: hidden;
	overflow-x: hidden;
	resize: none;
	min-height: 2.5em;
	scrollbar-width: none;
	-ms-overflow-style: none;
}

.x-pg-textarea-autogrow::-webkit-scrollbar {
	display: none;
}

.x-pg-form-label {
	font-weight: 500;
	color: var(--x-pg-text);
	margin-bottom: 0.5rem;
	display: block;
	font-size: 0.875rem;
}
/* 僅「標題」欄位：標題與 input 同一行以節省高度 */
.x-pg-form-group.x-pg-form-group--title-inline {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}
.x-pg-form-group.x-pg-form-group--title-inline .x-pg-form-label,
.x-pg-form-group.x-pg-form-group--title-inline .form-label {
	margin-bottom: 0;
	flex-shrink: 0;
}
.x-pg-form-group.x-pg-form-group--title-inline .form-control,
.x-pg-form-group.x-pg-form-group--title-inline input[type="text"] {
	flex: 1;
	min-width: 0;
}

.x-pg-required-badge {
	color: #dc3545;
	margin-left: 0.25rem;
}
.x-pg-required-count-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.1rem;
	height: 1.1rem;
	padding: 0 0.35rem;
	margin-left: 0.35rem;
	font-size: 0.7rem;
	font-weight: 600;
	line-height: 1;
	color: #fff;
	background-color: var(--bs-danger);
	border-radius: 999px;
}

/* ===== 照片上傳（巨頭風格） ===== */
.x-pg-form-group .dropzone {
	border: 2px dashed var(--x-pg-border, #e2e8f0);
	border-radius: 14px;
	padding: 1.5rem 1rem;
	text-align: center;
	background: linear-gradient(180deg, #fafbfc 0%, #f1f5f9 100%);
	cursor: pointer;
	transition: border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease, transform 0.2s ease;
	
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.x-pg-form-group .dropzone:hover {
	border-color: var(--x-pg-edit-accent, #6366f1);
	background: linear-gradient(180deg, rgba(99, 102, 241, 0.06) 0%, rgba(99, 102, 241, 0.02) 100%);
	box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.12), 0 2px 8px rgba(0, 0, 0, 0.06);
}

.x-pg-form-group .dropzone.dragover,
.x-pg-form-group .dropzone.dz-drag-hover {
	border-color: var(--x-pg-edit-accent, #6366f1);
	border-style: solid;
	background: rgba(99, 102, 241, 0.08);
	box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.2), 0 4px 12px rgba(0, 0, 0, 0.08);
	transform: scale(1.005);
}

.x-pg-form-group .dropzone.has-preview {
	position: relative;
	padding: 1rem;
	min-height: 0;
	background: var(--x-pg-surface, #fff);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.x-pg-form-group .dropzone .dropzone-preview-wrap {
	display: inline-block;
	max-width: 100%;
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	transition: box-shadow 0.2s ease;
}

.x-pg-form-group .dropzone .dropzone-preview-wrap:hover {
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
}

.x-pg-form-group .dropzone .dropzone-delete-btn {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 1;
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	color: inherit;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	opacity: 0.9;
	transition: background 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.x-pg-form-group .dropzone .dropzone-delete-btn:hover {
	background: #fff;
	opacity: 1;
	transform: scale(1.08);
}

.x-pg-form-group .dropzone .dz-message {
	flex-wrap: nowrap;
	word-break: break-word;

	justify-content: flex-start;
	align-items: center;
}

.x-pg-form-group .dropzone .dz-message-text {
	min-width: 0;
	flex: 1 1 auto;
	color: var(--x-pg-text-muted, #64748b);
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.01em;
}

.x-pg-form-group .dropzone .dz-message i,
.x-pg-form-group .dropzone .dz-message .bi {
	font-size: 1.75rem;
	color: #94a3b8;
	opacity: 0.9;
}

.x-pg-form-group .dropzone:hover .dz-message i,
.x-pg-form-group .dropzone:hover .dz-message .bi,
.x-pg-form-group .dropzone.dragover .dz-message i,
.x-pg-form-group .dropzone.dragover .dz-message .bi,
.x-pg-form-group .dropzone.dz-drag-hover .dz-message i,
.x-pg-form-group .dropzone.dz-drag-hover .dz-message .bi {
	color: var(--x-pg-edit-accent, #6366f1);
	opacity: 1;
}

/* 區塊背景圖片 dropzone：與照片上傳相同樣式 */
.x-pg-style-tab .dropzone {
	border: 2px dashed var(--x-pg-border, #e2e8f0);
	border-radius: 14px;
	padding: 1.5rem 1rem;
	text-align: center;
	background: linear-gradient(180deg, #fafbfc 0%, #f1f5f9 100%);
	cursor: pointer;
	transition: border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease, transform 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.x-pg-style-tab .dropzone:hover {
	border-color: var(--x-pg-edit-accent, #6366f1);
	background: linear-gradient(180deg, rgba(99, 102, 241, 0.06) 0%, rgba(99, 102, 241, 0.02) 100%);
	box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.12), 0 2px 8px rgba(0, 0, 0, 0.06);
}
.x-pg-style-tab .dropzone.dragover,
.x-pg-style-tab .dropzone.dz-drag-hover {
	border-color: var(--x-pg-edit-accent, #6366f1);
	border-style: solid;
	background: rgba(99, 102, 241, 0.08);
	box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.2), 0 4px 12px rgba(0, 0, 0, 0.08);
	transform: scale(1.005);
}
.x-pg-style-tab .dropzone.has-preview {
	position: relative;
	padding: 1rem;
	min-height: 0;
	background: var(--x-pg-surface, #fff);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}
.x-pg-style-tab .dropzone .dropzone-preview-wrap {
	display: inline-block;
	max-width: 100%;
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	transition: box-shadow 0.2s ease;
}
.x-pg-style-tab .dropzone .dropzone-preview-wrap:hover {
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
}
.x-pg-style-tab .dropzone .dropzone-delete-btn {
	position: absolute;
	top: 8px;
	right: 8px;
	z-index: 1;
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	color: inherit;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	opacity: 0.9;
	transition: background 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}
.x-pg-style-tab .dropzone .dropzone-delete-btn:hover {
	background: #fff;
	opacity: 1;
	transform: scale(1.08);
}
.x-pg-style-tab .dropzone .dz-message {
	flex-wrap: nowrap;
	word-break: break-word;
	justify-content: flex-start;
	align-items: center;
}
.x-pg-style-tab .dropzone .dz-message-text {
	min-width: 0;
	flex: 1 1 auto;
	color: var(--x-pg-text-muted, #64748b);
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.01em;
}
.x-pg-style-tab .dropzone .dz-message i,
.x-pg-style-tab .dropzone .dz-message .bi {
	font-size: 1.75rem;
	color: #94a3b8;
	opacity: 0.9;
}
.x-pg-style-tab .dropzone:hover .dz-message i,
.x-pg-style-tab .dropzone:hover .dz-message .bi,
.x-pg-style-tab .dropzone.dragover .dz-message i,
.x-pg-style-tab .dropzone.dragover .dz-message .bi,
.x-pg-style-tab .dropzone.dz-drag-hover .dz-message i,
.x-pg-style-tab .dropzone.dz-drag-hover .dz-message .bi {
	color: var(--x-pg-edit-accent, #6366f1);
	opacity: 1;
}

.x-pg-photo-preview {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
}

/* ===== 顏色選擇器 ===== */
.x-pg-color-picker {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin-top: 0.5rem;
}

.x-pg-color-option {
	width: 32px;
	height: 32px;
	border-radius: 0.375rem;
	cursor: pointer;
	border: 2px solid transparent;
	transition: all 0.2s ease;
	box-shadow: 0 0.125rem 0.5rem rgba(0, 0, 0, 0.1);
	position: relative;
}

.x-pg-color-option:hover {
	transform: scale(1.1);
	box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.15);
}

.x-pg-color-option.active {
	border-color: var(--x-pg-nav);
	box-shadow: 0 0 0 2px rgba(15, 23, 42, 0.12), var(--x-pg-shadow);
}

/* ===== 資歷區塊 ===== */
.x-pg-experiences-list {
	margin-bottom: 0.5rem;
}

.x-pg-list-add-action {
	margin-top: 0.75rem;
}

.x-pg-list-add-action .btn {
	min-height: 36px;
	padding-left: 0.875rem;
	padding-right: 0.875rem;
}

.x-pg-experience-item {
	margin-bottom: 0.75rem;
	padding: 0.75rem;
	background-color: var(--bs-gray-50);
	border-radius: 0.425rem;
	background-color: var(--bs-gray-100);
}

.x-pg-experience-item-label {
	font-size: 0.875em;
	font-weight: 600;
}

.x-pg-social-link-item-label {
	font-size: 0.875em;
	font-weight: 600;
}

.x-pg-experience-item .x-pg-form-row {
	margin-bottom: 0;
	align-items: center;
}

.x-pg-experience-item .x-pg-form-group {
	margin-bottom: 0;
}

.x-pg-experience-item .x-pg-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: 0.75rem;
	align-items: center;
}

.x-pg-experience-item .x-pg-form-group:last-child {
	width: auto;
	min-width: 50px;
	flex-shrink: 0;
}

/* 資歷精簡列表（與作品集同款：上下鈕排序 + 點擊編輯進 modal） */
.x-pg-experience-sort-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-top: 0.5rem;
	margin-bottom: 1rem;
}
.x-pg-experience-sort-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 7px 10px;
	background: #fff;
	border: 1px solid var(--bs-border-color, #dee2e6);
	border-radius: 8px;
	cursor: default;
	transition: box-shadow 0.15s, border-color 0.15s, opacity 0.15s;
	user-select: none;
}
.x-pg-experience-sort-item:hover {
	box-shadow: 0 2px 8px rgba(0,0,0,0.07);
}
.x-pg-experience-sort-title {
	flex: 1;
	font-size: 13px;
	font-weight: 500;
	color: #374151;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.x-pg-experience-sort-actions {
	display: flex;
	align-items: center;
	gap: 2px;
	flex-shrink: 0;
}
.x-pg-experience-sort-move-btn {
	background: none;
	border: none;
	cursor: pointer;
	padding: 4px 6px;
	border-radius: 4px;
	line-height: 1;
	transition: background 0.15s;
}
.x-pg-experience-sort-move-btn:disabled {
	opacity: 0.2;
	cursor: default;
}
.x-pg-experience-sort-move-btn:not(:disabled):hover {
	background: #e8edf2;
}
.x-pg-experience-sort-move-btn i,
.x-pg-experience-sort-move-btn .bi {
	color: #6b7280 !important;
	font-size: 13px;
}
.x-pg-experience-sort-edit-btn,
.x-pg-experience-sort-delete-btn {
	flex-shrink: 0;
	background: none;
	border: none;
	cursor: pointer;
	padding: 5px 8px;
	border-radius: 5px;
	font-size: 13px;
	line-height: 1;
	transition: background 0.15s, color 0.15s;
}
.x-pg-experience-sort-edit-btn i,
.x-pg-experience-sort-edit-btn .bi,
.x-pg-experience-sort-delete-btn i,
.x-pg-experience-sort-delete-btn .bi {
	color: #8fa3b8 !important;
	transition: color 0.15s;
}
.x-pg-experience-sort-edit-btn:hover {
	background: #f1f5f9;
}
.x-pg-experience-sort-edit-btn:hover i,
.x-pg-experience-sort-edit-btn:hover .bi {
	color: #374151 !important;
}
.x-pg-experience-sort-delete-btn:hover {
	background: #fee2e2;
}
.x-pg-experience-sort-delete-btn:hover i,
.x-pg-experience-sort-delete-btn:hover .bi {
	color: #dc2626 !important;
}

/* 資歷編輯 modal 單欄（僅左側表單，無右欄） */
.x-pg-pmedit-left.x-pg-pmedit-left--single {
	width: 100%;
	min-width: 0;
	max-width: none;
}

/* ===== 社群連結表單 ===== */
.x-pg-social-item {
	padding: 0.75rem;
	background-color: var(--bs-gray-50);
	border-radius: 0.425rem;
	border: 1px solid var(--bs-gray-200);
}

/* ===== 生成按鈕區 ===== */

/* ===== 預覽內容區 ===== */
.x-pg-page-scroll {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	height: 100%;
	padding: 0;
	margin: 0;
	position: relative;
}
.x-pg-page-inner {
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	min-height: 100vh;
	background-color: #f8f9fb;
	
}
.is-wrapper .x-pg-page-inner {
	border: none;
}
.x-pg-page-content {
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
}
.x-pg-page-main {
	flex: 1 1 auto;
	min-height: auto;
}
.x-pg-footer-section,
.x-pg-copyright-section {
	flex-shrink: 0;
}
.x-pg-page-body {
	display: flex;
	flex-direction: column;
}
.x-pg-page-inner-pattern {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}

/* Preview theme: --x-pg-primary, --x-pg-header-text, --x-pg-text, --x-pg-text-muted set by JS on .x-pg-page-inner */
.x-pg-page-inner .x-pg-page-section-title {
	color: var(--x-pg-text, #1e293b);
}
.x-pg-page-inner .x-pg-page-section-title svg {
	color: var(--x-pg-primary, var(--x-pg-nav));
}
.x-pg-page-inner .x-pg-page-description {
	color: var(--x-pg-text, #1e293b);
}
.x-pg-page-inner .x-pg-page-contact-item {
	color: var(--x-pg-text-muted, #64748b);
}
.x-pg-page-inner .x-pg-preview-contact-item svg,
.x-pg-page-inner .x-pg-preview-contact-item a {
	color: var(--x-pg-primary, var(--x-pg-nav));
}
.x-pg-page-inner .x-pg-preview-contact-item a:hover {
	color: var(--x-pg-primary-strong, var(--x-pg-nav-accent));
}
.x-pg-page-inner .x-pg-page-experience-name {
	color: var(--x-pg-text, #1e293b);
}
.x-pg-page-inner .x-pg-page-experience-time {
	color: var(--x-pg-text-muted, #64748b);
}
.x-pg-page-inner .x-pg-page-tag-badge {
	color: var(--x-pg-text, #1e293b);
}

/* Row-level auto text contrast: when inside .x-pg-row, prefer row text vars */
.x-pg-row .x-pg-page-section-title {
	color: var(--x-pg-row-title, var(--x-pg-text, #1e293b));
}
.x-pg-row .x-pg-page-description {
	color: var(--x-pg-row-text, var(--x-pg-text, #1e293b));
}
.x-pg-row .x-pg-page-contact-item {
	color: var(--x-pg-row-text-muted, var(--x-pg-text-muted, #64748b));
}
.x-pg-row .x-pg-page-experience-name {
	color: var(--x-pg-row-text, var(--x-pg-text, #1e293b));
}
.x-pg-row .x-pg-page-experience-time {
	color: var(--x-pg-row-text-muted, var(--x-pg-text-muted, #64748b));
}
.x-pg-row .x-pg-page-tag-badge {
	color: var(--x-pg-row-text, var(--x-pg-text, #1e293b));
}

@media (max-width: 991px) {
	.x-pg-preview-section.preview-expanded .x-pg-page-scroll {
		display: block;
		overflow-y: auto;
		height: calc(100vh - 60px);
		padding: 0;
	}
	
	.x-pg-page-scroll {
		padding: 0;
		background: var(--x-pg-bg);
		min-height: 0;
		display: block !important;
	}
}

/* ===== 預覽空狀態 ===== */
.x-pg-preview-empty {
	text-align: center;
	padding: 3em 1em;
	color: var(--bs-gray-500);
}

.x-pg-preview-empty__icon {
	font-size: 3em;
	margin-bottom: 1em;
	color: var(--bs-gray-400);
}

.x-pg-preview-empty__text {
	font-size: 1em;
	font-weight: 500;
	margin-bottom: 0.5em;
}

.x-pg-preview-empty__hint {
	font-size: 0.875em;
	color: var(--bs-gray-500);
}

/* ===== 長文區塊預覽：至少顯示空白方塊（標準） ===== */
.x-pg-rich-text-block--empty {
	min-height: 120px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	border-radius: 0.5rem;
	background: rgba(0, 0, 0, 0.02);
}
.x-pg-rich-text-block-placeholder {
	color: var(--bs-secondary, #6c757d);
	font-size: 0.875rem;
}
.x-pg-rich-text-content li {
	word-break: break-word;
	overflow-wrap: break-word;
}

/* ===== 載入狀態 ===== */
.x-pg-preview-loading {
	text-align: center;
	padding: 3em 1em;
	color: var(--bs-gray-600);
}

/* ===== 頁面預覽樣式（科技巨頭風格） ===== */

.x-pg-page-header-section {
	position: relative;
}
.x-pg-page-header-section::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 200'%3E%3Ccircle cx='80' cy='60' r='80' fill='rgba(255,255,255,0.07)'/%3E%3Ccircle cx='320' cy='120' r='100' fill='rgba(255,255,255,0.05)'/%3E%3Ccircle cx='200' cy='160' r='60' fill='rgba(255,255,255,0.04)'/%3E%3Cpath d='M0 120 Q100 80 200 100 T400 90 L400 200 L0 200 Z' fill='rgba(255,255,255,0.03)'/%3E%3C/svg%3E");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.x-pg-page-header-section .x-pg-x-container {
	position: relative;
	z-index: 1;
}
.x-pg-page-header-section .x-pg-row {
	padding: 2.5em 2em;
	text-align: center;
	color: #fff;
}

.x-pg-preview-photo {
	width: 120px;
	height: 120px;
	border-radius: 50%;
	object-fit: cover;
	border: 4px solid rgba(255, 255, 255, 0.3);
	margin-bottom: 1em;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12), 0 8px 24px -4px rgba(0, 0, 0, 0.15);
}
.x-pg-page-photo {
	--x-pg-photo-frame-height: 120px;
	width: var(--x-pg-photo-frame-height);
	height: var(--x-pg-photo-frame-height);
	min-width: var(--x-pg-photo-frame-height);
	min-height: var(--x-pg-photo-frame-height);
	max-width: var(--x-pg-photo-frame-height);
	max-height: var(--x-pg-photo-frame-height);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
	background: transparent;
	border: none;
	margin: 0 auto 1em;
	box-shadow: none;
}
.x-pg-avatar-media {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center center;
}
.x-pg-page-photo.x-pg-avatar-shape-rounded,
.x-pg-layout-card-header-photo-img.x-pg-avatar-shape-rounded,
.x-pg-layout-card-header-photo-placeholder.x-pg-avatar-shape-rounded,
.x-pg-layout-split-photo.x-pg-avatar-shape-rounded,
.x-pg-layout-split-photo-placeholder.x-pg-avatar-shape-rounded,
.x-pg-layout-bento-photo-img.x-pg-avatar-shape-rounded,
.x-pg-layout-bento-photo-placeholder.x-pg-avatar-shape-rounded,
.x-pg-layout-editorial-photo.x-pg-avatar-shape-rounded,
.profile-card__image.x-pg-avatar-shape-rounded {
	border-radius: 18px;
	overflow: hidden;
}
.x-pg-page-photo.x-pg-avatar-shape-circle,
.x-pg-layout-card-header-photo-img.x-pg-avatar-shape-circle,
.x-pg-layout-card-header-photo-placeholder.x-pg-avatar-shape-circle,
.x-pg-layout-split-photo.x-pg-avatar-shape-circle,
.x-pg-layout-split-photo-placeholder.x-pg-avatar-shape-circle,
.x-pg-layout-bento-photo-img.x-pg-avatar-shape-circle,
.x-pg-layout-bento-photo-placeholder.x-pg-avatar-shape-circle,
.x-pg-layout-editorial-photo.x-pg-avatar-shape-circle,
.profile-card__image.x-pg-avatar-shape-circle {
	border-radius: 999px;
	overflow: hidden;
}
.x-pg-page-photo.x-pg-avatar-shape-rect,
.x-pg-layout-card-header-photo-img.x-pg-avatar-shape-rect,
.x-pg-layout-card-header-photo-placeholder.x-pg-avatar-shape-rect,
.x-pg-layout-split-photo.x-pg-avatar-shape-rect,
.x-pg-layout-split-photo-placeholder.x-pg-avatar-shape-rect,
.x-pg-layout-bento-photo-img.x-pg-avatar-shape-rect,
.x-pg-layout-bento-photo-placeholder.x-pg-avatar-shape-rect,
.x-pg-layout-editorial-photo.x-pg-avatar-shape-rect,
.profile-card__image.x-pg-avatar-shape-rect {
	border-radius: 0;
	overflow: visible;
}
.x-pg-avatar-media.x-pg-avatar-shape-rect {
	border-radius: 0;
}
.x-pg-avatar-media.x-pg-avatar-shape-rounded {
	border-radius: 18px !important;
	clip-path: inset(0 round 18px);
}
.x-pg-avatar-media.x-pg-avatar-shape-circle {
	border-radius: 999px !important;
	clip-path: circle(50% at 50% 50%);
}
.x-pg-avatar-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	border: none;
	box-shadow: none;
	border-radius: inherit;
	background: transparent;
}
.x-pg-layout-card-header-photo-img,
.x-pg-layout-card-header-photo-placeholder {
	width: 100px;
	height: 100px;
	min-width: 100px;
	min-height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	border-radius: var(--x-pg-radius-xl);
	background: rgba(255,255,255,0.14);
}
.x-pg-page-photo-placeholder,
.x-pg-page-header-section .x-pg-preview-photo-placeholder {
	width: 120px;
	height: 120px;
	min-width: 120px;
	min-height: 120px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1em;
	border: 4px solid rgba(255, 255, 255, 0.3);
	font-size: 4em;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12), 0 8px 24px -4px rgba(0, 0, 0, 0.15);
}
.x-pg-page-photo > .x-pg-preview-photo-placeholder,
.x-pg-layout-split-photo-placeholder > .x-pg-preview-photo-placeholder,
.x-pg-layout-bento .x-pg-layout-bento-photo-placeholder > .x-pg-avatar-placeholder,
.x-pg-layout-editorial .x-pg-layout-editorial-photo-wrap .x-pg-preview-photo-placeholder > .x-pg-avatar-placeholder,
.x-pg-layout-education .x-pg-page-header-section .profile-card__image-placeholder > .x-pg-avatar-placeholder,
.x-pg-layout-card-header-photo-placeholder > .x-pg-avatar-placeholder {
	width: 100%;
	height: 100%;
	min-width: 0;
	min-height: 0;
	margin: 0;
	border: none;
	box-shadow: none;
	font-size: inherit;
}

.x-pg-page-photo-placeholder svg {
	width: 80px;
	height: 80px;
	color: rgba(255, 255, 255, 0.8);
}

.x-pg-page-name {
	font-size: 2em;
	font-weight: 700;
	margin-bottom: 0.5em;
	letter-spacing: -0.02em;
	color: #fff !important;
}

.x-pg-page-title {
	font-size: 1.25em;
	font-weight: 400;
	opacity: 0.95;
	color: #fff !important;
}

.x-pg-page-company {
	font-size: 1em;
	opacity: 0.9;
	margin-top: 0.5em;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	color: #fff !important;
}

/* ===== 關鍵亮點 ===== */
.x-pg-page-highlights {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1em;
	margin-top: 1.5em;
	padding-top: 1.5em;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.x-pg-page-highlight-item {
	background: rgba(255, 255, 255, 0.2);
	backdrop-filter: blur(10px);
	padding: 0.5em 1em;
	border-radius: 2em;
	font-size: 0.9em;
	color: #fff;
	display: flex;
	align-items: center;
	white-space: nowrap;
}

.x-pg-preview-highlight-item i {
	font-size: 0.875em;
	color: #ffd700;
}

.x-pg-preview-highlight-item i[style*="color"] {
	color: inherit;
}

.x-pg-preview-company i[style*="color"] {
	color: inherit;
}

/* 淺色主題（黃/綠等）時 header 使用較深的主色文字（由 React 傳入 --x-pg-header-text） */
.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-name,
.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-title,
.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-company,
.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-highlight-item {
	color: var(--x-pg-header-text, #2d2d2d) !important;
}

.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-company i,
.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-highlight-item i {
	color: var(--x-pg-header-text, #2d2d2d);
}
.x-pg-page-header-section:not(.x-pg-page-header-high-contrast) .x-pg-page-company i,
.x-pg-page-header-section:not(.x-pg-page-header-high-contrast) .x-pg-page-highlight-item i {
	color: rgba(255, 255, 255, 0.98);
}

.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-photo-placeholder svg {
	fill: var(--x-pg-header-text, #2d2d2d);
	opacity: 0.9;
}

.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-highlights {
	border-top-color: color-mix(in srgb, var(--x-pg-header-text, #2d2d2d) 15%, transparent);
}

.x-pg-page-header-section.x-pg-page-header-high-contrast .x-pg-page-highlight-item {
	background: color-mix(in srgb, var(--x-pg-header-text, #2d2d2d) 10%, transparent);
}

/* X-CONTAINER：SECTION 底下一層，避免與其他框架的 container 衝突。預設 max-width 800px；.x-pg-container-full 時為滿版。layout-card 沿用同一規則。 */
.x-pg-x-container {
	width: 100%;
	box-sizing: border-box;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}
.x-pg-x-container.x-pg-container-full {
	max-width: none;
}
/* X-ROW：顏色、陰影在 x-container 底下的 row 做；陰影由方塊陰影開關控制 */
.x-pg-row {
	background: var(--x-pg-surface);
	border: var(--x-pg-row-border);
	border-radius: var(--x-pg-radius);
	box-shadow: none;

	box-sizing: border-box;
	padding: var(--x-pg-row-inner-padding);
}
.x-pg-row.x-pg-page-title-block-row,.x-pg-row.x-pg-page-cta-block-row{
	padding-top:0 !important;
	padding-bottom:0 !important;
}
.x-pg-row.x-pg-row-no-radius {
	border-radius: 0;
}
.x-pg-row.x-pg-row-radius-tl {
	border-top-left-radius: var(--x-pg-radius);
}
.x-pg-row.x-pg-row-radius-tr {
	border-top-right-radius: var(--x-pg-radius);
}
.x-pg-row.x-pg-row-radius-bl {
	border-bottom-left-radius: var(--x-pg-radius);
}
.x-pg-row.x-pg-row-radius-br {
	border-bottom-right-radius: var(--x-pg-radius);
}
.x-pg-row.x-pg-row-radius-top {
	border-radius: 0;
	border-top-left-radius: var(--x-pg-radius);
	border-top-right-radius: var(--x-pg-radius);
}
.x-pg-row.x-pg-row-radius-bottom {
	border-radius: 0;
	border-bottom-left-radius: var(--x-pg-radius);
	border-bottom-right-radius: var(--x-pg-radius);
}
.x-pg-row--fill {
	padding: 0;
}
/* 區塊圖片／輪播／影片選「填滿方塊」時，row 無內距；data-preview-section 在 x-pg-section-outer 上 */
.x-pg-section-outer[data-preview-section^="imageBlock_"] .x-pg-row.x-pg-row--fill,
.x-pg-section-outer[data-preview-section^="carouselBlock_"] .x-pg-row.x-pg-row--fill,
.x-pg-section-outer[data-preview-section^="videoBlock_"] .x-pg-row.x-pg-row--fill {
	padding: 0;
}
.x-pg-section-outer[data-preview-section^="imageBlock_"] .x-pg-row.x-pg-row--fill {
	overflow: hidden;
}
.x-pg-row--spaced {
	padding: var(--x-pg-row-inner-padding);
}
.x-pg-row.x-pg-row-shadow {
	box-shadow: var(--x-pg-shadow-card);
	position: relative;
}
/* 黏在一起的 section：首塊保留上陰影、中間只留左右、尾塊保留下陰影 */
.x-pg-section-outer:has(.x-pg-page-section.pb-0):has(+ .x-pg-section-outer .x-pg-page-section.pt-0):not(.x-pg-section-outer:has(.x-pg-page-section.pb-0) + .x-pg-section-outer:has(.x-pg-page-section.pt-0)) .x-pg-row.x-pg-row-shadow {
	box-shadow:
		0 -6px 14px -12px rgba(0, 0, 0, 0.12),
		-8px 0 12px -10px rgba(0, 0, 0, 0.12),
		8px 0 12px -10px rgba(0, 0, 0, 0.12);
}
.x-pg-section-outer:has(.x-pg-page-section.pb-0) + .x-pg-section-outer:has(.x-pg-page-section.pt-0):has(.x-pg-page-section.pb-0):has(+ .x-pg-section-outer .x-pg-page-section.pt-0) .x-pg-row.x-pg-row-shadow {
	box-shadow:
		-8px 0 12px -10px rgba(0, 0, 0, 0.12),
		8px 0 12px -10px rgba(0, 0, 0, 0.12);
}
.x-pg-section-outer:has(.x-pg-page-section.pb-0) + .x-pg-section-outer:has(.x-pg-page-section.pt-0):not(:has(.x-pg-page-section.pb-0):has(+ .x-pg-section-outer .x-pg-page-section.pt-0)) .x-pg-row.x-pg-row-shadow {
	box-shadow:
		0 6px 14px -12px rgba(0, 0, 0, 0.12),
		-8px 0 12px -10px rgba(0, 0, 0, 0.12),
		8px 0 12px -10px rgba(0, 0, 0, 0.12);
}
.x-pg-page-social .x-pg-row.x-pg-row-shadow,
.x-pg-page-action-buttons .x-pg-row.x-pg-row-shadow,
.x-pg-section-outer[data-preview-section^="imageBlock_"] .x-pg-row.x-pg-row-shadow {
	box-shadow: var(--x-pg-shadow-card) !important;
}
/* 區塊內容預設最大寬 800px；layout-card 不另覆蓋，沿用此規則。 */
.x-pg-page-section-inner {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--x-pg-inner-padding);
	padding-right: var(--x-pg-inner-padding);
}
/* 除五類例外外，選「全滿」時方塊內容物仍為最大寬 800px + 左右 padding（inner + row-inner）。 */
.x-pg-x-container.x-pg-container-full .x-pg-page-section-inner {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
	padding-left: calc(var(--x-pg-inner-padding) + var(--x-pg-row-inner-padding));
	padding-right: calc(var(--x-pg-inner-padding) + var(--x-pg-row-inner-padding));
}
/* 區塊圖片（填滿方塊）、方塊圖片、圖片輪播、線上影片、iframe：滿版且 section-inner 無內距（padding: 0）；data-preview-section 在 x-pg-section-outer 上 */
.x-pg-section-outer[data-preview-section^="imageBlock_"] .x-pg-page-section-inner,
.x-pg-section-outer[data-preview-section^="pureImageBlock_"] .x-pg-page-section-inner,
.x-pg-section-outer[data-preview-section^="carouselBlock_"] .x-pg-page-section-inner,
.x-pg-section-outer[data-preview-section^="videoBlock_"] .x-pg-page-section-inner,
.x-pg-section-outer[data-preview-section^="iframeBlock_"] .x-pg-page-section-inner {
	max-width: none;
	padding: 0;
}
/* 標題區塊：僅不限制最大寬度 */
.x-pg-page-section[data-preview-section^="titleBlock_"] .x-pg-page-section-inner {
	max-width: none;
}
.x-pg-page-section {
	padding: 0;
}
/* 區塊邊界與 section padding 對應：p0~p5 (0=0, 1=0.25rem, 2=0.5rem, 3=1rem, 4=1.5rem, 5=3rem) */
.x-pg-page-section.pt-0 { padding-top: 0; }
.x-pg-page-section.pt-1 { padding-top: 0.25em; }
.x-pg-page-section.pt-2 { padding-top: 0.5em; }
.x-pg-page-section.pt-3 { padding-top: 1em; }
.x-pg-page-section.pt-4 { padding-top: 1.5em; }
.x-pg-page-section.pt-5 { padding-top: 3em; }
.x-pg-page-section.pe-0 { padding-right: 0; }
.x-pg-page-section.pe-1 { padding-right: 0.25em; }
.x-pg-page-section.pe-2 { padding-right: 0.5em; }
.x-pg-page-section.pe-3 { padding-right: 1em; }
.x-pg-page-section.pe-4 { padding-right: 1.5em; }
.x-pg-page-section.pe-5 { padding-right: 3em; }
.x-pg-page-section.pb-0 { padding-bottom: 0; }
.x-pg-page-section.pb-1 { padding-bottom: 0.25em; }
.x-pg-page-section.pb-2 { padding-bottom: 0.5em; }
.x-pg-page-section.pb-3 { padding-bottom: 1em; }
.x-pg-page-section.pb-4 { padding-bottom: 1.5em; }
.x-pg-page-section.pb-5 { padding-bottom: 3em; }
.x-pg-page-section.ps-0 { padding-left: 0; }
.x-pg-page-section.ps-1 { padding-left: 0.25em; }
.x-pg-page-section.ps-2 { padding-left: 0.5em; }
.x-pg-page-section.ps-3 { padding-left: 1em; }
.x-pg-page-section.ps-4 { padding-left: 1.5em; }
.x-pg-page-section.ps-5 { padding-left: 3em; }
#bioPreviewSection.x-pg-page-section {
	padding: 0;
}

.x-pg-page-section-title {
	font-size: var(--x-pg-title-font-size);
	font-weight: var(--x-pg-title-font-weight);
	color: var(--bs-gray-800);
	padding-top: 0.75em;
	padding-bottom: 0.75em;
	border-bottom: var(--x-pg-title-border-width) solid var(--x-pg-title-border-color);
	display: flex;
	align-items: center;
}

.x-pg-page-section-title svg {
	flex-shrink: 0;
	color: var(--x-pg-nav);
}

.x-pg-page-description {
	font-size: 1em;
	line-height: 1.7;
	color: var(--bs-gray-700);
	white-space: pre-line;
	padding-top: 0.5em;
	padding-bottom: 0.5em;
}

.x-pg-page-description strong {
	font-weight: 600;
}

.x-pg-page-description em {
	font-style: italic;
}

.x-pg-page-description u {
	text-decoration: underline;
}

.x-pg-page-description ul,
.x-pg-page-description ol {
	padding-left: 1.5em;
	margin: 0.5em 0;
}

.x-pg-page-contact {
	padding: 0.5em 0;
}

.x-pg-page-contact-item {
	display: flex;
	align-items: center;
	margin-bottom: 0.75em;
	font-size: 0.95em;
	color: var(--bs-gray-700);
}
.x-pg-page-contact-item a {
	text-decoration: none;
}
.x-pg-page-contact-item a:hover {
	text-decoration: none;
}

.x-pg-preview-contact-item svg {
	flex-shrink: 0;
	color: var(--x-pg-nav);
}

.x-pg-preview-contact-item a {
	color: var(--x-pg-nav);
	text-decoration: none;
	transition: color 0.2s;
}

.x-pg-preview-contact-item a:hover {
	color: var(--x-pg-nav-accent);
	text-decoration: underline;
}

.x-pg-preview-social {
	display: flex;
	gap: 1em;
	margin-top: 1.5em;
	padding-bottom: 1.5em;
	padding-top: 1.5em;
	border-top: 1px solid var(--bs-gray-200);
	justify-content: center;
	flex-wrap: wrap;
}

.x-pg-page-social .x-pg-row {
	box-shadow: none !important;
}
.x-pg-page-social .x-pg-row:not(.x-pg-row-no-radius) {
	padding-top: 0;
	padding-bottom: 0;
}

.x-pg-page-social-links-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.75em;
	width: 100%;
}

.x-pg-page-social-link {
	padding: 0.5em 1em;
	border-radius: var(--x-pg-radius-sm);
	color: #fff !important;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	font-size: 0.95em;
	transition: all 0.3s ease;
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12), 0 4px 16px -2px rgba(102, 126, 234, 0.25);
}
.x-pg-page-social .x-pg-page-social-link {
	background: transparent !important;
	box-shadow: none !important;
	border: none !important;
	padding: 0.5em;
	color: inherit !important;
}
.x-pg-page-social .x-pg-page-social-link:hover {
	box-shadow: none !important;
	transform: none;
	background: transparent !important;
	color: inherit !important;
}

.x-pg-page-social-link:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.14), 0 8px 24px -4px rgba(102, 126, 234, 0.35);
	color: #fff !important;
}

.x-pg-page-social-link i,
.x-pg-page-social-link svg {
	font-size: 1.1em;
	color: #fff;
}
.x-pg-page-social .x-pg-page-social-link i,
.x-pg-page-social .x-pg-page-social-link svg,
.x-pg-page-social .x-pg-page-social-link span {
	color: inherit !important;
}

.x-pg-page-social-link span {
	color: #fff !important;
}

/* ===== 資歷預覽 ===== */


.x-pg-page-experience-item {
	padding-bottom: .5rem;
	padding-top: 1rem;
	border-bottom: 1px solid var(--bs-gray-200);
}
.x-pg-page-experience-item:first-of-type{
	padding-top: 0.25em;
}	
.x-pg-page-experience-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 0.75em;
}
.x-pg-page-experience-item:last-of-type{
	border-bottom: 0;
}	

.x-pg-page-experience-description {
	margin-top: 0.5em;
	margin-bottom: 0.5em;
	padding-left: 1.25em;
	list-style-type: disc;
}
.x-pg-page-experience-description li {
	word-break: break-word;
	overflow-wrap: break-word;
}

.x-pg-page-experience-name {
	font-weight: 600;
	color: var(--bs-gray-800);
	font-size: 0.95em;
}

.x-pg-page-experience-time {
	color: var(--bs-gray-600);
	font-size: 0.875em;
}

/* ===== 富文本編輯器 ===== */
/* ===== 關於我編輯器樣式（優化版，接近巨頭編輯器） ===== */
.x-pg-description-toolbar,
.x-pg-portfolio-detail-toolbar {
	display: flex;
	gap: 2px;
	align-items: center;
	padding: 8px;
	background-color: #f8f9fa;
	border: 1px solid #e9ecef;
	border-bottom: none;
	border-radius: 0.375rem 0.375rem 0 0;
	width: 100%;
	box-sizing: border-box;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.x-pg-description-toolbar button,
.x-pg-portfolio-detail-toolbar button {
	border: 1px solid transparent;
	padding: 0.3rem;
	background-color: transparent;
	border-radius: 0.25rem;
	transition: all 0.2s ease;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
}

.x-pg-description-toolbar button:hover,
.x-pg-portfolio-detail-toolbar button:hover {
	background-color: #e9ecef;
	border-color: #dee2e6;
}

.x-pg-description-toolbar button.active,
.x-pg-portfolio-detail-toolbar button.active {
	background-color: #f1f5f9;
	border-color: var(--x-pg-nav-accent);
}

.x-pg-description-toolbar button i,
.x-pg-portfolio-detail-toolbar button i {
	color: var(--x-pg-text-muted);
	font-size: 0.875rem;
	padding-right: 0;
}

.x-pg-description-toolbar button:hover i,
.x-pg-portfolio-detail-toolbar button:hover i {
	color: var(--x-pg-nav);
}

.x-pg-description-toolbar button.active i,
.x-pg-portfolio-detail-toolbar button.active i {
	color: var(--x-pg-nav);
}

.x-pg-description-toolbar .vr,
.x-pg-portfolio-detail-toolbar .vr {
	width: 1px;
	height: 1.25rem;
	background-color: #dee2e6;
	margin: 0 4px;
}
.x-pg-editor-color-wrap {
	position: relative;
}
.x-pg-editor-color-input {
	position: absolute;
	width: 0;
	height: 0;
	opacity: 0;
	pointer-events: none;
}
.x-pg-editor-color-swatch {
	display: inline-block;
	width: 14px;
	height: 14px;
	border-radius: 2px;
	border: 1px solid rgba(0, 0, 0, 0.2);
}
.x-pg-editor-font-size-wrap {
	min-width: 0;
}
.x-pg-editor-font-size-select {
	width: auto;
	min-width: 5rem;
	max-width: 6rem;
}
.x-pg-editor-align-group {
	flex-wrap: nowrap;
	white-space: nowrap;
	gap: 2px;
}
.x-pg-description-toolbar-wrap {
	position: relative;
}
.x-pg-description-toolbar-wrap-hidden {
	display: none;
	margin-bottom: 0 !important;
}
.x-pg-shared-rich-text-editor--focus-within {
	position: relative;
}
.x-pg-editor-link-group {
	gap: 2px;
}
.x-pg-editor-link-btn {
	width: 2rem;
	height: 2rem;
	padding: 0 !important;
}
.x-pg-editor-link-popover {
	position: fixed;
	z-index: 1080;
	max-width: calc(100vw - 24px);
	padding: 0.9rem;
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: 0.85rem;
	background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
	box-shadow: 0 18px 42px rgba(15, 23, 42, 0.16), 0 4px 14px rgba(15, 23, 42, 0.08);
}
.x-pg-editor-link-popover-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 0.75rem;
}
.x-pg-editor-link-popover-title {
	font-size: 0.95rem;
	font-weight: 700;
	color: #0f172a;
}
.x-pg-editor-link-close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.9rem;
	height: 1.9rem;
	padding: 0;
	border-radius: 999px;
	color: #64748b;
	text-decoration: none;
}
.x-pg-editor-link-close:hover {
	background: rgba(148, 163, 184, 0.12);
	color: #0f172a;
}
.x-pg-editor-link-label {
	display: block;
	margin-bottom: 0.35rem;
	font-size: 0.74rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	color: #475569;
	text-transform: uppercase;
}
.x-pg-editor-link-input {
	border-radius: 0.75rem;
	padding: 0.65rem 0.8rem;
	border-color: #dbe4f0;
	box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.04);
}
.x-pg-editor-link-input:focus {
	border-color: rgba(59, 130, 246, 0.45);
	box-shadow: 0 0 0 0.2rem rgba(59, 130, 246, 0.14);
}
.x-pg-editor-link-switch-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 0.85rem;
	padding: 0.85rem 0.95rem;
	border: 1px solid rgba(148, 163, 184, 0.16);
	border-radius: 0.8rem;
	background: rgba(248, 250, 252, 0.95);
}
.x-pg-editor-link-switch-copy {
	min-width: 0;
}
.x-pg-editor-link-switch-title {
	font-size: 0.85rem;
	font-weight: 700;
	color: #0f172a;
}
.x-pg-editor-link-switch-hint {
	margin-top: 0.12rem;
	font-size: 0.75rem;
	color: #64748b;
}
.x-pg-editor-link-switch {
	flex-shrink: 0;
}
.x-pg-editor-link-feedback {
	margin-top: 0.65rem;
	font-size: 0.78rem;
	line-height: 1.5;
	color: #64748b;
}
.x-pg-editor-link-feedback-error {
	color: #dc2626;
}
.x-pg-editor-link-actions {
	display: flex;
	justify-content: flex-end;
	gap: 0.55rem;
	margin-top: 0.85rem;
}
.x-pg-editor-link-actions .btn {
	border-radius: 999px;
	padding-inline: 0.85rem;
	font-weight: 600;
}
.x-pg-portfolio-detail-toolbar .btn.btn-outline-secondary i {
	color: var(--x-pg-text-muted);
}
.x-pg-editor-history-btn {
	padding: 0.25rem 0.4rem;
	border: none !important;
	background: transparent;
	color: #6c757d;
	box-shadow: none !important;
}
.x-pg-editor-history-btn:hover,
.x-pg-editor-history-btn:focus,
.x-pg-editor-history-btn:active {
	border: none;
	background: transparent;
	color: #495057;
	box-shadow: none !important;
}
.x-pg-editor-history-btn:disabled {
	background: transparent;
	color: #dee2e6;
	opacity: 1;
}

.x-pg-description-editor {
	min-height: 200px;
	padding: 1rem;
	border: 1px solid #e9ecef;
	border-top: none;
	border-radius: 0 0 0.375rem 0.375rem;
	background-color: #fff;
	outline: none;
	line-height: 1.75;
	width: 100%;
	color: #000;
	font-size: 14px;
	cursor: text !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
	position: relative;
	overflow: visible;
}
.x-pg-description-editor--toolbar-collapsed {
	border-top: 1px solid #e9ecef;
	border-radius: 0.375rem;
}

.x-pg-description-editor:focus {
	
	box-shadow: 0 0 0 0.1rem rgba(84, 99, 165, 0.15);
	cursor: text !important;
}

/* placeholder 與輸入文字同一排版流，對齊一致 */
.x-pg-description-editor[data-placeholder]:empty:before {
	content: attr(data-placeholder);
	color: #6c757d;
	pointer-events: none;
}

.x-pg-description-editor[data-placeholder]:focus:empty:before {
	content: attr(data-placeholder);
	color: #adb5bd;
}

.x-pg-description-editor {
	color: #000;
}
.x-pg-description-editor::selection,
.x-pg-description-editor *::selection {
	background-color: rgba(13, 110, 253, 0.22);
	color: #000;
}
.x-pg-description-editor::-moz-selection,
.x-pg-description-editor *::-moz-selection {
	background-color: rgba(13, 110, 253, 0.22);
	color: #000;
}
.x-pg-description-editor * {
	cursor: text !important;
}

.x-pg-description-editor p {
	margin: 0 0 0.75rem 0;
}
.x-pg-description-editor p.x-pg-editor-insert-paragraph {
	margin: 0 !important;
}

.x-pg-description-editor p:last-child {
	margin-bottom: 0;
}

.x-pg-description-editor strong {
	font-weight: 600;
}

.x-pg-description-editor em {
	font-style: italic;
}

.x-pg-description-editor u {
	text-decoration: underline;
}

.x-pg-description-editor ul,
.x-pg-description-editor ol {
	padding-left: 1.75rem;
	margin: 0.75rem 0;
}

.x-pg-description-editor li {
	margin-bottom: 0.5rem;
	word-break: break-word;
	overflow-wrap: break-word;
}

.x-pg-description-editor li:last-child {
	margin-bottom: 0;
}

.x-pg-editor-img-wrapper {
	display: block;
	width: 100%;
	max-width: 100%;
	overflow: visible;
	position: relative;
}

.x-pg-editor-img-inner {
	position: relative;
	display: inline-block;
	max-width: 100%;
	vertical-align: bottom;
}

.x-pg-editor-img-wrapper img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
}

.x-pg-editor-img-resize-handle {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 24px;
	height: 24px;
	background-color: rgba(0, 0, 0, 0.5);
	border-radius: 2px;
	cursor: pointer !important;
	box-shadow: 0 0 0 2px #fff;
	z-index: 10;
	pointer-events: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.x-pg-editor-img-resize-handle svg {
	width: 14px;
	height: 14px;
	fill: currentColor;
	pointer-events: none;
}
.x-pg-description-editor .x-pg-editor-img-resize-handle {
	background-color: rgba(13, 110, 253, 0.9);
	cursor: pointer !important;
}
.x-pg-description-editor .x-pg-editor-img-wrapper {
	cursor: default !important;
}
.x-pg-description-editor .x-pg-editor-img-wrapper .x-pg-editor-img-resize-handle {
	cursor: pointer !important;
}
.x-pg-editor-img-insert-line {
	position: absolute;
	left: 0;
	width: 100%;
	height: 14px;
	padding: 0;
	border: none;
	background: transparent;
	display: none;
	align-items: center;
	justify-content: center;
	cursor: text !important;
	z-index: 5;
}
.x-pg-editor-img-insert-line-before {
	top: -10px;
}
.x-pg-editor-img-insert-line-after {
	bottom: -10px;
}
.x-pg-editor-img-insert-line-bar {
	display: block;
	width: 100%;
	height: 1px;
	background-color: rgba(13, 110, 253, 0.65);
}
.x-pg-editor-img-wrapper:hover .x-pg-editor-img-insert-line,
.x-pg-editor-img-wrapper.x-pg-editor-img-wrapper-selected .x-pg-editor-img-insert-line {
	display: flex;
}
.x-pg-editor-img-resize-popup {
	position: fixed;
	z-index: 1050;
	background: #fff;
	border: 1px solid #dee2e6;
	border-radius: 6px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	padding: 10px 14px;
	min-width: 188px;
}
.x-pg-editor-img-resize-popup label {
	display: block;
	font-size: 12px;
	color: #495057;
	margin-bottom: 6px;
}
.x-pg-editor-img-resize-popup input[type="range"] {
	width: 100%;
	margin: 0;
	cursor: pointer;
}
.x-pg-editor-img-resize-popup .x-pg-editor-resize-percent {
	font-size: 11px;
	color: #6c757d;
	margin-top: 4px;
	text-align: right;
}
.x-pg-editor-img-wrapper.x-pg-editor-img-wrapper-selected {
	outline: 2px solid var(--bs-primary, #0d6efd);
	outline-offset: 2px;
	border-radius: 4px;
}
.x-pg-editor-img-wrapper[data-align="left"] {
	display: block !important;
	width: 100% !important;
	text-align: left !important;
	margin-left: 0;
	margin-right: 0;
}
.x-pg-editor-img-wrapper[data-align="left"] img {
	display: block !important;
	width: 100% !important;
}
.x-pg-editor-img-wrapper[data-align="center"] {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	margin-left: 0;
	margin-right: 0;
}
.x-pg-editor-img-wrapper[data-align="center"] img {
	display: block !important;
	width: 100% !important;
}
.x-pg-editor-img-wrapper[data-align="right"] {
	display: block !important;
	width: 100% !important;
	text-align: right !important;
	margin-left: 0;
	margin-right: 0;
}
.x-pg-editor-img-wrapper[data-align="right"] img {
	display: block !important;
	width: 100% !important;
}
.x-pg-editor-img-delete {
	position: absolute;
	top: 4px;
	right: 4px;
	width: 22px;
	height: 22px;
	padding: 0;
	border: none;
	border-radius: 4px;
	background-color: rgba(0, 0, 0, 0.6);
	color: #fff;
	font-size: 1.25rem;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 10;
	pointer-events: auto;
}
.x-pg-editor-img-delete:hover {
	background-color: rgba(220, 53, 69, 0.9);
}

.x-pg-page-description .x-pg-img-block {
	display: block;
	width: 100%;
	margin: 0.5rem 0;
}
.x-pg-page-description .x-pg-img-block img {
	display: inline-block !important;
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
.x-pg-page-description .x-pg-img-block.x-pg-img-align-left {
	text-align: left;
}
.x-pg-page-description .x-pg-img-block.x-pg-img-align-center {
	text-align: center;
}
.x-pg-page-description .x-pg-img-block.x-pg-img-align-right {
	text-align: right;
}

/* ===== 響應式設計 ===== */
@media (max-width: 768px) {
	.x-pg-page-name {
		font-size: 1.5em;
	}

	.x-pg-page-title {
		font-size: 1em;
	}

	.x-pg-experience-item .x-pg-form-row {
		grid-template-columns: 1fr;
		gap: 0.5rem;
	}

	.x-pg-experience-item .x-pg-form-group:last-child {
		text-align: right;
	}

	.x-pg-description-toolbar {
		flex-wrap: wrap;
	}
	.x-pg-editor-link-popover {
		max-width: none;
	}
}

/* ===== 作品集 ===== */
.x-pg-portfolio-list {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	margin-bottom: 0.5rem;
}

/* PC 版：作品列表保持單欄，項目內部橫向布局 */
@media (min-width: 992px) {
	.x-pg-portfolio-list {
		display: flex;
		flex-direction: column;
		gap: 2rem;
	}
}

/* 平板版：加上 padding */
@media (min-width: 768px) and (max-width: 991px) {
	.x-pg-portfolio-list {
		padding: 0 1rem;
	}
	
	.x-pg-portfolio-item {
		padding: 1rem;
	}
}

/* 手機版：加上 padding */
@media (max-width: 767px) {
	.x-pg-portfolio-list {
		padding: 0 0.75rem;
	}
	
	.x-pg-portfolio-item {
		padding: 0.75rem;
	}
}

.x-pg-portfolio-item {
	position: relative;
	border-radius: 0.5rem;
	background-color: var(--bs-gray-100);
	border: 1px solid var(--bs-gray-200);
}

/* PC 版：橫向布局 */
@media (min-width: 992px) {
	.x-pg-portfolio-item {
		padding: 1.5rem;
	}
	
	.x-pg-portfolio-item-content {
		display: flex;
		gap: 1.5rem;
		margin-bottom: 1.5rem;
		align-items: flex-end; /* 底部切齊 */
	}
	
	.x-pg-portfolio-item-image-section {
		flex: 0 0 300px;
		min-width: 300px;
	}
	
	.x-pg-portfolio-item-text-section {
		flex: 1;
		min-width: 0;
		display: flex;
		flex-direction: column;
		justify-content: flex-end; /* 底部切齊 */
	}
	
	.x-pg-portfolio-item-bottom-section {
		width: 100%;
		padding-top: 1rem;
		border-top: 1px solid var(--bs-gray-200);
	}
}

/* 平板/手機版：垂直布局 */
@media (max-width: 991px) {
	.x-pg-portfolio-item {
		padding: 1rem;
	}
	
	.x-pg-portfolio-item-content {
		display: flex;
		flex-direction: column;
	}
	
	.x-pg-portfolio-item-image-section,
	.x-pg-portfolio-item-text-section,
	.x-pg-portfolio-item-bottom-section {
		width: 100%;
	}
}

/* 作品詳細敘述編輯器樣式 */
.x-pg-portfolio-detail-editor-container {
	border: 1px solid var(--bs-gray-300);
	border-radius: 0.375rem;
	background: #fff;
}

.x-pg-portfolio-detail-editor {
	min-height: 150px;
	padding: 1rem;
	border: 1px solid #e9ecef;
	border-top: none;
	border-radius: 0 0 0.375rem 0.375rem;
	background-color: #fff;
	outline: none;
	line-height: 1.75;
	width: 100%;
	color: #000;
	font-size: 0.9375rem;
	cursor: text !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
	position: relative;
	box-sizing: border-box;
}

.x-pg-portfolio-detail-editor:focus {
	box-shadow: 0 0 0 0.1rem rgba(84, 99, 165, 0.15);
	cursor: text !important;
}

/* 真正的 placeholder 效果（使用 ::before 偽元素） */
.x-pg-portfolio-detail-editor[data-placeholder]:empty:before {
	content: attr(data-placeholder);
	color: #6c757d;
	pointer-events: none;
	position: absolute;
	top: 1rem;
	left: 1rem;
}

.x-pg-portfolio-detail-editor[data-placeholder]:focus:empty:before {
	content: attr(data-placeholder);
	color: #adb5bd;
}

.x-pg-portfolio-detail-editor * {
	cursor: text !important;
	color: #000;
}

.x-pg-portfolio-detail-editor p {
	margin: 0 0 0.75rem 0;
}

.x-pg-portfolio-detail-editor p:last-child {
	margin-bottom: 0;
}

.x-pg-portfolio-detail-editor img {
	max-width: 100%;
	height: auto;
	border-radius: 0.375rem;
	margin: 0.5rem 0;
}

.x-pg-portfolio-detail-editor strong {
	font-weight: 600;
	color: #000;
}

.x-pg-portfolio-detail-editor em {
	font-style: italic;
	color: #000;
}

.x-pg-portfolio-detail-editor u {
	text-decoration: underline;
	color: #000;
}

.x-pg-portfolio-detail-editor ul,
.x-pg-portfolio-detail-editor ol {
	padding-left: 1.75rem;
	margin: 0.75rem 0;
	color: #000;
}

.x-pg-portfolio-detail-editor li {
	margin-bottom: 0.5rem;
	color: #000;
	word-break: break-word;
	overflow-wrap: break-word;
}

.x-pg-portfolio-detail-editor li:last-child {
	margin-bottom: 0;
}

/* 顯示方式按鈕組樣式 */
.x-pg-portfolio-display-type-group {
	border: 1px solid var(--bs-gray-300);
	border-radius: 0.375rem;
	overflow: hidden;
	display: flex;
}

.x-pg-portfolio-display-type-group .btn {
	border: none;
	border-radius: 0;
	flex: 1;
}

.x-pg-portfolio-display-type-group .btn:not(:last-child) {
	border-right: 1px solid var(--bs-gray-300);
}

.x-pg-portfolio-display-type-group .btn-check:checked + .btn {
	background-color: var(--x-pg-nav);
	color: #fff;
	border-color: var(--x-pg-nav);
	z-index: 1;
}

.x-pg-portfolio-preview {
	position: relative;
	width: 100%;
	padding-top: 100%;
	overflow: hidden;
}

.x-pg-portfolio-preview img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.x-pg-portfolio-preview .x-pg-remove-portfolio {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	z-index: 10;
}

/* ===== 區塊圖片區塊預覽（每張圖填滿 row 寬度） ===== */
.x-pg-page-image-block {
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 0;
}
.x-pg-page-image-block--spaced .x-pg-page-image-block-item {
	margin-bottom: 0.75rem;
}
.x-pg-page-image-block--spaced .x-pg-page-image-block-item:last-child {
	margin-bottom: 0;
}
.x-pg-page-image-block--spaced .x-pg-page-image-block-image {
	border-radius: 0.5rem;
	overflow: hidden;
	box-shadow: var(--x-pg-shadow-card);
}
.x-pg-page-image-block-item {
	width: 100%;
	margin: 0;
}
.x-pg-page-image-block-image {
	width: 100%;
	overflow: hidden;
	background-color: var(--bs-gray-100);
	position: relative;
}
.x-pg-page-image-block-image a {
	display: block;
	width: 100%;
}
.x-pg-page-image-block-image.x-pg-page-image-block-placeholder,
.x-pg-page-image-block-placeholder-inner {
	background-color: #b8c4ce !important;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	min-height: 120px;
}
.x-pg-page-image-block-placeholder-text,
.x-pg-page-image-block-placeholder-inner {
	color: #64748b;
}
.x-pg-page-image-block-placeholder-inner svg {
	color: inherit;
}
.x-pg-page-image-block-image img {
	width: 100%;
	display: block;
	vertical-align: middle;
}

/* ===== 方塊圖片區塊預覽（原始尺寸、置中、不撐出容器） ===== */
.x-pg-page-pure-image-block {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.75rem;
}
.x-pg-page-pure-image-block-item {
	width: 100%;
	display: flex;
	justify-content: center;
}
.x-pg-page-pure-image-block-item a {
	display: block;
	width: 100%;
}
.x-pg-page-pure-image-block-item img {
	max-width: 100%;
	height: auto;
	display: block;
	margin-left: auto;
	margin-right: auto;
	vertical-align: middle;
}
.x-pg-page-pure-image-block-placeholder {
	width: 100%;
	min-height: 120px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #b8c4ce;
	color: #64748b;
}
.x-pg-page-pure-image-block-placeholder-text {
	color: inherit;
}

/* ===== 作品集輪播預覽 ===== */
.x-pg-page-portfolio-grid {
	position: relative;
	width: 100%;
}

.x-pg-portfolio-page {
	display: none;
}

.x-pg-portfolio-page.active {
	display: block;
}

.x-pg-page-portfolio-grid.x-pg-portfolio-single {
	display: block;
	margin-bottom: 1rem;
}
.x-pg-page-portfolio-grid.x-pg-portfolio-single .x-pg-portfolio-grid-item {
	width: 100%;
	margin-bottom: 0;
}
.x-pg-page-portfolio-grid.x-pg-portfolio-single .x-pg-portfolio-grid-image {
	aspect-ratio: 16 / 9;
	min-height: 200px;
}
.x-pg-page-portfolio-grid.x-pg-portfolio-single .x-pg-portfolio-grid-content {
	padding: 1rem;
}

.x-pg-page-portfolio-grid.x-pg-portfolio-two {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
	margin-bottom: 0;
}

.x-pg-page-portfolio-grid.x-pg-portfolio-carousel {
	overflow: hidden;
	margin-bottom: 0;
}
.x-pg-portfolio-carousel-track {
	display: flex;
	transition: transform 0.35s ease-out;
	width: 100%;
}
.x-pg-portfolio-carousel-slide {
	flex: 0 0 100%;
	width: 100%;
	min-width: 0;
	padding: 0 0.25rem;
	box-sizing: border-box;
}
.x-pg-portfolio-carousel-slide .x-pg-portfolio-grid-item {
	width: 100%;
}

.x-pg-portfolio-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}

.x-pg-portfolio-grid-item {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 0.5rem;
	overflow: hidden;
	box-shadow: 0 0.1rem 0.3rem rgba(0, 0, 0, 0.1);
	transition: transform 0.2s, box-shadow 0.2s;
}

.x-pg-portfolio-grid-item:hover {
	transform: translateY(-2px);
	box-shadow: 0 0.2rem 0.5rem rgba(0, 0, 0, 0.15);
}

.x-pg-portfolio-grid-image {
	width: 100%;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background-color: var(--bs-gray-100);
	position: relative;
}

.x-pg-portfolio-grid-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.x-pg-portfolio-grid-image {
	position: relative;
	overflow: hidden;
}

.x-pg-portfolio-grid-image > div {
	width: 100%;
	height: 100%;
	min-height: 200px;
}

/* ===== 圖片輪播區塊（carouselBlock，科技巨頭風格） ===== */
.x-pg-page-carousel-block {
	position: relative;
	width: 100%;
	overflow: visible;
	border-radius: 0.5rem;
	background: #f0f2f5;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
.x-pg-page-carousel-block--spaced {
	background: transparent;
	box-shadow: none;
}
.x-pg-page-carousel-block--spaced .x-pg-page-carousel-viewport {
	border-radius: 0.5rem;
	overflow: hidden;
	box-shadow: var(--x-pg-shadow-card);
}
.x-pg-page-carousel-block--spaced .x-pg-page-carousel-slide-inner,
.x-pg-page-carousel-block--spaced .x-pg-page-carousel-block-placeholder {
	border-radius: 0.5rem;
}
.x-pg-page-carousel-viewport {
	position: relative;
	width: 100%;
	overflow: hidden;
	border-radius: 0.5rem;
	touch-action: pan-y pinch-zoom;
}

/* 倒數預覽提示 tooltip（取代原生 title 樣式） */
.countdown_banner .countdown-preview-hint {
	position: absolute;
	right: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: 11px;
	line-height: 1.2;
	background: rgba(0, 0, 0, 0.25);
	color: #fff;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	cursor: default;
}

.countdown_banner .countdown-preview-hint i {
	font-size: 13px;
	opacity: 0.9;
}

.countdown_banner .countdown-preview-hint span {
	white-space: nowrap;
}

.countdown_banner .countdown-preview-hint::after {
	content: attr(data-tooltip);
	position: absolute;
	right: 0;
	top: 100%;
	margin-top: 6px;
	padding: 6px 10px;
	border-radius: 6px;
	background: rgba(0, 0, 0, 0.85);
	color: #fff;
	font-size: 11px;
	line-height: 1.4;
	white-space: normal;
	max-width: 280px;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
	opacity: 0;
	pointer-events: none;
	transform: translateY(2px);
	transition: opacity 0.15s ease-out, transform 0.15s ease-out;
	z-index: 999;
}

.countdown_banner .countdown-preview-hint::before {
	content: "";
	position: absolute;
	right: 10px;
	top: 100%;
	margin-top: 1px;
	border-width: 5px;
	border-style: solid;
	border-color: rgba(0, 0, 0, 0.85) transparent transparent transparent;
	opacity: 0;
	transition: opacity 0.15s ease-out;
	z-index: 999;
}

.countdown_banner .countdown-preview-hint:hover::after,
.countdown_banner .countdown-preview-hint:hover::before {
	opacity: 1;
	transform: translateY(0);
}
.x-pg-page-carousel-track {
	display: flex;
	transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	width: 100%;
}
.x-pg-page-carousel-slide {
	flex: 0 0 100%;
	width: 100%;
	min-width: 0;
}
.x-pg-page-carousel-slide-inner {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #e8eaed;
}
.x-pg-page-carousel-slide-inner img {
	width: 100%;
	height: 100%;
	object-fit: scale-down;
	display: block;
}
.x-pg-page-carousel-block-placeholder {
	aspect-ratio: 16 / 9;
	background: linear-gradient(135deg, #e8eaed 0%, #dfe1e6 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #8b9199;
	font-size: 0.875rem;
	letter-spacing: 0.02em;
	border-radius: 0.5rem;
}
.x-pg-page-carousel-block-placeholder::before {
	content: "";
	width: 64px;
	height: 64px;
	opacity: 0.4;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238b9199' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='2'/%3E%3Ccircle cx='8.5' cy='8.5' r='1.5'/%3E%3Cpath d='M21 15l-5-5L5 21'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-right: 0.5rem;
}
.x-pg-page-carousel-block-placeholder span {
	position: relative;
	z-index: 1;
}
.x-pg-page-carousel-arrows {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	pointer-events: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 0.5rem;
	z-index: 4;
}
.x-pg-page-carousel-arrows .x-pg-page-carousel-prev,
.x-pg-page-carousel-arrows .x-pg-page-carousel-next {
	pointer-events: auto;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.45);
	color: #fff;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	opacity: 0;
	transition: opacity 0.2s ease, background 0.2s ease, transform 0.2s ease;
	flex-shrink: 0;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}
.x-pg-page-carousel-arrows .x-pg-page-carousel-prev svg,
.x-pg-page-carousel-arrows .x-pg-page-carousel-next svg {
	flex-shrink: 0;
}
.x-pg-page-carousel-block:hover .x-pg-page-carousel-arrows .x-pg-page-carousel-prev,
.x-pg-page-carousel-block:hover .x-pg-page-carousel-arrows .x-pg-page-carousel-next {
	opacity: 1;
}
.x-pg-page-carousel-arrows .x-pg-page-carousel-prev:hover,
.x-pg-page-carousel-arrows .x-pg-page-carousel-next:hover {
	background: rgba(0, 0, 0, 0.6);
	transform: scale(1.08);
}
@media (hover: none) {
	.x-pg-page-carousel-arrows .x-pg-page-carousel-prev,
	.x-pg-page-carousel-arrows .x-pg-page-carousel-next {
		opacity: 0.9;
	}
}
.x-pg-page-carousel-indicators-wrap {
	padding: 0.75rem 0.5rem 0.25rem;
	display: flex;
	justify-content: center;
	align-items: center;
}
.x-pg-page-carousel-indicators {
	display: flex;
	gap: 0.5rem;
	align-items: center;
	justify-content: center;
}
.x-pg-page-carousel-indicator {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #c2c6cc;
	border: none;
	padding: 0;
	cursor: pointer;
	transition: all 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.x-pg-page-carousel-indicator:hover {
	background: #9ca3af;
}
.x-pg-page-carousel-indicator.active {
	background: var(--x-pg-nav, #374151);
	width: 20px;
	border-radius: 3px;
}

/* ===== 標籤區塊（tagBlock） ===== */
.x-pg-page-tag-block-row {
	background: transparent;
}
.x-pg-page-tag-block {
	text-align: center;
	padding: 0.75rem 0;
}
.x-pg-page-tag-block-title {
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 0.75rem;
}
.x-pg-page-tag-block-tags {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem;
}
.x-pg-page-tag-badge {
	display: inline-block;
	padding: 0.35rem 0.75rem;
	border-radius: 2rem;
	background: rgba(0, 0, 0, 0.06);
	font-size: 0.875rem;
	color: var(--bs-gray-800);
	border: 1px solid rgba(0, 0, 0, 0.08);
}
.x-pg-page-tag-block-empty {
	padding: 0.5rem 0;
}

/* ===== 線上影片區塊（videoBlock） ===== */
.x-pg-page-video-block {
	width: 100%;
	border-radius: 0.5rem;
	overflow: visible;
	background: #e8eaed;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
.x-pg-page-video-block--spaced {
	background: transparent;
	box-shadow: none;
}
.x-pg-page-video-block--spaced .x-pg-page-video-wrapper,
.x-pg-page-video-block--spaced .x-pg-page-video-placeholder {
	border-radius: 0.5rem;
	overflow: hidden;
}
.x-pg-page-video-wrapper {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: #e8eaed;
}
.x-pg-page-video-wrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}
.x-pg-page-video-placeholder {
	aspect-ratio: 16 / 9;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	background-color: #b8c4ce;
	color: #64748b;
}
/* 手機版：直式影片（9:16，如 Shorts）填滿方塊寬度、依比例顯示 */
.x-pg-preview-frame.mobile .x-pg-page-video-wrapper--vertical {
	aspect-ratio: 9 / 16;
	width: 100%;
	display: block;
}
@media (max-width: 767px) {
	.x-pg-page-video-wrapper--vertical {
		aspect-ratio: 9 / 16;
		width: 100%;
		display: block;
	}
}

/* ===== iframe 區塊（貼滿 row，無留白；data-preview-section 在 x-pg-section-outer 上） ===== */
.x-pg-section-outer[data-preview-section^="iframeBlock_"] .x-pg-row {
	padding: 0;
}
/* ===== 橫幅區塊 row 無內距 ===== */
.x-pg-section-outer[data-preview-section^="bannerBlock_"] .x-pg-row {
	padding: 0;
}
.x-pg-page-iframe-block {
	width: 100%;
	border-radius: 0.5rem;
	overflow: hidden;
	background: #b8c4ce;
}
.x-pg-page-iframe-wrapper {
	position: relative;
	width: 100%;
	height: 400px;
}
.x-pg-page-iframe-wrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}
.x-pg-page-iframe-placeholder {
	height: 400px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	background: #b8c4ce;
	color: #64748b;
}

/* ===== 營業資訊區塊（businessInfoBlock），row 樣式同聯絡資訊 ===== */
.x-pg-page-business-info-block {
	padding: 0;
}
.x-pg-page-business-info-block-title {
	padding: 0 0 0.5rem;
	color: var(--x-pg-text, #1e293b);
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}
.x-pg-page-business-info-header {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1rem 0.25rem;
	color: #555;
	font-size: 1rem;
	font-weight: 500;
}
.x-pg-page-business-info-icon {
	font-size: 1.25rem;
	opacity: 0.85;
}
.x-pg-page-business-info-title {
	flex: 1;
}
.x-pg-page-business-info-content {
	padding: 0 1rem 1rem;
}
.x-pg-page-business-info-hours,
.x-pg-page-business-info-rows {
	margin: 0;
}
.x-pg-page-business-info-line {
	color: #666;
	font-size: 0.9375rem;
	line-height: 1.5;
	margin: 0 0 0.35rem 0;
	padding: 0;
}
.x-pg-page-business-info-line:last-child {
	margin-bottom: 0;
}
.x-pg-page-business-info-custom {
	padding: 0.5rem 1rem 1rem;
}
.x-pg-page-business-info-custom-row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: #666;
	font-size: 0.9375rem;
	line-height: 1.5;
	margin: 0 0 0.35rem 0;
}
.x-pg-page-business-info-custom-row:last-child {
	margin-bottom: 0;
}
.x-pg-page-business-info-custom-label {
	font-weight: 500;
	color: #555;
	min-width: 3em;
}
.x-pg-page-business-info-custom-value {
	flex: 1;
}
.x-pg-page-business-info-empty {
	padding: 0.5rem 1rem 1rem;
}

/* 營業資訊自訂項目編輯（表單側，參考 x-pg-experience-item） */
.x-pg-business-info-custom-list {
	margin-bottom: 0.5rem;
}
.x-pg-business-info-custom-item {
	margin-bottom: 0.75rem;
	padding: 0.75rem;
	background-color: var(--bs-gray-100);
	border-radius: 0.425rem;
	border: 1px solid var(--bs-gray-200);
}
.x-pg-business-info-custom-item-row1 {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0.5rem;
}
.x-pg-business-info-custom-item-row1 .x-pg-business-info-label-inp {
	flex: 1;
	min-width: 0;
}
.x-pg-business-info-custom-item-row2 {
	width: 100%;
}
/* 頁尾聯絡資訊卡片 */
.x-pg-footer-contact-list {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}
.x-pg-footer-contact-card {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 0.625rem;
	padding: 0.75rem;
	box-shadow: 0 1px 3px rgba(0,0,0,0.06);
	transition: box-shadow 0.15s, border-color 0.15s;
}
.x-pg-footer-contact-card:hover {
	border-color: #c7d2fe;
	box-shadow: 0 2px 8px rgba(99,102,241,0.08);
}
.x-pg-footer-contact-card-row1 {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}
.x-pg-footer-contact-card-row1 .form-control {
	flex: 1;
	min-width: 0;
}
.x-pg-footer-contact-card-row2 {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.x-pg-footer-contact-card-row2 .form-control {
	flex: 1;
	min-width: 0;
}
.x-pg-footer-contact-card-type {
	width: 5.5rem;
	flex-shrink: 0;
}
.x-pg-business-info-icon-picker-wrap {
	position: relative;
	flex-shrink: 0;
}
.x-pg-business-info-icon-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	padding: 0;
	border: 1px solid var(--bs-gray-300);
	border-radius: 0.375rem;
	background: #fff;
	color: var(--bs-body-color);
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
}
.x-pg-business-info-icon-btn:hover {
	background: var(--bs-gray-100);
	border-color: var(--bs-gray-400);
}
.x-pg-business-info-icon-btn i {
	font-size: 1.25rem;
	color: var(--x-pg-nav, #667eea) !important;
}
.x-pg-business-info-icon-picker-cell i {
	font-size: 1.25rem;
	color: var(--x-pg-nav, #667eea) !important;
}
.x-pg-business-info-icon-picker {
	padding: 0.5rem;
	background: #fff;
	border: 1px solid var(--bs-gray-300);
	border-radius: 0.425rem;
	box-shadow: 0 0.25rem 0.75rem rgba(0,0,0,0.15);
	z-index: 1050;
	display: grid;
	grid-template-columns: repeat(6, 2rem);
	gap: 0.25rem;
	max-height: 12rem;
	overflow-y: auto;
}
.x-pg-business-info-icon-picker--fixed {
	position: fixed;
}

/* 頁尾 linkBar 連結按鈕 badge */
.x-pg-link-url-badge {
	position: absolute;
	top: 1px;
	right: 1px;
	width: 9px;
	height: 9px;
	background: #198754;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}
.x-pg-link-url-badge i {
	font-size: 6px;
	color: #fff;
	line-height: 1;
}

/* 頁尾 linkBar 連結 popover */
.x-pg-link-url-popover {
	position: fixed;
	z-index: 1060;
	background: #fff;
	border: 1px solid var(--bs-gray-300);
	border-radius: 0.425rem;
	box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.15);
	padding: 0.5rem;
	min-width: 220px;
}
.x-pg-business-info-icon-picker-cell {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	padding: 0;
	border: none;
	border-radius: 0.25rem;
	background: transparent;
	color: var(--bs-body-color);
	cursor: pointer;
	transition: background 0.15s;
}
.x-pg-business-info-icon-picker-cell:hover {
	background: var(--bs-gray-200);
}

/* 營業資訊區塊：排版同聯絡資訊（data-preview-section 在 x-pg-section-outer 上） */
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-page-contact-item {
	align-items: center;
}
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-business-info-hours-wrap {
	border-bottom: 1px solid var(--bs-gray-200, #dee2e6);
	margin-bottom: 0.75em;
	padding-bottom: 0.75em;
}
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-business-info-hours-wrap .x-pg-page-contact-item {
	margin-bottom: 0;
}
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-page-contact-item svg,
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-page-contact-item .bi {
	flex-shrink: 0;
	color: var(--x-pg-primary, rgb(102, 126, 234));
}
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-page-contact-item .bi {
	font-weight: 600;
}
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-business-info-contact-text {
	display: inline;
}
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-business-info-label {
	color: var(--bs-gray-600, #4b5563);
	font-size: 0.9em;
	margin-right: 0.5em;
}
.x-pg-section-outer[data-preview-section^="businessInfoBlock_"] .x-pg-business-info-value {
	color: var(--x-pg-text, #1e293b);
	font-weight: 500;
}

/* ===== 標題區塊（titleBlock，Linktree/巨頭風格） ===== */
.x-pg-page-title-block-row {
	box-shadow: none;
}
.x-pg-page-title-block {
	text-align: center;
	padding: 0;
}
.x-pg-page-title-block-text {
	font-size: 1.5em;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--bs-gray-900);
	margin: 0;
	line-height: 1.3;
}
.x-pg-page-title-block-empty {
	padding: 0.5em 0;
}
.x-pg-page-title-block-text-placeholder {
	color: var(--bs-secondary-color, #6c757d) !important;
}
/* 標題區塊：內層 wrapper（leading + 文字） */
.x-pg-page-title-block-inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.5em 0.75em;
}
.x-pg-page-title-block-text {
	font-size: 1.5em;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--bs-gray-900);
	margin: 0;
	line-height: 1.3;
}
/* 字體大小 modifier */
.x-pg-page-title-block-text--sm { font-size: 1.15em; }
.x-pg-page-title-block-text--md { font-size: 1.5em; }
.x-pg-page-title-block-text--lg { font-size: 1.85em; }
.x-pg-page-title-block-text--xl { font-size: 2.25em; }
/* 裝飾 modifier（套在 .x-pg-page-title-block-inner 上） */
.x-pg-page-title-block-inner.x-pg-page-title-block--underline .x-pg-page-title-block-text {
	text-decoration: underline;
	text-underline-offset: 0.2em;
}
.x-pg-page-title-block-inner.x-pg-page-title-block--line-below {
	position: relative;
	padding-bottom: 0.5em;
}
.x-pg-page-title-block-inner.x-pg-page-title-block--line-below::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	width: 3em;
	height: 2px;
	background: var(--bs-gray-300, #dee2e6);
}
.x-pg-page-title-block-inner.x-pg-page-title-block--accent-bar {
	position: relative;
	padding-bottom: 0.4em;
}
.x-pg-page-title-block-inner.x-pg-page-title-block--accent-bar::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	width: 2.5em;
	height: 4px;
	border-radius: 2px;
	background: var(--x-pg-primary, rgb(102, 126, 234));
}
/* 前方圖示：容器 */
.x-pg-page-title-block-leading {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.x-pg-page-title-block-leading .bi {
	font-size: 1.25em;
	color: var(--x-pg-primary, rgb(102, 126, 234));
}
.x-pg-page-title-block-inner--sm .x-pg-page-title-block-leading .bi { font-size: 1em; }
.x-pg-page-title-block-inner--lg .x-pg-page-title-block-leading .bi { font-size: 1.4em; }
.x-pg-page-title-block-inner--xl .x-pg-page-title-block-leading .bi { font-size: 1.6em; }
.x-pg-page-title-block-emoji {
	line-height: 1;
	font-size: 1em;
}
.x-pg-page-title-block-inner--sm .x-pg-page-title-block-leading .x-pg-page-title-block-emoji { font-size: 0.9em; }
.x-pg-page-title-block-inner--lg .x-pg-page-title-block-leading .x-pg-page-title-block-emoji { font-size: 1.15em; }
.x-pg-page-title-block-inner--xl .x-pg-page-title-block-leading .x-pg-page-title-block-emoji { font-size: 1.35em; }
.x-pg-page-title-block-leading-img {
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	object-fit: cover;
	display: block;
}
.x-pg-page-title-block-inner--sm .x-pg-page-title-block-leading-img { width: 1.5rem; height: 1.5rem; }
.x-pg-page-title-block-inner--lg .x-pg-page-title-block-leading-img { width: 2.25rem; height: 2.25rem; }
.x-pg-page-title-block-inner--xl .x-pg-page-title-block-leading-img { width: 2.5rem; height: 2.5rem; }

/* ===== 標題區塊外型樣式（styleVariant） ===== */
/* 1) 實心色條（solidLabel） */
.x-pg-title-style--solid-label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.35em 1.2em;
	border-radius: 999px;
	background: var(--x-pg-primary, rgb(102, 126, 234));
	color: #fff;
}
.x-pg-title-style--solid-label .x-pg-page-title-block-text {
	color: #fff;
}
.x-pg-title-style--solid-label .x-pg-page-title-block-text-placeholder {
	color: rgba(255, 255, 255, 0.8) !important;
}

/* 2) 圓點 + 雙線（dotLine） */
.x-pg-title-style--dot-line {
	position: relative;
	padding: 0.75em 2.5em;
	border-top: 1px solid var(--x-pg-primary, rgb(248, 113, 113));
	border-bottom: 1px solid var(--x-pg-primary, rgb(248, 113, 113));
}
.x-pg-title-style--dot-line::before,
.x-pg-title-style--dot-line::after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--x-pg-primary, rgb(248, 113, 113));
}
.x-pg-title-style--dot-line::before {
	left: 0.75em;
}
.x-pg-title-style--dot-line::after {
	right: 0.75em;
}

/* 3) 左側編號標籤（numberTag） */
.x-pg-title-style--number-tag {
	display: inline-flex;
	align-items: center;
	gap: 0.75em;
}
.x-pg-title-number-tag {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5em;
	padding: 0.25em 0.75em;
	background: var(--x-pg-primary, rgb(248, 113, 113));
	color: #fff;
	font-weight: 700;
	border-radius: 999px 0 0 999px;
}
.x-pg-title-number-tag::after {
	content: "";
	position: absolute;
	right: -10px;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-top: 1em solid transparent;
	border-bottom: 1em solid transparent;
	border-left: 0.65em solid var(--x-pg-primary, rgb(248, 113, 113));
}

/* 4) 下方箭頭線（arrowUnderline） */
.x-pg-title-style--arrow-underline {
	position: relative;
	padding-bottom: 0.9em;
}
.x-pg-title-style--arrow-underline::before {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0.4em;
	transform: translateX(-50%);
	width: 4.5em;
	height: 2px;
	background: var(--x-pg-primary, rgb(248, 113, 113));
}
.x-pg-title-style--arrow-underline::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 1px;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-top: 6px solid var(--x-pg-primary, rgb(248, 113, 113));
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
}

/* 5) 左側圖示卡片（iconLabel） */
.x-pg-title-style--icon-label {
	position: relative;
	padding-bottom: 0.75em;
	gap: 0.75em;
}
.x-pg-title-style--icon-label::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	margin: 0 auto;
	max-width: 12em;
	height: 2px;
	background: var(--bs-gray-300, #dee2e6);
}
.x-pg-title-style--icon-label .x-pg-page-title-block-leading {
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 0.5rem;
	background: var(--x-pg-primary, rgb(248, 113, 113));
	color: #fff;
}
.x-pg-title-style--icon-label .x-pg-page-title-block-leading .bi,
.x-pg-title-style--icon-label .x-pg-page-title-block-leading .x-pg-page-title-block-emoji {
	color: #fff;
	font-size: 1.2em;
}
.x-pg-title-style--icon-label .x-pg-page-title-block-leading-img {
	border-radius: 0.5rem;
}
.x-pg-title-style--icon-label .x-pg-page-title-block-text {
	text-align: left;
}

/* 6) 圓形徽章 + 標題（badgeCircle） */
.x-pg-title-style--badge-circle {
	display: inline-flex;
	align-items: center;
	gap: 0.75em;
}
.x-pg-title-badge {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: 999px;
	background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.4), transparent 60%), var(--x-pg-primary, rgb(248, 113, 113));
	color: #fff;
}
.x-pg-title-badge::before {
	content: "POINT";
	position: absolute;
	top: -0.6rem;
	left: 50%;
	transform: translateX(-50%);
	font-size: 0.6rem;
	letter-spacing: 0.08em;
	color: var(--x-pg-primary, rgb(248, 113, 113));
	text-transform: uppercase;
}
.x-pg-title-badge-number {
	font-weight: 700;
	font-size: 1rem;
}
.x-pg-title-style--badge-circle .x-pg-page-title-block-text {
	text-align: left;
}

/* Modal 最大寬度 */
.mw-500px {
	max-width: 500px !important;
}

.x-pg-portfolio-grid-link-icon {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	background: rgba(255, 255, 255, 0.9);
	border-radius: 50%;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
	z-index: 10;
}

.x-pg-portfolio-grid-link-icon i {
	color: var(--x-pg-nav);
	font-size: 1rem;
}

.x-pg-portfolio-grid-content {
	padding: 0.75rem;
}

.x-pg-portfolio-grid-title {
	font-size: 0.875rem;
	color: var(--bs-gray-800);
	font-weight: 600;
	margin-bottom: 0.25rem;
	text-align: center;
}

.x-pg-portfolio-grid-description {
	font-size: 0.75rem;
	color: var(--bs-gray-600);
	line-height: 1.4;
	text-align: center;
	margin-top: 0.25rem;
}

.x-pg-portfolio-grid-detail {
	font-size: 0.7rem;
	color: var(--bs-gray-500);
	line-height: 1.4;
	text-align: center;
	margin-top: 0.5rem;
	padding-top: 0.5rem;
	border-top: 1px solid var(--bs-gray-200);
}

.x-pg-portfolio-grid-controls {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 1.75rem;
	gap: 0.625rem;
	padding: 0.4rem 0.625rem;
	background: rgba(255, 255, 255, 0.65);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid rgba(255, 255, 255, 0.85);
	border-radius: 100px;
	box-shadow: 0 2px 16px rgba(15, 23, 42, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.9);
	width: fit-content;
	margin-left: auto;
	margin-right: auto;
}

.x-pg-portfolio-grid-prev,
.x-pg-portfolio-grid-next {
	background: transparent;
	border: 1px solid var(--x-pg-border, #e8ecf1);
	border-radius: 50%;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94),
	            border-color 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94),
	            transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1),
	            box-shadow 0.2s ease;
	flex-shrink: 0;
}

.x-pg-portfolio-grid-prev:hover,
.x-pg-portfolio-grid-next:hover {
	background: var(--x-pg-primary, var(--x-pg-nav));
	border-color: var(--x-pg-primary, var(--x-pg-nav));
	transform: scale(1.1);
	box-shadow: 0 4px 12px rgba(15, 23, 42, 0.18);
}

.x-pg-portfolio-grid-prev i,
.x-pg-portfolio-grid-next i {
	color: var(--x-pg-text-muted, #64748b);
	font-size: 0.9rem;
	transition: color 0.2s ease;
}

.x-pg-portfolio-grid-prev:hover i,
.x-pg-portfolio-grid-next:hover i {
	color: #fff;
}

.x-pg-portfolio-grid-indicators {
	display: flex;
	gap: 0.375rem;
	justify-content: center;
	align-items: center;
}

.x-pg-portfolio-grid-indicator {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	border: none;
	padding: 0;
	background-color: var(--x-pg-border, #e2e8f0);
	cursor: pointer;
	transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.x-pg-portfolio-grid-indicator.active {
	background-color: var(--x-pg-primary, var(--x-pg-nav));
	width: 18px;
	border-radius: 3px;
}

.x-pg-portfolio-grid-indicator:hover:not(.active) {
	background-color: var(--x-pg-text-muted, #94a3b8);
	transform: scale(1.4);
}

.x-pg-display-type-options {
	display: flex;
	gap: 0.375rem;
	flex-wrap: nowrap;
	width: 100%;
}
.x-pg-display-type-option {
	display: flex;
	flex: 1 1 0;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.15rem;
	padding: 0.5rem 0.625rem;
	min-height: 0;
	border: 2px solid var(--x-pg-border, #e8ecf1);
	border-radius: var(--x-pg-radius-sm);
	background: #fff;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
	font-size: 0.75rem;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-display-type-option:hover {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
}
.x-pg-display-type-option.active {
	border-color: var(--bs-primary);
	background: rgba(99, 102, 241, 0.04);
	box-shadow: none;
}
.x-pg-display-type-row {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.3rem;
	width: 100%;
}
.x-pg-display-type-icon,
.x-pg-display-type-option .x-pg-display-type-icon,
.x-pg-display-type-option i.x-pg-display-type-icon {
	font-size: 1rem;
	color: #334155 !important;
	flex-shrink: 0;
}
.x-pg-display-type-option:hover .x-pg-display-type-icon,
.x-pg-display-type-option:hover i.x-pg-display-type-icon,
.x-pg-display-type-option.active .x-pg-display-type-icon,
.x-pg-display-type-option.active i.x-pg-display-type-icon {
	color: var(--bs-primary) !important;
}
.x-pg-display-type-label {
	font-size: 0.75rem;
	font-weight: 600;
	color: inherit;
	white-space: nowrap;
}
.x-pg-display-type-hint {
	font-size: 0.7rem;
	color: var(--bs-gray-500);
	line-height: 1.3;
}
.x-pg-display-type-option.active .x-pg-display-type-hint {
	color: var(--bs-gray-600);
}

.x-pg-portfolio-grid-item-link {
	text-decoration: none;
	color: inherit;
	cursor: pointer;
}
.x-pg-portfolio-grid-item-modal {
	cursor: pointer;
}

.x-pg-portfolio-modal-backdrop {
	position: fixed;
	inset: 0;
	z-index: 1060;
	background: rgba(0, 0, 0, 0.5);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	box-sizing: border-box;
}
.x-pg-portfolio-modal-dialog {
	background: #fff;
	border-radius: 0.5rem;
	box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.2);
	max-width: 560px;
	width: 100%;
	max-height: 85vh;
	display: flex;
	flex-direction: column;
}
.x-pg-portfolio-modal-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	padding: 1rem 1.25rem;
	padding-right: 3rem;
	border-bottom: 1px solid var(--bs-gray-200);
	flex-shrink: 0;
	position: relative;
}
.x-pg-portfolio-modal-title {
	margin: 0;
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--bs-gray-800);
	flex: 1;
	min-width: 0;
	padding-right: 0.5rem;
}
.x-pg-portfolio-modal-close {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	width: 2.25rem;
	height: 2.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	color: var(--bs-gray-600);
	border-radius: 50%;
	line-height: 1;
	transition: color 0.2s, background 0.2s;
}
.x-pg-portfolio-modal-close:hover {
	color: var(--bs-gray-900);
	background: var(--bs-gray-200);
}
.x-pg-portfolio-modal-close.btn-close-style {
	background: var(--bs-gray-100);
	color: var(--bs-gray-700);
	font-size: 1.125rem;
}
.x-pg-portfolio-modal-close.btn-close-style:hover {
	background: var(--bs-gray-300);
	color: #000;
}
.btn-close-style i{
	color: var(--bs-gray-700);
}
.x-pg-portfolio-modal-close i {
	font-size: 1.25rem;
}
.x-pg-portfolio-modal-body {
	padding: 1.25rem;
	overflow-y: auto;
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--bs-gray-700);
}
.x-pg-portfolio-modal-body p {
	margin: 0 0 0.75rem 0;
}
.x-pg-portfolio-modal-body p:last-child {
	margin-bottom: 0;
}
.x-pg-portfolio-modal-body ul,
.x-pg-portfolio-modal-body ol {
	padding-left: 1.5rem;
	margin: 0.5rem 0;
}

/* 活動條款區塊：折疊 details/summary、觸發按鈕 */
.x-pg-event-terms-block .x-pg-event-terms-details {
	width: 100%;
}
.x-pg-event-terms-block .x-pg-event-terms-summary {
	position: relative;
	display: flex;
	align-items: start;
	justify-content: space-between;
	cursor: pointer;
	font-weight: 600;
	list-style: none;
	padding: 0.25rem 2rem 0.25rem 0;
	border-radius: .625rem;
}
.x-pg-event-terms-block .x-pg-event-terms-summary:hover {
	filter: brightness(99%);
}
.x-pg-event-terms-block .x-pg-event-terms-summary::-webkit-details-marker {
	display: none;
}
.x-pg-event-terms-block .x-pg-event-terms-summary::marker {
	content: "";
}
.x-pg-event-terms-block .x-pg-event-terms-summary::after {
	position: absolute;
	right: 0.5rem;
	top: 50%;
	margin-top: 2px;
	width: 0;
	height: 0;
	content: '';
	border-style: solid;
	border-width: 6px 6px 0 6px;
	border-color: #c4c4c4 transparent transparent transparent;
	transform: translateY(-50%);
	transition: transform 0.3s;
	transform-origin: center;
}
.x-pg-event-terms-block .x-pg-event-terms-details[open] .x-pg-event-terms-summary::after {
	transform: translateY(-50%) rotate(180deg);
}
.x-pg-event-terms-block .x-pg-event-terms-details[open] .x-pg-event-terms-summary {
	border-bottom: 1px solid #f3f3f3;
	border-radius: .625rem .625rem 0 0;
	margin-bottom: 12px;
}
.x-pg-event-terms-block .x-pg-event-terms-details[open] .x-pg-event-terms-summary ol{
	padding-left: 1.25rem;
}
.x-pg-event-terms-block .x-pg-event-terms-modal-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.x-pg-event-terms-block .x-pg-event-terms-modal-row .x-pg-event-terms-modal-title {
	margin: 0;
	font-weight: 600;
}
.x-pg-event-terms-block .x-pg-event-terms-view-link {
	color: var(--x-pg-nav, #0f172a);
	text-decoration: none;
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	font-size: inherit;
}
.x-pg-event-terms-block .x-pg-event-terms-view-link:hover {
	color: var(--x-pg-nav-accent, #334155);
}
/* 活動條款區塊：直接顯示（inline） */
.x-pg-event-terms-block .x-pg-event-terms-inline {
	width: 100%;
	padding: 1rem 0 0;
}
.x-pg-event-terms-block .x-pg-event-terms-inline-title {
	margin: 0 0 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 1.125rem;
	font-weight: 600;
	line-height: 1.4;
	color: inherit;
	border-bottom: 1px solid rgba(0, 0, 0, 0.12);
}
.x-pg-event-terms-block .x-pg-event-terms-inline .xt_area {
	margin-top: 0;
}
/* 活動條款區塊內 .xt_area：後端 HTML 內容隔離，自 xlead 搬入並限定 scope */
.x-pg-event-terms-block .xt_area,
.x-pg-portfolio-modal-body .xt_area {
	width: 100%;
	border-radius: 8px;
	margin-bottom: 0.75rem;
}
.x-pg-event-terms-block .xt_area span,
.x-pg-portfolio-modal-body .xt_area span {
	font-size: inherit;
	color: inherit;
}
.x-pg-event-terms-block .xt_area.form-check-label span,
.x-pg-portfolio-modal-body .xt_area.form-check-label span,
.x-pg-event-terms-block .xt_area.form-check-label,
.x-pg-portfolio-modal-body .xt_area.form-check-label {
	margin-bottom: 0 !important;
}
.x-pg-event-terms-block .xt_area.te-plain,
.x-pg-portfolio-modal-body .xt_area.te-plain {
	padding: 0;
	margin-bottom: 0.75rem;
	background-color: transparent;
}
.x-pg-event-terms-block .xt_area.te-title,
.x-pg-portfolio-modal-body .xt_area.te-title {
	background-color: #eee;
	padding: 0.5rem 1rem;
	position: relative;
	font-weight: 600;
	color: #5d5b5b;
	font-size: 1.1rem;
}
.x-pg-event-terms-block .xt_area.te-title::before,
.x-pg-portfolio-modal-body .xt_area.te-title::before {
	content: '';
	height: 12px;
	width: 4px;
	display: inline-block;
	background-color: #bbb;
	border-radius: 8px;
	position: absolute;
	left: 6px;
	top: 50%;
	transform: translateY(-50%);
}
.x-pg-event-terms-block .xt_area.te-quote,
.x-pg-portfolio-modal-body .xt_area.te-quote {
	background-color: rgba(221, 221, 221, 0.27);
	position: static;
	height: initial;
	padding: 1.25rem;
}
.x-pg-event-terms-block .xt_area.te-quote::before,
.x-pg-portfolio-modal-body .xt_area.te-quote::before {
	content: url('https://xleadfunnel.oss-cn-hongkong.aliyuncs.com/dev/panel/img/catalog/member/bxs-quote-left.svg');
}
.x-pg-event-terms-block .xt_area.te-box,
.x-pg-portfolio-modal-body .xt_area.te-box {
	background-color: transparent;
	border: 1px solid #e3e3e3;
	padding: 1.25rem;
}

/* ===== 範例預覽樣式 ===== */
.x-pg-page-placeholder {
	opacity: 0.7;
	position: relative;
}

.x-pg-page-placeholder::before {
	content: '範例預覽';
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	padding: 0.25rem 0.5rem;
	border-radius: 0.25rem;
	font-size: 0.75rem;
	z-index: 10;
	pointer-events: none;
}

.x-pg-page-placeholder .x-pg-page-description,
.x-pg-page-placeholder .x-pg-page-experience-name,
.x-pg-page-placeholder .x-pg-page-experience-time,
.x-pg-page-placeholder .x-pg-page-contact-item {
	color: var(--bs-gray-600) !important;
}

/* Placeholder 模式下，header 區塊的文字保持白色 */
.x-pg-page-placeholder .x-pg-page-header-section .x-pg-page-name,
.x-pg-page-placeholder .x-pg-page-header-section .x-pg-page-title,
.x-pg-page-placeholder .x-pg-page-header-section .x-pg-page-company {
	color: #fff !important;
}

.x-pg-page-placeholder .x-pg-page-contact-item a,
.x-pg-page-placeholder .x-pg-page-social-link {
	opacity: 0.7;
	cursor: default;
}

/* ===== 行動按鈕 ===== */
.x-pg-page-action-buttons {
	padding: 1.5rem 0;
	margin: 0 auto;
}

.x-pg-page-action-buttons .x-pg-row {
	box-shadow: none !important;
}

.x-pg-action-buttons-inner {
	max-width: 360px;
	margin: 0 auto;
}

.x-pg-action-buttons-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}

.x-pg-action-buttons-grid.x-pg-action-buttons-single {
	grid-template-columns: 1fr;
}
@media (min-width: 768px) {
	.x-pg-action-buttons-grid.x-pg-action-buttons-single {
		width: max-content;
		max-width: 100%;
		margin-left: auto;
		margin-right: auto;
	}
}

.x-pg-page-action-buttons .x-pg-action-button {
	background: transparent !important;
	box-shadow: none !important;
}

.x-pg-action-button {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.875rem 1.25rem;
	text-decoration: none;
	border-radius: var(--x-pg-radius);
	transition: all 0.2s ease;
	gap: 0.75rem;
	border: 1px solid rgba(0, 0, 0, 0.08);
}

.x-pg-page-action-buttons .x-pg-action-button:hover {
	transform: translateY(-1px);
	box-shadow: none;
}

.x-pg-action-button:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 16px rgba(15, 23, 42, 0.12);
	color: #fff;
	background: var(--x-pg-nav-accent);
}

.x-pg-action-button-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	font-size: 1.25rem;
}

.x-pg-action-button-icon i,
.x-pg-action-button-icon svg {
	color: #fff;
	width: 1.25rem;
	height: 1.25rem;
}
.x-pg-page-action-buttons .x-pg-action-button-icon i,
.x-pg-page-action-buttons .x-pg-action-button-icon svg {
	color: inherit;
}

.x-pg-action-button-text {
	font-size: 0.95rem;
	font-weight: 500;
	flex: 1;
	text-align: center;
	color: #fff !important;
}
.x-pg-page-action-buttons .x-pg-action-button-text {
	color: inherit !important;
	text-align: center;
}
.x-pg-action-button-text.form-control {
	color: #000 !important;
	text-align: left;
}

.x-pg-action-button-item {
	background-color: var(--bs-gray-50);
	border: 1px solid var(--bs-gray-200);
}

.x-pg-action-button-icon-preview {
	display: flex;
	align-items: center;
	justify-content: center;
}

.x-pg-action-button-icon-preview i,
.x-pg-action-button-icon-preview svg {
	color: var(--x-pg-nav);
}
.x-pg-action-button-icon-display {
	cursor: pointer;
	transition: all 0.2s ease;
}

.x-pg-action-button-icon-display:hover {
	border-color: var(--x-pg-nav-accent) !important;
	background-color: #f1f5f9 !important;
	transform: scale(1.05);
}

.x-pg-action-button-icon-display:hover i {
	color: var(--x-pg-nav);
}

.x-pg-action-button-icon-display i {
	font-size: 1.5rem;
	color: var(--x-pg-text-muted);
	transition: color 0.2s ease;
}

/* 確保行動按鈕的 input-group 保持在同一行 */
.x-pg-action-button-item .input-group {
	display: flex;
	flex-wrap: nowrap;
	width: 100%;
}

.x-pg-action-button-item .input-group .form-select.x-pg-action-button-protocol {
	flex-shrink: 0;
	
	
	max-width: 86px;
}

.x-pg-action-button-item .input-group .form-control.x-pg-action-button-url {
	flex: 1;
	min-width: 0;
}

/* ===== 按鈕區塊 (CTA Block) ===== */
.x-pg-page-cta-block {
	padding: 1.5rem 0;
	margin: 0 auto;
}

.x-pg-page-cta-block .x-pg-row {
	box-shadow: none !important;
}

.x-pg-cta-block-inner {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	width: 100%;
	justify-content: center;
}

.x-pg-cta-block-inner.x-pg-cta-block-layout-row {
	flex-direction: row;
}

.x-pg-cta-block-inner.x-pg-cta-block-layout-column {
	flex-direction: column;
	align-items: center;
}

.x-pg-cta-block-inner .x-pg-cta-btn {
	flex: 1;
	min-width: 280px;
}

.x-pg-cta-block-inner.x-pg-cta-block-layout-column .x-pg-cta-btn {
	flex: none;
	width: 100%;
}

/* 僅一個按鈕時不拉滿寬（科技巨頭常見：單一 CTA 約 50% 或依內容） */
.x-pg-cta-block-inner.x-pg-cta-block-single {
	justify-content: center;
}
.x-pg-cta-block-inner.x-pg-cta-block-single .x-pg-cta-btn {
	flex: 0 1 auto;
	max-width: 50%;
}
.x-pg-cta-block-inner.x-pg-cta-block-layout-column.x-pg-cta-block-single .x-pg-cta-btn {
	width: auto;
	max-width: 50%;
}

/* ===== 多欄式區塊（multiColumnBlock，科技巨頭風格） ===== */
.x-pg-multi-column-move-group {
	display: inline-flex;
	align-items: center;
	gap: 0.125rem;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
}
.x-pg-multi-column-move-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.5rem;
	height: 1.5rem;
	padding: 0;
	border: 0;
	border-radius: 0.25rem;
	background: transparent;
	color: #334155;
	font-size: 0.78rem;
	font-weight: 600;
	line-height: 1;
	transition: background-color 0.18s ease, color 0.18s ease, opacity 0.18s ease;
}
.x-pg-multi-column-move-btn i {
	color: currentColor;
}
.x-pg-multi-column-move-btn:hover:not(:disabled) {
	background: rgba(148, 163, 184, 0.14);
	color: #1d4ed8;
}
.x-pg-multi-column-move-btn:focus-visible {
	outline: none;
	box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.16);
}
.x-pg-multi-column-move-btn:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}
.x-pg-multi-column-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 1rem;
}
.x-pg-multi-column-toolbar-copy {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	min-width: 0;
}
.x-pg-multi-column-toolbar-copy strong {
	font-size: 0.95rem;
	color: #0f172a;
}
.x-pg-multi-column-toolbar-copy span {
	font-size: 0.8rem;
	color: #64748b;
}
.x-pg-multi-column-card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.75rem;
	align-items: stretch;
	margin-bottom: 1rem;
}
.x-pg-multi-column-card {
	display: flex;
	flex-direction: column;
	min-width: 0;
	margin-bottom: 0.75rem;
	padding: 0.8rem 0.55rem;
	border: 1px solid #e2e8f0;
	border-radius: 16px;
	background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
	box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
	cursor: pointer;
	transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}
.x-pg-multi-column-card:hover,
.x-pg-multi-column-card:focus-visible,
.x-pg-multi-column-card.is-active {
	border-color: rgba(37, 99, 235, 0.5);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12), 0 10px 24px rgba(15, 23, 42, 0.08);
	transform: translateY(-1px);
	outline: none;
}
.x-pg-multi-column-card-header,
.x-pg-multi-column-card-footer {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	
}
.x-pg-multi-column-card-header {
	flex-direction: column;
	align-items: stretch;
}
.x-pg-multi-column-card-title-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.4rem;
	padding-bottom: 4px;
	
	border-bottom: 1px solid #e2e8f0;
}
.x-pg-multi-column-card-title-wrap {
	display: flex;
	flex-direction: column;
	min-width: 0;
}
.x-pg-multi-column-card-index {
	font-size: 0.78rem;
	font-weight: 700;
	color: #0f172a;
}
.x-pg-multi-column-card-actions {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: nowrap;
	gap: 0.18rem;
	flex-shrink: 1;
	width: 100%;
	padding-bottom:4px;
	margin-bottom: 4px;
	border-bottom: 1px solid #e2e8f0;
}
.x-pg-multi-column-card-action {
	background: none;
	border: none;
	cursor: pointer;
	padding: 4px 6px;
	border-radius: 4px;
	line-height: 1;
	background: transparent;
	color: #334155;
	transition: background-color 0.15s ease, color 0.15s ease, opacity 0.15s ease;
}
.x-pg-multi-column-card-action i {
	color: currentColor !important;
	font-size: 13px;
}
.x-pg-multi-column-card-action:hover:not(:disabled) {
	background: #e8edf2;
	color: #1d4ed8;
}
.x-pg-multi-column-card-action:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}
.x-pg-multi-column-card-action:not(.is-danger) {
	color: #2563eb;
}
.x-pg-multi-column-card-action.is-danger:hover:not(:disabled) {
	background: rgba(239, 68, 68, 0.12);
	color: #dc2626;
}
.x-pg-multi-column-card-action.is-danger {
	color: #dc2626;
}
.x-pg-multi-column-card-preview {
	display: flex;
	flex-direction: column;
	gap: 4px;
	
}
.x-pg-multi-column-card-preview--textFirst {
	flex-direction: column-reverse;
}
.x-pg-multi-column-card-media {
	width: 100%;
	aspect-ratio: 4 / 3;
	border-radius: 12px;
	overflow: hidden;
	background: #e2e8f0;
	box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.14);
}
.x-pg-multi-column-card-thumb {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}
.x-pg-multi-column-card-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 0.5rem;
	text-align: center;
	color: #64748b;
	font-size: 0.68rem;
	line-height: 1.4;
}
.x-pg-multi-column-card-placeholder i {
	font-size: 1rem;
}
.x-pg-multi-column-card-text {
	min-width: 0;
}
.x-pg-multi-column-card-summary {
	margin: 0;
	color: #334155;
	font-size: 0.78rem;
	line-height: 1.55;
	word-break: break-word;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.x-pg-multi-column-card-footer {
	align-items: center;
	min-height: 0;
	margin-top: 0;
}
.x-pg-multi-column-card-badges {
	min-width: 0;
}
.x-pg-multi-column-card-edit {
	flex-shrink: 0;
	background: none;
	border: none;
	cursor: pointer;
	padding: 4px 6px;
	border-radius: 5px;
	font-size: 13px;
	line-height: 1;
	color: #8fa3b8;
	transition: background 0.15s, color 0.15s;
}
.x-pg-multi-column-card-edit:hover {
	background: #f1f5f9;
	color: #374151;
}
.x-pg-multi-column-card-edit i,
.x-pg-multi-column-card-edit .bi {
	color: currentColor !important;
	font-size: 13px;
}
.x-pg-multi-column-editor-modal-dialog {
	max-width: min(920px, calc(100vw - 32px));
}
.x-pg-multi-column-editor-modal-dialog .modal-body {
	max-height: min(68vh, 720px);
	overflow-y: auto;
	padding-top: 1rem;
	padding-bottom: 1rem;
}
.x-pg-multi-column-modal-nav {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
}
.x-pg-multi-column-editor-layout {
	display: grid;
	grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
	gap: 0.875rem;
	align-items: start;
}
.x-pg-multi-column-editor-sidebar,
.x-pg-multi-column-editor-content {
	min-width: 0;
}
.x-pg-multi-column-editor-panel {
	background: #f8fafc;
	border: 1px solid #e5e7eb;
	border-radius: 16px;
	padding: 0.875rem;
}
.x-pg-multi-column-editor-panel-head {
	margin-bottom: 0.75rem;
}
.x-pg-multi-column-editor-panel-head h6 {
	font-size: 0.95rem;
	font-weight: 700;
	color: #0f172a;
}
.x-pg-multi-column-editor-panel-head > :last-child {
	margin-bottom: 0;
}
.x-pg-multi-column-editor-toolbar {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.75rem;
}
.x-pg-multi-column-editor-toolbar-item {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	min-width: 0;
}
.x-pg-multi-column-editor-toolbar-item-color {
	flex: 1 1 auto;
	justify-content: space-between;
}
.x-pg-multi-column-editor-toolbar-label {
	font-size: 0.8125rem;
	font-weight: 600;
	color: #334155;
	white-space: nowrap;
}
.x-pg-multi-column-order-cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.5rem;
}
.x-pg-multi-column-order-cards .x-pg-carousel-option-card {
	width: 100%;
	justify-content: flex-start;
}
.x-pg-multi-column-editor-content-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: nowrap;
}
.x-pg-multi-column-editor-toolbar-item-color,
.x-pg-multi-column-editor-toolbar-item-shadow {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 0;
}
.x-pg-multi-column-editor-image-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 260px;
	gap: 1rem;
	align-items: start;
}
.x-pg-multi-column-editor-image-main,
.x-pg-multi-column-editor-image-side {
	min-width: 0;
}
.x-pg-multi-column-editor-image-head {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	justify-content: space-between;
	margin-bottom: 0.75rem;
}
.x-pg-multi-column-editor-image-side {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	padding-top: 0.1rem;
	width: 260px;
	flex: 0 0 260px;
}
.x-pg-multi-column-editor-toolbar-item-color,
.x-pg-multi-column-editor-toolbar-item-shadow {
	border: 1px solid #e2e8f0;
	border-radius: 12px;
	background: #ffffff;
	padding: 0.75rem 0.875rem;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.x-pg-multi-column-order-cards-inline {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.5rem;
	flex: 0 0 auto;
}
.x-pg-multi-column-order-cards-inline .x-pg-carousel-option-card {
	width: 100%;
	min-width: 0;
	justify-content: center;
}
.x-pg-multi-column-editor-disabled-note {
	padding: 0.875rem 1rem;
	border: 1px dashed #cbd5e1;
	border-radius: 12px;
	background: #fff;
	color: #64748b;
	font-size: 0.875rem;
	line-height: 1.5;
}
.x-pg-multi-column-editor-preview-panel {
	background: #ffffff;
}
.x-pg-multi-column-editor-preview-card {
	border: 1px solid #e2e8f0;
	border-radius: 14px;
	padding: 0.75rem;
	background: transparent;
	transition: box-shadow 0.2s ease, background 0.2s ease;
}
.x-pg-multi-column-editor-preview-card.is-shadow {
	box-shadow: var(--x-pg-shadow-card);
}
.x-pg-multi-column-editor-preview-stack {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.x-pg-multi-column-editor-preview-stack.is-image-first .x-pg-multi-column-editor-preview-media {
	order: 1;
}
.x-pg-multi-column-editor-preview-stack.is-image-first .x-pg-multi-column-editor-preview-text {
	order: 2;
}
.x-pg-multi-column-editor-preview-stack.is-text-first .x-pg-multi-column-editor-preview-text {
	order: 1;
}
.x-pg-multi-column-editor-preview-stack.is-text-first .x-pg-multi-column-editor-preview-media {
	order: 2;
}
.x-pg-multi-column-editor-preview-media {
	width: 100%;
}
.x-pg-multi-column-editor-preview-media-image {
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: 10px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	background-color: #e5e7eb;
}
.x-pg-multi-column-editor-preview-placeholder {
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: 10px;
	border: 1px dashed #cbd5e1;
	background: transparent;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #94a3b8;
}
.x-pg-multi-column-editor-preview-text {
	min-width: 0;
}
.x-pg-multi-column-editor-preview-text .x-pg-rich-text-content {
	font-size: 0.88rem;
	line-height: 1.55;
	word-break: break-word;
}
.x-pg-multi-column-editor-preview-text .x-pg-rich-text-content > :last-child {
	margin-bottom: 0;
}
.x-pg-multi-column-editor-stack {
	display: flex;
	flex-direction: column;
	gap: 0.875rem;
}
.x-pg-multi-column-block {
	display: grid;
	gap: 1rem;
	width: 100%;
}
.x-pg-multi-column-block-col {
	border-radius: var(--x-pg-radius, 8px);
	overflow: hidden;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
	outline: 1px solid transparent;
	outline-offset: 0;
	transition: outline-color 0.2s ease, box-shadow 0.2s ease;
}
.x-pg-multi-column-block-col-shadow {
	box-shadow: var(--x-pg-shadow-card);
}
.x-pg-multi-column-block-col-active {
	outline-color: rgba(37, 99, 235, 0.9);
	box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12), var(--x-pg-shadow-card);
}
.x-pg-multi-column-block-col-img {
	width: 100%;
	display: block;
	border-radius: var(--x-pg-radius, 8px);
	overflow: hidden;
}
.x-pg-multi-column-block-col-text {
	min-width: 0;
}
.x-pg-multi-column-block-col-text .x-pg-rich-text-content {
	word-break: break-word;
}
.x-pg-multi-column-block-placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	color: #64748b;
}
.x-pg-multi-column-block-placeholder svg {
	color: currentColor;
}
.x-pg-multi-column-block-placeholder-text {
	font-size: 0.875rem;
}
.x-pg-section-outer[data-preview-section^="multiColumnBlock_"] .x-pg-row.x-pg-multi-column-block-row,
.x-pg-section-outer[data-preview-section^="multiColumnBlock_"] .x-pg-multi-column-block-row {
	padding: 0;
}
.x-pg-section-outer[data-preview-section^="multiColumnBlock_"] .x-pg-page-section-inner.x-pg-multi-column-block-inner {
	max-width: none;
	padding: 0;
}
@media (max-width: 767.98px) {
	.x-pg-multi-column-toolbar {
		align-items: flex-start;
		flex-direction: column;
	}
	.x-pg-multi-column-card {
		padding: 0.6rem 0.4rem;
		border-radius: 14px;
	}
	.x-pg-multi-column-card-preview {
		gap: 0.5rem;
	}
	.x-pg-multi-column-card-index {
		font-size: 0.72rem;
	}
	.x-pg-multi-column-card-edit,
	.x-pg-multi-column-card-summary,
	.x-pg-multi-column-card-placeholder {
		font-size: 0.62rem;
	}
	.x-pg-multi-column-editor-modal-dialog {
		max-width: calc(100vw - 12px);
		margin: 0.5rem auto;
	}
	.x-pg-multi-column-editor-layout {
		grid-template-columns: 1fr;
	}
	.x-pg-multi-column-editor-image-layout {
		grid-template-columns: 1fr;
	}
	.x-pg-multi-column-editor-content-head {
		align-items: flex-start;
		flex-direction: column;
	}
	.x-pg-multi-column-order-cards-inline {
		width: 100%;
	}
	.x-pg-multi-column-editor-toolbar-item-color {
		width: 100%;
	}
	.x-pg-multi-column-editor-image-side {
		width: 100%;
		flex-basis: auto;
	}
	.x-pg-multi-column-block {
		grid-template-columns: 1fr !important;
	}
}
.x-pg-preview-frame.mobile .x-pg-multi-column-block,
.x-pg-preview-frame.size-mobile .x-pg-multi-column-block {
	grid-template-columns: 1fr !important;
}

.x-pg-cta-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.875rem 1.5rem;
	text-decoration: none;
	font-size: 0.95rem;
	font-weight: 500;
	transition: opacity 0.2s ease, transform 0.2s ease;
	cursor: pointer;
}

.x-pg-cta-btn:hover {
	opacity: 0.92;
	transform: translateY(-1px);
}

.x-pg-cta-btn--rounded {
	border-radius: var(--x-pg-radius, 8px);
}

.x-pg-cta-btn--square {
	border-radius: 0;
}

.x-pg-cta-btn--pill {
	border-radius: 9999px;
}

.x-pg-cta-button-item {
	background-color: var(--bs-gray-50);
	border: 1px solid var(--bs-gray-200);
}

.x-pg-icon-picker-popover {
	user-select: none;
}

.x-pg-icon-picker-grid {
	display: grid;
	grid-template-columns: repeat(8, 1fr);
	gap: 4px;
}

.x-pg-icon-picker-cell {
	width: 100%;
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid transparent;
	border-radius: 6px;
	background: transparent;
	color: var(--x-pg-text);
	font-size: 1.1rem;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
}

.x-pg-icon-picker-cell:hover {
	background: var(--bs-gray-100);
	border-color: var(--bs-gray-300);
}

.x-pg-icon-picker-cell.active {
	background: rgba(67, 79, 132, 0.12);
	border-color: var(--x-pg-edit-accent);
	color: var(--x-pg-edit-accent);
}

.x-pg-action-button.x-pg-action-button-img {
	padding: 0;
	overflow: hidden;
	display: block;
}

.x-pg-action-button-img-wrap {
	display: block;
	width: 100%;
	height: 56px;
	border-radius: inherit;
	overflow: hidden;
}

.x-pg-action-button-img-wrap img.x-pg-action-button-img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: contain;
}

.x-pg-action-button-img-wrap img.x-pg-action-button-img.x-pg-action-button-img-fill {
	object-fit: cover;
}

/* ===== 自定義 Alert 系統 ===== */
.x-pg-alert-container {
	position: fixed;
	top: 120px;
	right: 20px;
	z-index: 9999;
	max-width: 450px;
	opacity: 0;
	transform: translateX(120%) scale(0.9);
	transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
	pointer-events: none;
}

.x-pg-alert-container.x-pg-alert-show {
	opacity: 1;
	transform: translateX(0) scale(1);
	pointer-events: auto;
}

.x-pg-alert-content {
	display: flex;
	align-items: flex-start;
	background: #fff;
	border-radius: 1rem;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25), 0 8px 20px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
	padding: 1.25rem 1.5rem;
	gap: 1.25rem;
	position: relative;
	border-left: 4px solid transparent;
	animation: x-pg-alert-pulse 0.6s ease-out;
}

@keyframes x-pg-alert-pulse {
	0% {
		transform: scale(0.95);
		opacity: 0.8;
	}
	50% {
		transform: scale(1.02);
	}
	100% {
		transform: scale(1);
		opacity: 1;
	}
}

.x-pg-alert-icon {
	font-size: 2rem;
	flex-shrink: 0;
	line-height: 1;
	filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1));
}

.x-pg-alert-body {
	flex: 1;
	min-width: 0;
}

.x-pg-alert-title {
	font-weight: 700;
	font-size: 1.05rem;
	color: var(--bs-gray-900);
	margin-bottom: 0.375rem;
	letter-spacing: -0.01em;
}

.x-pg-alert-message {
	font-size: 0.95rem;
	color: var(--bs-gray-800);
	line-height: 1.6;
	font-weight: 500;
}

.x-pg-alert-close {
	background: none;
	border: none;
	color: var(--bs-gray-400);
	cursor: pointer;
	padding: 0.375rem;
	line-height: 1;
	flex-shrink: 0;
	transition: all 0.2s ease;
	border-radius: 0.375rem;
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.x-pg-alert-close:hover {
	color: var(--bs-gray-700);
	background-color: var(--bs-gray-100);
	transform: rotate(90deg);
}

.x-pg-alert-close i {
	font-size: 1.375rem;
}

/* Confirm 對話框 */
.x-pg-alert-overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: rgba(0, 0, 0, 0.5);
	z-index: 1070;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	opacity: 0;
	transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
	backdrop-filter: blur(4px);
}

.x-pg-alert-overlay.x-pg-alert-show {
	opacity: 1;
	pointer-events: auto;
}

.x-pg-alert-dialog {
	background: var(--x-pg-surface);
	border-radius: var(--x-pg-radius);
	box-shadow: var(--x-pg-shadow-lg), 0 24px 48px rgba(15, 23, 42, 0.12);
	max-width: 500px;
	width: 100%;
	max-height: 90vh;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transform: scale(0.9);
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.x-pg-alert-overlay.x-pg-alert-show .x-pg-alert-dialog {
	transform: scale(1);
}

.x-pg-alert-dialog-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.5rem 1.5rem 1rem;
	border-bottom: 1px solid var(--bs-gray-200);
}

.x-pg-alert-dialog-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--bs-gray-900);
}

.x-pg-alert-dialog-close {
	background: none;
	border: none;
	color: var(--bs-gray-400);
	cursor: pointer;
	padding: 0.5rem;
	line-height: 1;
	transition: all 0.2s ease;
	border-radius: 0.375rem;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.x-pg-alert-dialog-close:hover {
	color: var(--bs-gray-600);
	background-color: var(--bs-gray-100);
}

.x-pg-alert-dialog-close i {
	font-size: 1.25rem;
}

.x-pg-alert-dialog-body {
	padding: 1.5rem;
	flex: 1;
	overflow-y: auto;
}

.x-pg-alert-dialog-message {
	font-size: 0.95rem;
	color: var(--bs-gray-700);
	line-height: 1.6;
}

.x-pg-alert-dialog-footer {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.75rem;
	padding: 1rem 1.5rem;
	border-top: 1px solid var(--bs-gray-200);
	background-color: var(--bs-gray-50);
}

.x-pg-alert-dialog-footer .btn {
	min-width: 80px;
}

/* Alert 類型特定樣式 */
.x-pg-alert-container[data-type="success"] .x-pg-alert-content {
	border-left-color: #10b981;
	background: linear-gradient(to right, #d1fae5 0%, #fff 8%);
}

.x-pg-alert-container[data-type="error"] .x-pg-alert-content {
	border-left-color: #ef4444;
	background: linear-gradient(to right, #fee2e2 0%, #fff 8%);
}

.x-pg-alert-container[data-type="warning"] .x-pg-alert-content {
	border-left-color: #f59e0b;
	background: linear-gradient(to right, #fef3c7 0%, #fff 8%);
}

.x-pg-alert-container[data-type="info"] .x-pg-alert-content {
	border-left-color: #3b82f6;
	background: linear-gradient(to right, #dbeafe 0%, #fff 8%);
}

@media (max-width: 576px) {
	.x-pg-alert-container {
		right: 10px;
		left: 10px;
		max-width: none;
		top: 80px;
		transform: translateY(-120%) scale(0.9);
	}
	
	.x-pg-alert-container.x-pg-alert-show {
		transform: translateY(0) scale(1);
	}
	
	.x-pg-alert-dialog {
		max-width: 100%;
		margin: 0;
		border-radius: 1rem 1rem 0 0;
	}
	
	.x-pg-alert-overlay {
		align-items: flex-end;
		padding: 0;
	}
}

/* ===== SweetAlert2 Toast — 科技巨頭深色風格（與 bio-alert toast 統一） ===== */

/* 容器定位：右下角，與 bio-alert wrapper 同區 */
.x-pg-app-body .swal2-container.swal2-top-end,
.x-pg-app-body .swal2-container.swal2-bottom-end {
	top: auto;
	bottom: 28px;
	right: 24px;
	left: auto;
	width: auto;
	max-width: 380px;
}

/* Toast 主體 */
.x-pg-app-body .swal2-popup.x-pg-swal-toast {
	background: #111827;
	border-radius: 13px;
	box-shadow:
		0 0 0 1px rgba(255, 255, 255, 0.07),
		0 2px 4px rgba(0, 0, 0, 0.24),
		0 8px 20px rgba(0, 0, 0, 0.3),
		0 24px 48px rgba(0, 0, 0, 0.18);
	border-left: 2.5px solid transparent;
	padding: 14px 16px 20px 16px;
	text-align: left;
	min-width: 280px;
	max-width: 380px;
	width: 380px;
	gap: 0;
}

/* 隱藏 swal 預設 icon（用左側 border 顏色區分） */
.x-pg-app-body .swal2-popup.x-pg-swal-toast .swal2-icon { display: none !important; }

/* 標題 */
.x-pg-app-body .swal2-popup.x-pg-swal-toast .swal2-title {
	font-size: 0.875rem;
	font-weight: 600;
	color: #f1f5f9;
	letter-spacing: -0.01em;
	line-height: 1.4;
	padding: 0;
	margin: 0 0 3px 0;
	justify-content: flex-start;
}

/* 訊息文字 */
.x-pg-app-body .swal2-popup.x-pg-swal-toast .swal2-html-container {
	font-size: 0.875rem;
	color: #94a3b8;
	line-height: 1.5;
	font-weight: 400;
	margin: 0;
	padding: 0;
	text-align: left;
}

/* 進度條容器 */
.x-pg-app-body .swal2-popup.x-pg-swal-toast .swal2-timer-progress-bar-container {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2.5px;
	overflow: hidden;
	border-radius: 0 0 13px 13px;
}

/* 進度條本體 */
.x-pg-app-body .swal2-popup.x-pg-swal-toast .swal2-timer-progress-bar {
	height: 100%;
	opacity: 0.65;
}

/* 類型：Success */
.x-pg-app-body .swal2-popup.x-pg-swal-toast-success {
	border-left-color: #22c55e;
}
.x-pg-app-body .swal2-popup.x-pg-swal-toast-success .swal2-timer-progress-bar {
	background: #22c55e;
}

/* 類型：Error */
.x-pg-app-body .swal2-popup.x-pg-swal-toast-error {
	border-left-color: #ef4444;
}
.x-pg-app-body .swal2-popup.x-pg-swal-toast-error .swal2-timer-progress-bar {
	background: #ef4444;
}

/* 類型：Warning */
.x-pg-app-body .swal2-popup.x-pg-swal-toast-warning {
	border-left-color: #f59e0b;
}
.x-pg-app-body .swal2-popup.x-pg-swal-toast-warning .swal2-timer-progress-bar {
	background: #f59e0b;
}

/* 類型：Info */
.x-pg-app-body .swal2-popup.x-pg-swal-toast-info {
	border-left-color: #60a5fa;
}
.x-pg-app-body .swal2-popup.x-pg-swal-toast-info .swal2-timer-progress-bar {
	background: #60a5fa;
}

/* 響應式 */
@media (max-width: 576px) {
	.x-pg-app-body .swal2-container.swal2-top-end,
	.x-pg-app-body .swal2-container.swal2-bottom-end {
		bottom: 16px;
		right: 12px;
		left: 12px;
		max-width: none;
	}
	.x-pg-app-body .swal2-popup.x-pg-swal-toast {
		width: 100%;
		max-width: none;
	}
}

/* ===== Custom Dropdown 樣式 ===== */
.x-pg-nav-top .custom-dropdown {
	position: relative;
	display: inline-block;
}

.x-pg-nav-top .custom-dropdown-toggle {
	cursor: pointer;
	border: 0;
	background: transparent;
	color: #fff !important;
	border-radius: 0.475rem;
	padding: 0.5rem 0.75rem;
	display: flex;
	align-items: center;
	transition: background 0.2s, color 0.2s;
	text-decoration: none;
}

.x-pg-nav-top .custom-dropdown-toggle:hover,
.x-pg-nav-top .custom-dropdown-toggle:focus {
	background: rgba(255, 255, 255, 0.1);
	color: #fff !important;
	outline: none;
}

.x-pg-nav-top .custom-dropdown-menu {
	display: none;
	position: absolute;
	right: 0;
	top: calc(100% + 0.5rem);
	min-width: 180px;
	background: #fff;
	border-radius: 0.475rem;
	box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
	z-index: 1100;
	padding: 0.5rem 0;
	list-style: none;
	margin: 0;
}

.x-pg-nav-top .custom-dropdown:focus-within .custom-dropdown-menu,
.x-pg-nav-top .custom-dropdown.open .custom-dropdown-menu {
	display: block;
}

.x-pg-nav-top .custom-dropdown-menu li {
	padding: 0;
	margin: 0;
}

.x-pg-nav-top .custom-dropdown-menu li a {
	display: flex;
	align-items: center;
	width: 100%;
	padding: 0.65rem 1rem;
	color: #333;
	text-decoration: none;
	background: transparent;
	border: none;
	text-align: left;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
	font-size: 0.875rem;
}

.x-pg-nav-top .custom-dropdown-menu li a:hover,
.x-pg-nav-top .custom-dropdown-menu li a:focus {
	background-color: #f1f5f9;
	color: var(--x-pg-nav);
	outline: none;
}

.x-pg-nav-top .custom-dropdown-menu li a i {
	width: 18px;
	text-align: center;
}

/* ===== 設定網址 / 網域 Modal 樣式 ===== */
#bioPublishUrlSettingsModal .input-group {
	display: flex;
	align-items: stretch;
}

#bioPublishUrlSettingsModal .input-group-text {
	white-space: nowrap;
	font-weight: 500;
	color: #495057;
	border-right: 0;
}

#bioPublishUrlSettingsModal .input-group .form-control {
	border-left: 0;
}

#bioPublishUrlSettingsModal .input-group .form-control:focus {
	border-left: 1px solid #86b7fe;
	z-index: 3;
}

#bioPublishUrlSettingsModal .input-group:focus-within .input-group-text {
	border-color: #86b7fe;
	z-index: 3;
}

/* ===== DEV 角标样式 ===== */
.x-pg-dev-badge {
	position: relative;
}

.x-pg-dev-badge::after {
	content: "DEV";
	position: absolute;
	top: -6px;
	right: -6px;
	background-color: #ff6b6b;
	color: #fff;
	font-size: 0.6rem;
	font-weight: 700;
	padding: 2px 4px;
	border-radius: 3px;
	line-height: 1;
	z-index: 10;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
	letter-spacing: 0.5px;
	pointer-events: none; /* 防止角标遮挡按钮点击 */
}

/* 新視窗預覽：工具列與 PC/平板/手機切換 */
.preview-container {
	display: flex;
	flex-direction: column;
	height: 100vh;
	background: #f5f5f5;
}
.preview-toolbar {
	background: #fff;
	border-bottom: 1px solid #e0e0e0;
	padding: 1rem 1.5rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
	z-index: 1000;
}
.preview-toolbar h4 {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 600;
	color: #333;
}
.device-selector {
	display: flex;
	gap: 0.5rem;
	align-items: center;
}
.device-btn {
	padding: 0.5rem 1rem;
	border: 1px solid #ddd;
	background: #fff;
	border-radius: 0.375rem;
	cursor: pointer;
	font-size: 0.875rem;
	transition: all 0.2s;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--x-pg-text);
}
.device-btn i,
.device-btn span {
	color: inherit;
}
.device-btn:hover {
	background: #f8f9fa;
	border-color: #667eea;
}
.device-btn:hover i,
.device-btn:hover span {
	color: inherit;
}
.device-btn.active {
	background: #667eea;
	color: #fff;
	border-color: #667eea;
}
.device-btn.active i,
.device-btn.active span {
	color: #fff;
}
.preview-content-wrapper {
	flex: 1;
	overflow: auto;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	padding: 2rem;
}
.preview-frame {
	background: #fff;
	box-shadow: var(--x-pg-shadow-card);
	transition: all 0.3s ease;
	overflow: hidden;
}
.preview-frame.desktop {
	width: 100%;
	
}
.preview-frame.tablet {
	width: 768px;
}
.preview-frame.mobile {
	width: 375px;
}
.preview-inner {
	width: 100%;
	overflow: auto;
	background: #fff;
}
.preview-actual-page-hint {
	font-size: 0.9375rem;
	color: #475569;
	line-height: 1.5;
	padding: 0.75rem 1.5rem;
	background: #f1f5f9;
	border-bottom: 1px solid #e2e8f0;
	flex-shrink: 0;
}
.preview-content-wrapper:has(.preview-frame.desktop) {
	padding: 2rem 0 0 0;
}

/* 裝置模擬：平板(768px) / 手機(576px) 時，強制 Bootstrap 響應式顯示與間距等同該斷點 */
.x-pg-preview-frame.tablet .label_box.label-matrix .x-radio,
.x-pg-preview-frame.tablet .score-level .score-level__scales,
.x-pg-preview-frame.size-tablet .label_box.label-matrix .x-radio,
.x-pg-preview-frame.size-tablet .score-level .score-level__scales {
	display: none !important;
}
.x-pg-preview-frame.tablet .label_box.label-matrix,
.x-pg-preview-frame.size-tablet .label_box.label-matrix {
	display: flex;
	width: 100%;
	flex-wrap: wrap;
	gap: 4px;
}
.x-pg-preview-frame.tablet .label_box.label-matrix label,
.x-pg-preview-frame.size-tablet .label_box.label-matrix label {
	flex-grow: 1;
	outline: 1px dashed #979797;
	background-color: #fff;
	width: 100%;
}
.x-pg-preview-frame.tablet .label_box.label-matrix label .d-flex.gap-3,
.x-pg-preview-frame.size-tablet .label_box.label-matrix label .d-flex.gap-3 {
	justify-content: start;
	width: 100%;
	gap: 0 !important;
}
.x-pg-preview-frame.tablet .label_box.label-matrix input[type="radio"]:checked+label,
.x-pg-preview-frame.size-tablet .label_box.label-matrix input[type="radio"]:checked+label {
	outline: 1px solid var(--bs-danger);
	background-color: #f9f4e5;
	font-weight: 700;
}
.x-pg-preview-frame.tablet .sub-quest__title,
.x-pg-preview-frame.size-tablet .sub-quest__title {
	width: 100%;
}
.x-pg-preview-frame.tablet .sub-quest,
.x-pg-preview-frame.size-tablet .sub-quest {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
}
.x-pg-preview-frame.tablet .sub-quest span,
.x-pg-preview-frame.size-tablet .sub-quest span {
	width: 100%;
	display: block;
	margin-bottom: .5rem;
}
.x-pg-preview-frame.mobile .label_box.label-matrix .x-radio,
.x-pg-preview-frame.mobile .score-level .score-level__scales,
.x-pg-preview-frame.size-mobile .label_box.label-matrix .x-radio,
.x-pg-preview-frame.size-mobile .score-level .score-level__scales {
	display: none !important;
}
.x-pg-preview-frame.mobile .label_box.label-matrix,
.x-pg-preview-frame.size-mobile .label_box.label-matrix {
	display: flex;
	width: 100%;
	flex-wrap: wrap;
	gap: 4px;
}
.x-pg-preview-frame.mobile .label_box.label-matrix label,
.x-pg-preview-frame.size-mobile .label_box.label-matrix label {
	flex-grow: 1;
	outline: 1px dashed #979797;
	background-color: #fff;
	width: 100%;
}
.x-pg-preview-frame.mobile .label_box.label-matrix label .d-flex.gap-3,
.x-pg-preview-frame.size-mobile .label_box.label-matrix label .d-flex.gap-3 {
	justify-content: start;
	width: 100%;
	gap: 0 !important;
}
.x-pg-preview-frame.mobile .label_box.label-matrix input[type="radio"]:checked+label,
.x-pg-preview-frame.size-mobile .label_box.label-matrix input[type="radio"]:checked+label {
	outline: 1px solid var(--bs-danger);
	background-color: #f9f4e5;
	font-weight: 700;
}
.x-pg-preview-frame.mobile .sub-quest__title,
.x-pg-preview-frame.size-mobile .sub-quest__title {
	width: 100%;
}
.x-pg-preview-frame.mobile .sub-quest,
.x-pg-preview-frame.size-mobile .sub-quest {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
}
.x-pg-preview-frame.mobile .sub-quest span,
.x-pg-preview-frame.size-mobile .sub-quest span {
	width: 100%;
	display: block;
	margin-bottom: .5rem;
}
/* flex 斷點類：平板時等同 md 以下，手機時等同 sm 以下 */
.x-pg-preview-frame.tablet .flex-lg-row,
.x-pg-preview-frame.tablet .flex-xl-row,
.x-pg-preview-frame.tablet .flex-xxl-row,
.x-pg-preview-frame.size-tablet .flex-lg-row,
.x-pg-preview-frame.size-tablet .flex-xl-row,
.x-pg-preview-frame.size-tablet .flex-xxl-row {
	flex-direction: column !important;
}
.x-pg-preview-frame.mobile .flex-md-row,
.x-pg-preview-frame.mobile .flex-lg-row,
.x-pg-preview-frame.mobile .flex-xl-row,
.x-pg-preview-frame.mobile .flex-xxl-row,
.x-pg-preview-frame.size-mobile .flex-md-row,
.x-pg-preview-frame.size-mobile .flex-lg-row,
.x-pg-preview-frame.size-mobile .flex-xl-row,
.x-pg-preview-frame.size-mobile .flex-xxl-row {
	flex-direction: column !important;
}
.x-pg-preview-frame.tablet [class^="d-lg-"]:not(.d-lg-none),
.x-pg-preview-frame.tablet [class*=" d-lg-"]:not(.d-lg-none),
.x-pg-preview-frame.tablet [class^="d-xl-"]:not(.d-xl-none),
.x-pg-preview-frame.tablet [class*=" d-xl-"]:not(.d-xl-none),
.x-pg-preview-frame.tablet [class^="d-xxl-"]:not(.d-xxl-none),
.x-pg-preview-frame.tablet [class*=" d-xxl-"]:not(.d-xxl-none),
.x-pg-preview-frame.size-tablet [class^="d-lg-"]:not(.d-lg-none),
.x-pg-preview-frame.size-tablet [class*=" d-lg-"]:not(.d-lg-none),
.x-pg-preview-frame.size-tablet [class^="d-xl-"]:not(.d-xl-none),
.x-pg-preview-frame.size-tablet [class*=" d-xl-"]:not(.d-xl-none),
.x-pg-preview-frame.size-tablet [class^="d-xxl-"]:not(.d-xxl-none),
.x-pg-preview-frame.size-tablet [class*=" d-xxl-"]:not(.d-xxl-none) {
	display: none !important;
}
.x-pg-preview-frame.tablet .d-lg-none,
.x-pg-preview-frame.tablet .d-xl-none,
.x-pg-preview-frame.tablet .d-xxl-none,
.x-pg-preview-frame.size-tablet .d-lg-none,
.x-pg-preview-frame.size-tablet .d-xl-none,
.x-pg-preview-frame.size-tablet .d-xxl-none {
	display: revert !important;
}
.x-pg-preview-frame.mobile [class^="d-md-"]:not(.d-md-none),
.x-pg-preview-frame.mobile [class*=" d-md-"]:not(.d-md-none),
.x-pg-preview-frame.mobile [class^="d-lg-"]:not(.d-lg-none),
.x-pg-preview-frame.mobile [class*=" d-lg-"]:not(.d-lg-none),
.x-pg-preview-frame.mobile [class^="d-xl-"]:not(.d-xl-none),
.x-pg-preview-frame.mobile [class*=" d-xl-"]:not(.d-xl-none),
.x-pg-preview-frame.mobile [class^="d-xxl-"]:not(.d-xxl-none),
.x-pg-preview-frame.mobile [class*=" d-xxl-"]:not(.d-xxl-none),
.x-pg-preview-frame.size-mobile [class^="d-md-"]:not(.d-md-none),
.x-pg-preview-frame.size-mobile [class*=" d-md-"]:not(.d-md-none),
.x-pg-preview-frame.size-mobile [class^="d-lg-"]:not(.d-lg-none),
.x-pg-preview-frame.size-mobile [class*=" d-lg-"]:not(.d-lg-none),
.x-pg-preview-frame.size-mobile [class^="d-xl-"]:not(.d-xl-none),
.x-pg-preview-frame.size-mobile [class*=" d-xl-"]:not(.d-xl-none),
.x-pg-preview-frame.size-mobile [class^="d-xxl-"]:not(.d-xxl-none),
.x-pg-preview-frame.size-mobile [class*=" d-xxl-"]:not(.d-xxl-none) {
	display: none !important;
}
.x-pg-preview-frame.mobile .d-md-none,
.x-pg-preview-frame.mobile .d-lg-none,
.x-pg-preview-frame.mobile .d-xl-none,
.x-pg-preview-frame.mobile .d-xxl-none,
.x-pg-preview-frame.size-mobile .d-md-none,
.x-pg-preview-frame.size-mobile .d-lg-none,
.x-pg-preview-frame.size-mobile .d-xl-none,
.x-pg-preview-frame.size-mobile .d-xxl-none {
	display: revert !important;
}
.x-pg-preview-frame.tablet [class*="p-xl-"],
.x-pg-preview-frame.tablet [class*="p-lg-"],
.x-pg-preview-frame.tablet [class*="p-xxl-"],
.x-pg-preview-frame.tablet [class*="px-xl-"],
.x-pg-preview-frame.tablet [class*="px-lg-"],
.x-pg-preview-frame.tablet [class*="py-xl-"],
.x-pg-preview-frame.tablet [class*="py-lg-"],
.x-pg-preview-frame.tablet [class*="pt-xl-"],
.x-pg-preview-frame.tablet [class*="pt-lg-"],
.x-pg-preview-frame.tablet [class*="pb-xl-"],
.x-pg-preview-frame.tablet [class*="pb-lg-"],
.x-pg-preview-frame.tablet [class*="ps-xl-"],
.x-pg-preview-frame.tablet [class*="ps-lg-"],
.x-pg-preview-frame.tablet [class*="pe-xl-"],
.x-pg-preview-frame.tablet [class*="pe-lg-"],
.x-pg-preview-frame.size-tablet [class*="p-xl-"],
.x-pg-preview-frame.size-tablet [class*="p-lg-"],
.x-pg-preview-frame.size-tablet [class*="p-xxl-"],
.x-pg-preview-frame.size-tablet [class*="px-xl-"],
.x-pg-preview-frame.size-tablet [class*="px-lg-"],
.x-pg-preview-frame.size-tablet [class*="py-xl-"],
.x-pg-preview-frame.size-tablet [class*="py-lg-"],
.x-pg-preview-frame.size-tablet [class*="pt-xl-"],
.x-pg-preview-frame.size-tablet [class*="pt-lg-"],
.x-pg-preview-frame.size-tablet [class*="pb-xl-"],
.x-pg-preview-frame.size-tablet [class*="pb-lg-"],
.x-pg-preview-frame.size-tablet [class*="ps-xl-"],
.x-pg-preview-frame.size-tablet [class*="ps-lg-"],
.x-pg-preview-frame.size-tablet [class*="pe-xl-"],
.x-pg-preview-frame.size-tablet [class*="pe-lg-"] {
	padding: 0 !important;
}
.x-pg-preview-frame.tablet [class*="m-xl-"],
.x-pg-preview-frame.tablet [class*="m-lg-"],
.x-pg-preview-frame.tablet [class*="m-xxl-"],
.x-pg-preview-frame.tablet [class*="mx-xl-"],
.x-pg-preview-frame.tablet [class*="mx-lg-"],
.x-pg-preview-frame.tablet [class*="my-xl-"],
.x-pg-preview-frame.tablet [class*="my-lg-"],
.x-pg-preview-frame.tablet [class*="mt-xl-"],
.x-pg-preview-frame.tablet [class*="mt-lg-"],
.x-pg-preview-frame.tablet [class*="mb-xl-"],
.x-pg-preview-frame.tablet [class*="mb-lg-"],
.x-pg-preview-frame.tablet [class*="ms-xl-"],
.x-pg-preview-frame.tablet [class*="ms-lg-"],
.x-pg-preview-frame.tablet [class*="me-xl-"],
.x-pg-preview-frame.tablet [class*="me-lg-"],
.x-pg-preview-frame.size-tablet [class*="m-xl-"],
.x-pg-preview-frame.size-tablet [class*="m-lg-"],
.x-pg-preview-frame.size-tablet [class*="m-xxl-"],
.x-pg-preview-frame.size-tablet [class*="mx-xl-"],
.x-pg-preview-frame.size-tablet [class*="mx-lg-"],
.x-pg-preview-frame.size-tablet [class*="my-xl-"],
.x-pg-preview-frame.size-tablet [class*="my-lg-"],
.x-pg-preview-frame.size-tablet [class*="mt-xl-"],
.x-pg-preview-frame.size-tablet [class*="mt-lg-"],
.x-pg-preview-frame.size-tablet [class*="mb-xl-"],
.x-pg-preview-frame.size-tablet [class*="mb-lg-"],
.x-pg-preview-frame.size-tablet [class*="ms-xl-"],
.x-pg-preview-frame.size-tablet [class*="ms-lg-"],
.x-pg-preview-frame.size-tablet [class*="me-xl-"],
.x-pg-preview-frame.size-tablet [class*="me-lg-"] {
	margin: 0 !important;
}
.x-pg-preview-frame.mobile [class*="p-md-"],
.x-pg-preview-frame.mobile [class*="p-lg-"],
.x-pg-preview-frame.mobile [class*="p-xl-"],
.x-pg-preview-frame.mobile [class*="p-xxl-"],
.x-pg-preview-frame.mobile [class*="px-md-"],
.x-pg-preview-frame.mobile [class*="px-lg-"],
.x-pg-preview-frame.mobile [class*="px-xl-"],
.x-pg-preview-frame.mobile [class*="py-md-"],
.x-pg-preview-frame.mobile [class*="py-lg-"],
.x-pg-preview-frame.mobile [class*="py-xl-"],
.x-pg-preview-frame.mobile [class*="pt-md-"],
.x-pg-preview-frame.mobile [class*="pt-lg-"],
.x-pg-preview-frame.mobile [class*="pt-xl-"],
.x-pg-preview-frame.mobile [class*="pb-md-"],
.x-pg-preview-frame.mobile [class*="pb-lg-"],
.x-pg-preview-frame.mobile [class*="pb-xl-"],
.x-pg-preview-frame.mobile [class*="ps-md-"],
.x-pg-preview-frame.mobile [class*="ps-lg-"],
.x-pg-preview-frame.mobile [class*="ps-xl-"],
.x-pg-preview-frame.mobile [class*="pe-md-"],
.x-pg-preview-frame.mobile [class*="pe-lg-"],
.x-pg-preview-frame.mobile [class*="pe-xl-"],
.x-pg-preview-frame.size-mobile [class*="p-md-"],
.x-pg-preview-frame.size-mobile [class*="p-lg-"],
.x-pg-preview-frame.size-mobile [class*="p-xl-"],
.x-pg-preview-frame.size-mobile [class*="p-xxl-"],
.x-pg-preview-frame.size-mobile [class*="px-md-"],
.x-pg-preview-frame.size-mobile [class*="px-lg-"],
.x-pg-preview-frame.size-mobile [class*="px-xl-"],
.x-pg-preview-frame.size-mobile [class*="py-md-"],
.x-pg-preview-frame.size-mobile [class*="py-lg-"],
.x-pg-preview-frame.size-mobile [class*="py-xl-"],
.x-pg-preview-frame.size-mobile [class*="pt-md-"],
.x-pg-preview-frame.size-mobile [class*="pt-lg-"],
.x-pg-preview-frame.size-mobile [class*="pt-xl-"],
.x-pg-preview-frame.size-mobile [class*="pb-md-"],
.x-pg-preview-frame.size-mobile [class*="pb-lg-"],
.x-pg-preview-frame.size-mobile [class*="pb-xl-"],
.x-pg-preview-frame.size-mobile [class*="ps-md-"],
.x-pg-preview-frame.size-mobile [class*="ps-lg-"],
.x-pg-preview-frame.size-mobile [class*="ps-xl-"],
.x-pg-preview-frame.size-mobile [class*="pe-md-"],
.x-pg-preview-frame.size-mobile [class*="pe-lg-"],
.x-pg-preview-frame.size-mobile [class*="pe-xl-"] {
	padding: 0 !important;
}
.x-pg-preview-frame.mobile [class*="m-md-"],
.x-pg-preview-frame.mobile [class*="m-lg-"],
.x-pg-preview-frame.mobile [class*="m-xl-"],
.x-pg-preview-frame.mobile [class*="m-xxl-"],
.x-pg-preview-frame.mobile [class*="mx-md-"],
.x-pg-preview-frame.mobile [class*="mx-lg-"],
.x-pg-preview-frame.mobile [class*="my-md-"],
.x-pg-preview-frame.mobile [class*="my-lg-"],
.x-pg-preview-frame.mobile [class*="mt-md-"],
.x-pg-preview-frame.mobile [class*="mt-lg-"],
.x-pg-preview-frame.mobile [class*="mb-md-"],
.x-pg-preview-frame.mobile [class*="mb-lg-"],
.x-pg-preview-frame.mobile [class*="ms-md-"],
.x-pg-preview-frame.mobile [class*="ms-lg-"],
.x-pg-preview-frame.mobile [class*="me-md-"],
.x-pg-preview-frame.mobile [class*="me-lg-"],
.x-pg-preview-frame.size-mobile [class*="m-md-"],
.x-pg-preview-frame.size-mobile [class*="m-lg-"],
.x-pg-preview-frame.size-mobile [class*="m-xl-"],
.x-pg-preview-frame.size-mobile [class*="m-xxl-"],
.x-pg-preview-frame.size-mobile [class*="mx-md-"],
.x-pg-preview-frame.size-mobile [class*="mx-lg-"],
.x-pg-preview-frame.size-mobile [class*="my-md-"],
.x-pg-preview-frame.size-mobile [class*="my-lg-"],
.x-pg-preview-frame.size-mobile [class*="mt-md-"],
.x-pg-preview-frame.size-mobile [class*="mt-lg-"],
.x-pg-preview-frame.size-mobile [class*="mb-md-"],
.x-pg-preview-frame.size-mobile [class*="mb-lg-"],
.x-pg-preview-frame.size-mobile [class*="ms-md-"],
.x-pg-preview-frame.size-mobile [class*="ms-lg-"],
.x-pg-preview-frame.size-mobile [class*="me-md-"],
.x-pg-preview-frame.size-mobile [class*="me-lg-"] {
	margin: 0 !important;
}

/* 巨頭風格 Confirm 對話框（bio-resume-alert） */
.bio-alert-overlay {
	position: fixed;
	inset: 0;
	z-index: 1060;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(15, 23, 42, 0.4);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.25s ease, visibility 0.25s ease;
}
.bio-alert-overlay.bio-alert-show {
	opacity: 1;
	visibility: visible;
}
.bio-alert-dialog {
	min-width: 320px;
	max-width: 400px;
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.18), 0 0 0 1px rgba(0, 0, 0, 0.04);
	overflow: hidden;
	transform: scale(0.96);
	transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.bio-alert-overlay.bio-alert-show .bio-alert-dialog {
	transform: scale(1);
}
.bio-alert-dialog-header {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 22px 20px 0;
	position: relative;
}
.bio-alert-dialog-header-text {
	flex: 1;
	min-width: 0;
}
.bio-alert-dialog-title {
	font-size: 1.125rem;
	font-weight: 600;
	color: #0f172a;
	letter-spacing: -0.01em;
	line-height: 1.35;
	margin-bottom: 4px;
}
.bio-alert-dialog-message {
	font-size: 0.9375rem;
	color: #475569;
	line-height: 1.5;
}
.bio-alert-dialog-close {
	position: absolute;
	top: 18px;
	right: 16px;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	color: #64748b;
	border-radius: 8px;
	cursor: pointer;
	transition: color 0.2s, background 0.2s;
}
.bio-alert-dialog-close:hover {
	color: #0f172a;
	background: #f1f5f9;
}
.bio-alert-dialog-icon {
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 12px;
	font-size: 1.25rem;
}
.bio-alert-dialog-icon-danger {
	background: #fef2f2;
	color: #dc2626;
}
.bio-alert-dialog-footer {
	display: flex;
	justify-content: flex-end;
	gap: 10px;
	padding: 20px 20px 22px;
	border-top: 1px solid #f1f5f9;
}
.bio-alert-dialog-footer .bio-alert-cancel {
	border-radius: 10px;
	font-weight: 500;
}
.bio-alert-dialog-footer .bio-alert-confirm {
	border-radius: 10px;
	font-weight: 500;
}
.bio-alert-dialog-danger .bio-alert-dialog-footer .bio-alert-confirm {
	background: #dc2626;
	border-color: #dc2626;
}
.bio-alert-dialog-danger .bio-alert-dialog-footer .bio-alert-confirm:hover {
	background: #b91c1c;
	border-color: #b91c1c;
}

/* ===== Bio Alert Toast 通知 (科技巨頭風格 — Linear / Vercel) ===== */
#bio-alert-wrapper {
	position: fixed;
	bottom: 28px;
	right: 24px;
	z-index: 9999;
	display: flex;
	flex-direction: column;
	gap: 10px;
	width: 380px;
	pointer-events: none;
}

.bio-alert-container {
	width: 100%;
	opacity: 0;
	transform: translateY(14px) scale(0.93);
	transition:
		opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1),
		transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
	pointer-events: none;
}

.bio-alert-container.bio-alert-show {
	opacity: 1;
	transform: translateY(0) scale(1);
	pointer-events: auto;
}

.bio-alert-content {
	display: flex;
	align-items: flex-start;
	gap: 11px;
	background: #111827;
	border-radius: 13px;
	box-shadow:
		0 0 0 1px rgba(255, 255, 255, 0.07),
		0 2px 4px rgba(0, 0, 0, 0.24),
		0 8px 20px rgba(0, 0, 0, 0.3),
		0 24px 48px rgba(0, 0, 0, 0.18);
	padding: 14px 12px 20px 16px;
	position: relative;
	overflow: hidden;
	border-left: 2.5px solid transparent; /* JS inline style 設置顏色 */
}

/* 底部自動消失進度條 */
.bio-alert-progress {
	position: absolute;
	bottom: 0;
	left: 0;
	height: 2.5px;
	border-radius: 0 2px 0 0;
	background: var(--bio-alert-color, #3b82f6);
	opacity: 0.65;
	width: 100%;
	transform-origin: left center;
	animation: bio-alert-progress-shrink var(--bio-alert-duration, 3000ms) linear forwards;
}

@keyframes bio-alert-progress-shrink {
	from { width: 100%; }
	to { width: 0%; }
}

/* 圖示 */
.bio-alert-icon {
	font-size: 1.1rem;
	flex-shrink: 0;
	line-height: 1;
	margin-top: 1px;
	/* color 由 JS inline style 設置 */
	opacity: 0.92;
}

/* 文字區 */
.bio-alert-body {
	flex: 1;
	min-width: 0;
}

.bio-alert-title {
	font-size: 0.875rem;
	font-weight: 600;
	color: #f1f5f9;
	margin-bottom: 3px;
	line-height: 1.4;
	letter-spacing: -0.01em;
}

.bio-alert-message {
	font-size: 0.875rem;
	color: #94a3b8;
	line-height: 1.5;
}

/* 只有訊息（無標題）時，文字較亮 */
.bio-alert-body > .bio-alert-message:only-child {
	color: #cbd5e1;
}

/* 關閉按鈕 */
.bio-alert-close {
	background: none;
	border: none;
	color: #4b5563;
	cursor: pointer;
	line-height: 1;
	flex-shrink: 0;
	transition: color 0.15s ease, background 0.15s ease;
	border-radius: 6px;
	width: 22px;
	height: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 1px;
	padding: 0;
}

.bio-alert-close:hover {
	color: #e2e8f0;
	background: rgba(255, 255, 255, 0.1);
}

.bio-alert-close i {
	font-size: 0.9rem;
	line-height: 1;
}

/* 響應式：手機全寬從底部滑入 */
@media (max-width: 576px) {
	#bio-alert-wrapper {
		bottom: 16px;
		right: 12px;
		left: 12px;
		width: auto;
	}
}

/* ===== 版面配置選擇器（主題設定） ===== */
.x-pg-layout-cards .x-pg-layout-card-btn {
	min-width: 4rem;
	padding: 0.5rem 0.75rem;
	border-radius: var(--x-pg-radius-sm);
	border: 1px solid var(--x-pg-border);
	background: var(--x-pg-surface);
	font-size: 0.8125rem;
	transition: border-color 0.15s, box-shadow 0.15s;
}
.x-pg-layout-cards .x-pg-layout-card-btn:hover {
	border-color: var(--x-pg-edit-accent);
}
.x-pg-layout-cards .x-pg-layout-card-btn.active {
	border-color: var(--x-pg-edit-accent);
	background: rgba(67, 79, 132, 0.08);
	box-shadow: 0 0 0 1px var(--x-pg-edit-accent);
}

/* ===== 區塊外觀（所有版型共用預設） ===== */
.x-pg-page-header-section .x-pg-row {
	border-radius: var(--x-pg-radius-lg);
}
.x-pg-page-section .x-pg-row {
	border-radius: var(--x-pg-radius);
}
.x-pg-page-header-section .x-pg-row.x-pg-row-no-radius,
.x-pg-page-section .x-pg-row.x-pg-row-no-radius,
.x-pg-page-social .x-pg-row.x-pg-row-no-radius,
.x-pg-page-action-buttons .x-pg-row.x-pg-row-no-radius {
	border-radius: 0;
}
.x-pg-page-header-section .x-pg-row.x-pg-row-radius-tl,
.x-pg-page-header-section .x-pg-row.x-pg-row-radius-tr,
.x-pg-page-header-section .x-pg-row.x-pg-row-radius-bl,
.x-pg-page-header-section .x-pg-row.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-section-outer[data-preview-section^="bannerBlock_"] .x-pg-page-section .x-pg-row {
	border-radius: var(--x-pg-radius) var(--x-pg-radius) 0 0;
}
.x-pg-section-outer[data-preview-section^="eventTermsBlock_"] .x-pg-page-section .x-pg-row {
	border-radius: 0 0 var(--x-pg-radius) var(--x-pg-radius);
}
.x-pg-page-section .x-pg-row.x-pg-row-radius-tl,
.x-pg-page-section .x-pg-row.x-pg-row-radius-tr,
.x-pg-page-section .x-pg-row.x-pg-row-radius-bl,
.x-pg-page-section .x-pg-row.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-page-section .x-pg-row.x-pg-row-radius-tl {
	border-top-left-radius: var(--x-pg-radius);
}
.x-pg-page-section .x-pg-row.x-pg-row-radius-tr {
	border-top-right-radius: var(--x-pg-radius);
}
.x-pg-page-section .x-pg-row.x-pg-row-radius-bl {
	border-bottom-left-radius: var(--x-pg-radius);
}
.x-pg-page-section .x-pg-row.x-pg-row-radius-br {
	border-bottom-right-radius: var(--x-pg-radius);
}
.x-pg-page-header-section .x-pg-row.x-pg-row-radius-tl {
	border-top-left-radius: var(--x-pg-radius-lg);
}
.x-pg-page-header-section .x-pg-row.x-pg-row-radius-tr {
	border-top-right-radius: var(--x-pg-radius-lg);
}
.x-pg-page-header-section .x-pg-row.x-pg-row-radius-bl {
	border-bottom-left-radius: var(--x-pg-radius-lg);
}
.x-pg-page-header-section .x-pg-row.x-pg-row-radius-br {
	border-bottom-right-radius: var(--x-pg-radius-lg);
}
.x-pg-page-section {
	width: 100%;
	box-sizing: border-box;
}
/* ===== 版型：專業（橫向卡片 / 左圖右文） ===== */
.x-pg-layout-minimal .x-pg-layout-minimal-header {
	padding: var(--x-pg-row-inner-padding) var(--x-pg-inner-padding);
}
.x-pg-layout-minimal .x-pg-layout-minimal-row {
	position: relative;
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex-wrap: wrap;
	padding: 1.5rem 2rem;
	border-radius: var(--x-pg-radius-xl);
	overflow: hidden;
	text-align: left;
	min-height: 20vh;
}
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-no-radius {
	border-radius: 0;
}
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-radius-tl,
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-radius-tr,
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-radius-bl,
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-radius-tl {
	border-top-left-radius: var(--x-pg-radius-xl);
}
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-radius-tr {
	border-top-right-radius: var(--x-pg-radius-xl);
}
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-radius-bl {
	border-bottom-left-radius: var(--x-pg-radius-xl);
}
.x-pg-layout-minimal .x-pg-layout-minimal-row.x-pg-row-radius-br {
	border-bottom-right-radius: var(--x-pg-radius-xl);
}
.x-pg-layout-minimal .x-pg-layout-minimal-row::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	border-radius: inherit;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 560 200'%3E%3Cdefs%3E%3ClinearGradient id='g1' x1='0%25' y1='0%25' x2='100%25' y2='100%25'%3E%3Cstop offset='0%25' stop-color='%23fff' stop-opacity='0.08'/%3E%3Cstop offset='100%25' stop-color='%23fff' stop-opacity='0'/%3E%3C/linearGradient%3E%3C/defs%3E%3Ccircle cx='80' cy='80' r='120' fill='rgba(255,255,255,0.06)'/%3E%3Ccircle cx='480' cy='100' r='140' fill='rgba(255,255,255,0.05)'/%3E%3Ccircle cx='280' cy='160' r='80' fill='rgba(255,255,255,0.04)'/%3E%3Cpath d='M0 160 Q140 100 280 120 T560 100 L560 200 L0 200 Z' fill='rgba(255,255,255,0.03)'/%3E%3Crect width='100%25' height='100%25' fill='url(%23g1)'/%3E%3C/svg%3E");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.x-pg-layout-minimal .x-pg-layout-minimal-row > * {
	position: relative;
	z-index: 1;
}
.x-pg-layout-minimal .x-pg-layout-minimal-photo {
	--x-pg-photo-frame-height: 100px;
	width: var(--x-pg-photo-frame-height);
	height: var(--x-pg-photo-frame-height);
	min-width: var(--x-pg-photo-frame-height);
	min-height: var(--x-pg-photo-frame-height);
	max-width: var(--x-pg-photo-frame-height);
	max-height: var(--x-pg-photo-frame-height);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
	background: transparent;
	border: none;
	box-shadow: none;
}
.x-pg-layout-minimal .x-pg-layout-minimal-photo .x-pg-avatar-placeholder {
	width: 100px;
	height: 100px;
	min-width: 100px;
	min-height: 100px;
	border-radius: 0;
}
.x-pg-layout-minimal .x-pg-layout-minimal-heading {
	flex: 1;
	min-width: 0;
	text-align: left;
}
.x-pg-layout-minimal .x-pg-layout-minimal-name {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin: 0 0 0.4rem 0;
	line-height: 1.2;
	text-align: left;
}
.x-pg-layout-minimal .x-pg-layout-minimal-meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5rem 0.75rem;
	margin: 0 0 0.5rem 0;
	font-size: 0.875rem;
	opacity: 0.95;
	justify-content: flex-start;
}
.x-pg-layout-minimal .x-pg-layout-minimal-meta-sep {
	width: 1px;
	height: 0.875em;
	background: rgba(255,255,255,0.5);
	flex-shrink: 0;
}
.x-pg-layout-minimal .x-pg-layout-minimal-title {
	font-size: 0.9375rem;
	opacity: 0.95;
	margin: 0;
	font-weight: 500;
}
.x-pg-layout-minimal .x-pg-layout-minimal-company {
	margin: 0;
	font-size: 0.875rem;
	opacity: 0.9;
	display: flex;
	align-items: center;
	gap: 0.35rem;
}
.x-pg-layout-minimal .x-pg-layout-minimal-highlights {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.6rem;
	justify-content: flex-start;
}
.x-pg-layout-minimal .x-pg-layout-minimal-highlights .x-pg-page-highlight-item {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.3rem 0.8rem;
	border-radius: 999px;
	background: rgba(255,255,255,0.2);
	border: 1px solid rgba(255,255,255,0.35);
	font-size: 0.8125rem;
	margin: 0;
}
.x-pg-layout-minimal .x-pg-layout-minimal-highlights .x-pg-page-highlight-item i {
	margin: 0;
}
@media (max-width: 767px) {
	.x-pg-layout-minimal .x-pg-layout-minimal-photo,
	.x-pg-layout-minimal .x-pg-preview-photo-placeholder.x-pg-layout-minimal-photo {
		margin-left: 8px;
	}
}
.x-pg-preview-frame.mobile .x-pg-layout-minimal .x-pg-layout-minimal-photo,
.x-pg-preview-frame.mobile .x-pg-layout-minimal .x-pg-preview-photo-placeholder.x-pg-layout-minimal-photo {
	margin-left: 8px;
}

/* ===== 版型：全屏（滿版照片 / 底部漸層 / 白字） ===== */
.x-pg-layout-tech-hero .x-pg-page-inner {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}
.x-pg-layout-tech-hero .x-pg-page-header-section.x-pg-layout-tech-hero-hero {
	background: transparent;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero {
	min-height: 40vh;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	overflow: hidden;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero .x-pg-x-container {
	position: relative;
	z-index: 1;
	width: 100%;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner {
	width: 100%;
	max-width: 800px;
	min-height: clamp(420px, 56vh, 620px);
	margin-left: auto;
	margin-right: auto;
	padding: 2rem var(--x-pg-inner-padding) 2.5rem;
	box-shadow: none;
	border-radius: var(--x-pg-radius-lg);
	overflow: hidden;
	position: relative;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-no-radius {
	border-radius: 0;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-radius-tl,
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-radius-tr,
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-radius-bl,
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-radius-tl {
	border-top-left-radius: var(--x-pg-radius-lg);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-radius-tr {
	border-top-right-radius: var(--x-pg-radius-lg);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-radius-bl {
	border-bottom-left-radius: var(--x-pg-radius-lg);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner.x-pg-row-radius-br {
	border-bottom-right-radius: var(--x-pg-radius-lg);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner-with-bg {
	background:
		radial-gradient(circle at center, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0) 58%),
		linear-gradient(180deg, rgba(9, 14, 22, 0.88) 0%, rgba(9, 14, 22, 0.72) 100%);
	box-shadow: 0 25px 50px -12px rgba(0,0,0,0.2);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at center, rgba(255, 255, 255, 0.025) 0%, rgba(255, 255, 255, 0) 58%),
		linear-gradient(180deg, rgba(9, 14, 22, 0.12) 0%, rgba(9, 14, 22, 0.06) 100%);
	pointer-events: none;
	z-index: 0;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-media {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: block;
	object-fit: contain;
	object-position: center center;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(to top, rgba(4, 8, 14, 0.42) 0%, rgba(4, 8, 14, 0.18) 20%, rgba(4, 8, 14, 0.06) 38%, rgba(4, 8, 14, 0.015) 58%, rgba(4, 8, 14, 0) 72%),
		var(--x-pg-tech-hero-overlay, linear-gradient(to top, rgba(0,0,0,0.14) 0%, rgba(0,0,0,0.04) 28%, rgba(0,0,0,0) 52%));
	pointer-events: none;
	z-index: 0;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-content {
	position: absolute;
	z-index: 1;
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	text-align: center;
	bottom: 50px;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-name {
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: -0.03em;
	margin: 0 0 0.35rem 0;
	line-height: 1.2;
	color: #ffffff;
	text-shadow: 0 1px 4px rgba(0,0,0,0.5), 0 2px 8px rgba(0,0,0,0.3);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-title {
	font-size: 1.125rem;
	margin: 0 0 0.25rem 0;
	color: rgba(255,255,255,0.95);
	text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-company {
	font-size: 1rem;
	margin: 0 0 0.5rem 0;
	color: rgba(255,255,255,0.9);
	text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-highlights {
	margin-top: 0.75rem;
	text-align: center;
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-highlights .x-pg-page-highlight-item {
	color: rgba(255,255,255,0.9);
	text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}
.x-pg-layout-tech-hero .x-pg-layout-tech-hero-highlights .x-pg-page-highlight-item i {
	color: rgba(255,255,255,0.95);
}
@media (min-width: 768px) and (max-width: 991px) {
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner {
		min-height: clamp(380px, 50vh, 520px);
		padding: 1.75rem var(--x-pg-inner-padding) 2rem;
	}
}
@media (max-width: 767px) {
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero {
		min-height: 0;
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner {
		min-height: 520px;
		aspect-ratio: auto;
		padding: 0;
		display: flex;
		flex-direction: column;
		background:
			linear-gradient(180deg, rgba(11, 17, 27, 0.96) 0%, rgba(11, 17, 27, 0.88) 34%, rgba(18, 27, 42, 0.96) 100%);
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-media {
		position: absolute;
		inset: 0 0 auto 0;
		width: 100%;
		height: 340px;
		object-fit: contain;
		object-position: center top;
		background: transparent;
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-overlay {
		inset: 0 0 auto 0;
		height: 340px;
		background:
			linear-gradient(180deg, rgba(3, 6, 12, 0.14) 0%, rgba(3, 6, 12, 0.04) 28%, rgba(3, 6, 12, 0.1) 72%, rgba(3, 6, 12, 0.22) 100%);
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-content {
		position: relative;
		margin-top: 300px;
		height: auto;
		justify-content: flex-start;
		padding: 1rem 1rem 1.25rem;
		bottom: auto;
		background:
			linear-gradient(180deg, rgba(11, 17, 27, 0) 0%, rgba(11, 17, 27, 0.68) 16%, rgba(11, 17, 27, 0.96) 100%);
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-name {
		font-size: 1.75rem;
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-title {
		font-size: 1rem;
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-company {
		font-size: 0.95rem;
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-highlights {
		margin-top: 1rem;
		padding-top: 0.85rem;
		gap: 0.75rem;
	}
	.x-pg-layout-tech-hero .x-pg-layout-tech-hero-highlights .x-pg-page-highlight-item {
		white-space: normal;
		justify-content: center;
	}
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero {
	min-height: 0;
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-hero-inner {
	min-height: 520px;
	aspect-ratio: auto;
	padding: 0;
	display: flex;
	flex-direction: column;
	background:
		linear-gradient(180deg, rgba(11, 17, 27, 0.96) 0%, rgba(11, 17, 27, 0.88) 34%, rgba(18, 27, 42, 0.96) 100%);
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-media {
	position: absolute;
	inset: 0 0 auto 0;
	width: 100%;
	height: 340px;
	object-fit: contain;
	object-position: center top;
	background: transparent;
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-overlay {
	inset: 0 0 auto 0;
	height: 340px;
	background:
		linear-gradient(180deg, rgba(3, 6, 12, 0.14) 0%, rgba(3, 6, 12, 0.04) 28%, rgba(3, 6, 12, 0.1) 72%, rgba(3, 6, 12, 0.22) 100%);
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-content {
	position: relative;
	margin-top: 300px;
	height: auto;
	justify-content: flex-start;
	padding: 1rem 1rem 1.25rem;
	bottom: auto;
	background:
		linear-gradient(180deg, rgba(11, 17, 27, 0) 0%, rgba(11, 17, 27, 0.68) 16%, rgba(11, 17, 27, 0.96) 100%);
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-name {
	font-size: 1.75rem;
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-title {
	font-size: 1rem;
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-company {
	font-size: 0.95rem;
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-highlights {
	margin-top: 1rem;
	padding-top: 0.85rem;
	gap: 0.75rem;
}
.x-pg-preview-frame.mobile .x-pg-layout-tech-hero .x-pg-layout-tech-hero-highlights .x-pg-page-highlight-item {
	white-space: normal;
	justify-content: center;
}

/* ===== 版型：左右分欄 ===== */
.x-pg-layout-split .x-pg-layout-split-inner {
	display: flex;
	flex-wrap: wrap;
}
.x-pg-layout-split .x-pg-layout-split-sidebar {
	width: 280px;
	flex-shrink: 0;
	padding: var(--x-pg-row-inner-padding) var(--x-pg-inner-padding);
	background: rgba(0, 0, 0, 0.03);
	border-right: 1px solid var(--x-pg-border);
}
.x-pg-layout-split .x-pg-layout-split-main {
	flex: 1;
	min-width: 0;
	padding: var(--x-pg-row-inner-padding) var(--x-pg-inner-padding);
}
.x-pg-layout-split .x-pg-layout-split-sidebar-block {
	padding-bottom: var(--x-pg-row-inner-padding);
	margin-bottom: var(--x-pg-inner-padding);
	border-bottom: 1px solid var(--x-pg-border);
}
.x-pg-layout-split .x-pg-layout-split-photo {
	width: 160px;
	height: 160px;
	min-width: 160px;
	min-height: 160px;
	max-width: 160px;
	max-height: 160px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: var(--x-pg-border);
	border-radius: var(--x-pg-radius);
	margin-bottom: 0.75rem;
}
.x-pg-layout-split .x-pg-layout-split-photo-placeholder {
	width: 160px;
	height: 160px;
	min-width: 160px;
	min-height: 160px;
	background: var(--x-pg-border);
	border-radius: var(--x-pg-radius);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 0.75rem;
}
.x-pg-layout-split .x-pg-layout-split-name {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 0.25rem 0;
}
.x-pg-layout-split .x-pg-layout-split-title {
	font-size: 0.9375rem;
	color: var(--x-pg-text-muted);
	margin: 0;
}
@media (max-width: 767px) {
	.x-pg-layout-split .x-pg-layout-split-inner {
		flex-direction: column;
	}
	.x-pg-layout-split .x-pg-layout-split-sidebar {
		width: 100%;
		border-right: none;
		border-bottom: 1px solid var(--x-pg-border);
	}
}

/* ===== 版型：機械（儀表板 / 模組），僅 header 為卡片樣式 ===== */
.x-pg-layout-card {
	display: flex;
	justify-content: center;
}
.x-pg-layout-card .x-pg-layout-card-inner {
	width: 100%;
	max-width: 100%;
	margin: 0 auto;
	padding: 0;
	box-sizing: border-box;
}
.x-pg-layout-card .x-pg-layout-card-header-wrap {
	margin-top: 0;
	margin-bottom: 0;
}
.x-pg-layout-card .x-pg-layout-card-header-wrap .x-pg-x-container {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}
.x-pg-layout-card .x-pg-layout-card-header-wrap .x-pg-page-header-section {
	border-radius: 0;
	
	position: relative;
}
.x-pg-layout-card .x-pg-layout-card-header-wrap .x-pg-page-header-section:has(.x-pg-container-full) {
	background: transparent !important;
}
.x-pg-layout-card .x-pg-layout-card-header-wrap .x-pg-page-header-section:has(.x-pg-container-full)::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	background: var(--x-pg-row-bg, var(--x-pg-primary, #667eea));
	z-index: 0;
}
.x-pg-layout-card .x-pg-layout-card-header-wrap .x-pg-page-header-section:has(.x-pg-container-full) .x-pg-x-container,
.x-pg-layout-card .x-pg-layout-card-header-wrap .x-pg-page-header-section:has(.x-pg-container-full) .x-pg-row {
	position: relative;
	z-index: 1;
}
.x-pg-layout-card .x-pg-layout-card-header-wrap .x-pg-page-header-section:has(.x-pg-container-full) .x-pg-row {
	background: transparent !important;
}
/* 僅限 x-pg-page-header-section：卡片內左文右圖用 flex，x-pg-page-company 靠右，x-pg-page-highlights 在左文區底部 */
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row {
	position: relative;
	padding: 1.85rem 1.9rem 6.1rem;
	text-align: left;
	display: grid;
	grid-template-columns: minmax(0, 1fr) clamp(250px, 28vw, 340px);
	align-items: start;
	gap: 1.6rem;
	border-radius: 2rem;
	background:
		linear-gradient(145deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.04) 48%, rgba(255,255,255,0.08) 100%);
	border: 1px solid rgba(255,255,255,0.16);
	box-shadow:
		0 26px 54px rgba(15,23,42,0.15),
		inset 0 1px 0 rgba(255,255,255,0.12);
	backdrop-filter: blur(12px);
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-no-radius {
	border-radius: 0;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-radius-tl,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-radius-tr,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-radius-bl,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-radius-tl {
	border-top-left-radius: 2rem;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-radius-tr {
	border-top-right-radius: 2rem;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-radius-bl {
	border-bottom-left-radius: 2rem;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row.x-pg-row-radius-br {
	border-bottom-right-radius: 2rem;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row::before {
	content: "";
	position: absolute;
	inset: 1.2rem;
	border-radius: 1.6rem;
	background:
		radial-gradient(circle at top right, rgba(255,255,255,0.13), transparent 38%),
		linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0));
	pointer-events: none;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > * {
	position: relative;
	z-index: 1;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-header-text-col {
	min-width: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	padding-right: 0.3rem;
	position: static;
	padding: 12px 0 0 12px;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-name {
	font-size: clamp(2.8rem, 5.1vw, 4.9rem);
	line-height: 0.9;
	font-weight: 800;
	letter-spacing: -0.065em;
	margin: 0 0 0.85rem 0;
	max-width: 7ch;
	text-wrap: balance;
	text-shadow: 0 12px 28px rgba(15,23,42,0.1);
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-title {
	font-size: 1.05rem;
	font-weight: 500;
	opacity: 0.94;
	margin: 0 0 1.2rem 0;
	max-width: 22ch;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-company {
	display: inline-flex;
	align-items: center;
	justify-content: start;
	gap: 0.6rem;
	font-size: 1rem;
	font-weight: 500;
	opacity: 0.86;
	margin: 0;
	padding-top: 1rem;
	border-top: 1px solid rgba(255,255,255,0.16);
	max-width: 28ch;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder {
	order: 2;
	flex-shrink: 0;
	--x-pg-photo-frame-height: 260px;
	width: var(--x-pg-photo-frame-height);
	height: var(--x-pg-photo-frame-height);
	min-width: var(--x-pg-photo-frame-height);
	min-height: var(--x-pg-photo-frame-height);
	max-width: 100%;
	max-height: none;
	display: flex;
	align-items: center;
	justify-content: center;
	align-self: start;
	justify-self: end;
	overflow: hidden;
	margin: 0;
	
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo.x-pg-avatar-shape-rounded,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder.x-pg-avatar-shape-rounded,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder.x-pg-avatar-shape-rounded {
	border-radius: 18px;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo.x-pg-avatar-shape-circle,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder.x-pg-avatar-shape-circle,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder.x-pg-avatar-shape-circle {
	--x-pg-photo-frame-height: 300px;
	border-radius: 999px;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo.x-pg-avatar-shape-rect,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder.x-pg-avatar-shape-rect,
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder.x-pg-avatar-shape-rect {
	border-radius: 0;
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-highlights {
	position: absolute;
	left: 1.25rem;
	right: 1.25rem;
	bottom: 1.25rem;
	z-index: 2;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.8rem;
	margin: 0;
	padding: 1rem 1.05rem;
	border-top: none;
	border-radius: 1.4rem;
	
	backdrop-filter: blur(12px);
}
.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-highlight-item {
	justify-content: flex-start;
	gap: 0.65rem;
	min-width: 0;
	padding: 0.8rem 0.9rem;
	border-radius: 1rem;
	background: rgba(255,255,255,0.1);
	border: 1px solid rgba(255,255,255,0.12);
	font-size: 0.96rem;
	font-weight: 500;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
@media (max-width: 767px) {
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row {
		padding: 1rem 1rem 1rem;
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-header-text-col {
		padding-right: 0;
	}
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-name {
		font-size: 2.5rem;
		max-width: none;
	}
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-title {
		font-size: 1.02rem;
		margin-bottom: 0.9rem;
	}
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-company {
		padding-top: 0.8rem;
	}
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo,
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder,
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder {
		--x-pg-photo-frame-height: 180px;
		justify-self: start;
	}
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-highlights {
		position: static;
		grid-template-columns: 1fr;
		margin-top: 1rem;
		padding: 0.85rem;
	}
	.x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-highlight-item {
		font-size: 0.92rem;
	}
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row {
	padding: 1rem 1rem 1rem;
	grid-template-columns: 1fr;
	gap: 0;
	overflow: hidden;
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo,
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder,
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder {
	position: absolute;
	top: 1.1rem;
	left: 50%;
	right: auto;
	transform: translateX(-50%);
	--x-pg-photo-frame-height: min(74vw, 320px);
	width: var(--x-pg-photo-frame-height);
	height: var(--x-pg-photo-frame-height);
	min-width: var(--x-pg-photo-frame-height);
	min-height: var(--x-pg-photo-frame-height);
	justify-self: center;
	align-self: start;
	z-index: 2;
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo.x-pg-avatar-shape-circle,
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder.x-pg-avatar-shape-circle,
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder.x-pg-avatar-shape-circle,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo.x-pg-avatar-shape-circle,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-photo-placeholder.x-pg-avatar-shape-circle,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-preview-photo-placeholder.x-pg-avatar-shape-circle {
	--x-pg-photo-frame-height: min(74vw, 320px);
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-header-text-col,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row > .x-pg-page-header-text-col {
	position: relative;
	z-index: 3;
	padding: clamp(9.75rem, 38vw, 13.75rem) 0 0 0;
	padding-right: 0;
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-name,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-name {
	display: inline-block;
	width: fit-content;
	max-width: min(78%, 7.5ch);
	font-size: clamp(2rem, 9vw, 3rem);
	line-height: 0.92;
	margin: 0 0 0.55rem 0;
	padding: 0.2rem 0.45rem 0.28rem;
	background: rgba(255, 255, 255, 0.18);
	backdrop-filter: blur(10px);
	box-shadow: 0 8px 22px rgba(15, 23, 42, 0.14);
	border-radius: 0.35rem;
	position: relative;
	z-index: 1;
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-title,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-title {
	display: inline-block;
	width: fit-content;
	max-width: 82%;
	font-size: 0.9rem;
	line-height: 1.3;
	margin: 0 0 0.85rem 0;
	padding: 0.22rem 0.5rem 0.28rem;
	background: rgba(255, 255, 255, 0.14);
	backdrop-filter: blur(8px);
	box-shadow: 0 6px 18px rgba(15, 23, 42, 0.12);
	border-radius: 0.35rem;
	position: relative;
	z-index: 1;
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-company,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-company {
	padding-top: 0.55rem;
	max-width: 100%;
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-highlights,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-highlights {
	position: static;
	grid-template-columns: 1fr;
	gap: 0.55rem;
	margin-top: 0.8rem;
	padding: 0.65rem;
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-highlight-item,
.x-pg-preview-frame.size-mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-page-highlight-item {
	gap: 0.45rem;
	padding: 0.55rem 0.7rem;
	font-size: 0.82rem;
	line-height: 1.25;
}
/* ===== 版型：破格（左文右圖、用戶圖可超出方塊） ===== */
.x-pg-layout-bento .x-pg-layout-bento-hero {
	background: transparent;
}
.x-pg-layout-bento .x-pg-layout-bento-hero-container {
	width: 100%;
	overflow: visible;
}
.x-pg-layout-bento .x-pg-layout-bento-hero-inner {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	min-height: 470px;
	margin-top: 0;
	border-radius: var(--x-pg-radius-lg);
	box-shadow: var(--x-pg-shadow-card);
	border: 1px solid rgba(0,0,0,0.08);
	overflow: visible;
	position: relative;
	padding: 2.4rem 2.25rem 2.2rem 2.25rem;
	box-sizing: border-box;
}
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-no-radius {
	border-radius: 0;
}
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-radius-tl,
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-radius-tr,
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-radius-bl,
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-radius-tl {
	border-top-left-radius: var(--x-pg-radius-lg);
}
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-radius-tr {
	border-top-right-radius: var(--x-pg-radius-lg);
}
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-radius-bl {
	border-bottom-left-radius: var(--x-pg-radius-lg);
}
.x-pg-layout-bento .x-pg-layout-bento-hero-inner.x-pg-row-radius-br {
	border-bottom-right-radius: var(--x-pg-radius-lg);
}
.x-pg-layout-bento .x-pg-layout-bento-text {
	position: relative;
	z-index: 3;
	flex: 0 1 78%;
	min-width: 0;
	max-width: 78%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-align: left;
	padding: 0 0 0.75rem 0;
	margin-right: -5.75rem;
}
.x-pg-layout-bento .x-pg-layout-bento-name {
	font-size: clamp(2.6rem, 4.5vw, 4rem);
	font-weight: 700;
	letter-spacing: -0.04em;
	line-height: 1.02;
	margin: 0 0 0.55rem 0;
	max-width: 9ch;
	text-wrap: balance;
	text-shadow: 0 12px 28px rgba(15,23,42,0.12);
}
.x-pg-layout-bento .x-pg-layout-bento-title {
	font-size: 1.2rem;
	margin: 0 0 0.45rem 0;
	opacity: 0.98;
	max-width: 22ch;
}
.x-pg-layout-bento .x-pg-layout-bento-company {
	font-size: 1rem;
	margin-top: 0.35rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	max-width: 24ch;
}
.x-pg-layout-bento .x-pg-layout-bento-highlights {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem 0.9rem;
	margin-top: 1.35rem;
	padding-top: 1.05rem;
	border-top: 1px solid rgba(255,255,255,0.2);
	justify-content: flex-start;
	max-width: min(760px, 100%);
}
.x-pg-layout-bento .x-pg-layout-bento-hero.x-pg-page-header-high-contrast .x-pg-layout-bento-highlights {
	border-top-color: color-mix(in srgb, var(--x-pg-header-text, #2d2d2d) 15%, transparent);
}
.x-pg-layout-bento .x-pg-layout-bento-photo-wrap {
	position: absolute;
	right: -1.25rem;
	top: 3.2rem;
	z-index: 1;
	flex-shrink: 0;
	width: 330px;
	min-width: 330px;
	max-width: 330px;
	overflow: visible;
	display: flex;
	align-items: flex-end;
	justify-content: flex-end;
	margin: 0;
	padding: 0;
}
.x-pg-layout-bento .x-pg-layout-bento-photo-img {
	width: 100%;
	height: auto;
	min-width: 0;
	min-height: 0;
	max-width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
	background: transparent;
	border-radius: 0;
	margin: 0;
	box-shadow: 0 28px 60px rgba(15,23,42,0.18);
}
.x-pg-layout-bento .x-pg-layout-bento-photo-img.x-pg-avatar-shape-rounded,
.x-pg-layout-bento .x-pg-layout-bento-photo-img.x-pg-avatar-shape-circle {
	box-shadow: none;
}
.x-pg-layout-bento .x-pg-layout-bento-photo-placeholder {
	width: 100%;
	height: auto;
	min-width: 0;
	min-height: 0;
	max-width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	background: rgba(255,255,255,0.22);
	border-radius: 1.6rem 1.6rem 1.2rem 1.2rem;
	box-shadow: 0 28px 60px rgba(15,23,42,0.16);
}
.x-pg-layout-bento .x-pg-layout-bento-photo-placeholder svg {
	width: 70px;
	height: 70px;
	opacity: 0.9;
}
.x-pg-layout-bento .x-pg-layout-bento-hero.x-pg-page-header-high-contrast .x-pg-layout-bento-photo-placeholder svg {
	fill: var(--x-pg-header-text, #2d2d2d);
}
@media (max-width: 991px) {
	.x-pg-layout-bento .x-pg-layout-bento-hero-inner {
		min-height: 360px;
		margin-top: 0.5rem;
		padding: 1.05rem 1.15rem 1rem 1.15rem;
		overflow: visible;
	}
	.x-pg-layout-bento .x-pg-layout-bento-text {
		position: relative;
		z-index: 3;
		width: 100%;
		max-width: 100%;
		padding: 8rem 7.4rem 0.3rem 0;
		margin-right: 0;
		text-align: left;
	}
	.x-pg-layout-bento .x-pg-layout-bento-highlights {
		gap: 0.45rem 0.75rem;
		margin-top: 0.85rem;
		padding-top: 0.85rem;
		justify-content: flex-start;
	}
	.x-pg-layout-bento .x-pg-layout-bento-photo-wrap {
		position: absolute;
		top: 2.1rem;
		right: -1rem;
		width: 280px;
		min-width: 280px;
		max-width: 280px;
		min-height: 0;
		align-items: end;
		justify-content: flex-end;
		z-index: 1;
		margin: 0;
		padding: 0;
	}
	.x-pg-layout-bento .x-pg-layout-bento-photo-img {
		margin: 0;
		width: 100%;
		height: auto;
		min-width: 0;
		min-height: 0;
		max-width: 100%;
		border-radius: 0;
		box-shadow: 0 20px 40px rgba(15,23,42,0.16);
	}
	.x-pg-layout-bento .x-pg-layout-bento-photo-img.x-pg-avatar-shape-rounded,
	.x-pg-layout-bento .x-pg-layout-bento-photo-img.x-pg-avatar-shape-circle {
		box-shadow: none;
	}
	.x-pg-layout-bento .x-pg-layout-bento-photo-placeholder {
		margin: 0;
		width: 100%;
		height: auto;
		min-width: 0;
		min-height: 0;
		max-width: 100%;
		border-radius: 1rem 1rem 0.9rem 0.9rem;
		box-shadow: 0 18px 32px rgba(15,23,42,0.12);
	}
}
@media (max-width: 767px) {
	.x-pg-layout-bento .x-pg-layout-bento-hero-inner {
		min-height: 0;
		padding: 0.95rem 0.95rem 1rem 0.95rem;
	}
	.x-pg-page-highlights {
		justify-content: flex-start;
	}
	.x-pg-layout-bento .x-pg-layout-bento-text {
		width: 100%;
		max-width: 100%;
		margin-right: 0;
		padding: 7rem 4.25rem 0.15rem 0;
	}
	.x-pg-layout-bento .x-pg-layout-bento-name {
		font-size: 1.95rem;
		max-width: 8ch;
	}
	.x-pg-layout-bento .x-pg-layout-bento-title {
		font-size: 1.02rem;
	}
	.x-pg-layout-bento .x-pg-layout-bento-photo-wrap {
		top: 5.5rem;
		right: -0.85rem;
		width: 210px;
		min-width: 210px;
		max-width: 210px;
	}
	.x-pg-layout-bento .x-pg-layout-bento-photo-img,
	.x-pg-layout-bento .x-pg-layout-bento-photo-placeholder {
		margin: 0;
		height: auto;
		min-height: 0;
		max-width: 100%;
	}
}
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-hero-inner,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-hero-inner {
	min-height: 0;
	overflow: visible;
}
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-hero-inner {
	min-height: 360px;
	padding: 1.05rem 1.15rem 1rem 1.15rem;
}
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-text,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-text {
	position: relative;
	z-index: 3;
	width: 100%;
	max-width: 100%;
	padding: 8rem 7.4rem 0.3rem 0;
	margin-right: 0;
	text-align: left;
}
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-highlights,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-highlights {
	gap: 0.45rem 0.75rem;
	margin-top: 0.85rem;
	padding-top: 0.85rem;
	justify-content: flex-start;
}
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-photo-wrap,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-photo-wrap {
	position: absolute;
	top: 2.1rem;
	right: -1rem;
	z-index: 1;
	width: 280px;
	min-width: 280px;
	max-width: 280px;
	min-height: 0;
	align-items: end;
	justify-content: flex-end;
	margin: 0;
	padding: 0;
}
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-photo-img,
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-photo-placeholder,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-photo-img,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-photo-placeholder {
	margin: 0;
	width: 100%;
	height: auto;
	min-width: 0;
	min-height: 0;
	border-radius: 0;
}
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-photo-img.x-pg-avatar-shape-rounded,
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-photo-img.x-pg-avatar-shape-circle,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-photo-img.x-pg-avatar-shape-rounded,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-photo-img.x-pg-avatar-shape-circle {
	box-shadow: none;
}
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-photo-img,
.x-pg-preview-frame.tablet .x-pg-layout-bento .x-pg-layout-bento-photo-placeholder {
	max-width: 100%;
}
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-hero-inner {
	min-height: 0;
	
	padding: 0.95rem 0.95rem 1rem 0.95rem;
}
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-text {
	width: 100%;
	max-width: 100%;
	margin-right: 0;
	padding: 4rem 4.25rem 0.15rem 0;
}
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-name {
	font-size: 1.95rem;
	max-width: 8ch;
}
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-title {
	font-size: 1.02rem;
}
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-photo-wrap {
	top: 2.25rem;
	right: -0.85rem;
	width: 210px;
	min-width: 210px;
	max-width: 210px;
}
.x-pg-preview-frame.mobile .x-pg-page-highlights {
	justify-content: flex-start;
}
.x-pg-preview-frame.mobile .x-pg-layout-card-header-wrap .x-pg-page-header-section .x-pg-row {
	gap: 4px;
}
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-photo-img,
.x-pg-preview-frame.mobile .x-pg-layout-bento .x-pg-layout-bento-photo-placeholder {
	margin: 0;
	height: auto;
	min-height: 0;
	max-width: 100%;
}

/* ===== 版型：餐飲（雙色 / 左圖跨區，僅影響 Header） ===== */
.x-pg-layout-editorial .x-pg-page-inner {
	overflow-x: hidden;
}
.x-pg-layout-editorial .x-pg-layout-editorial-masthead {
	padding: var(--x-pg-row-inner-padding) var(--x-pg-inner-padding);
	border-bottom: none;
}
.x-pg-layout-editorial .x-pg-layout-editorial-twotone {
	position: relative;
	border-radius: var(--x-pg-radius-xl);
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(0,0,0,0.10), 0 1px 3px rgba(0,0,0,0.06);
}
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-no-radius {
	border-radius: 0;
}
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-radius-tl,
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-radius-tr,
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-radius-bl,
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-radius-tl {
	border-top-left-radius: var(--x-pg-radius-xl);
}
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-radius-tr {
	border-top-right-radius: var(--x-pg-radius-xl);
}
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-radius-bl {
	border-bottom-left-radius: var(--x-pg-radius-xl);
}
.x-pg-layout-editorial .x-pg-layout-editorial-twotone.x-pg-row-radius-br {
	border-bottom-right-radius: var(--x-pg-radius-xl);
}
.x-pg-layout-editorial .x-pg-layout-editorial-top {
	height: 130px;
	position: relative;
	display: flex;
	align-items: flex-end;
	padding-left: 2rem;
	padding-right: 2rem;
	padding-bottom: 0.5rem;
	box-sizing: border-box;
}
.x-pg-layout-editorial .x-pg-layout-editorial-name-wrap {
	margin-left: calc(130px + var(--x-pg-inner-padding) - 2rem);
	flex: 1;
	min-width: 0;
	position: relative;
	z-index: 1;
}
.x-pg-layout-editorial .x-pg-layout-editorial-top .x-pg-layout-editorial-name {
	color: #ffffff;
	margin: 0;
	font-size: 1.875rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.25;
	text-shadow: 0 1px 3px rgba(0,0,0,0.35), 0 1px 1px rgba(0,0,0,0.2);
}
.x-pg-layout-editorial .x-pg-page-header-high-contrast .x-pg-layout-editorial-top .x-pg-layout-editorial-name {
	color: var(--x-pg-header-text, #2d2d2d);
	text-shadow: 0 1px 2px rgba(255,255,255,0.6), 0 1px 1px rgba(0,0,0,0.08);
}
.x-pg-layout-editorial .x-pg-layout-editorial-top::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	border-radius: inherit;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 520 200'%3E%3Cdefs%3E%3ClinearGradient id='edg1' x1='0%25' y1='0%25' x2='100%25' y2='100%25'%3E%3Cstop offset='0%25' stop-color='%23fff' stop-opacity='0.12'/%3E%3Cstop offset='100%25' stop-color='%23fff' stop-opacity='0'/%3E%3C/linearGradient%3E%3C/defs%3E%3Ccircle cx='60' cy='50' r='100' fill='rgba(255,255,255,0.08)'/%3E%3Ccircle cx='420' cy='80' r='120' fill='rgba(255,255,255,0.06)'/%3E%3Ccircle cx='260' cy='120' r='70' fill='rgba(255,255,255,0.05)'/%3E%3Cpath d='M0 80 Q130 40 260 60 T520 50 L520 200 L0 200 Z' fill='rgba(255,255,255,0.04)'/%3E%3Crect width='100%25' height='100%25' fill='url(%23edg1)'/%3E%3C/svg%3E");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.x-pg-layout-editorial .x-pg-layout-editorial-top::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background: linear-gradient(135deg, rgba(0,0,0,0.18) 0%, transparent 55%);
}
.x-pg-layout-editorial .x-pg-layout-editorial-photo-wrap {
	position: absolute;
	left: 2rem;
	top: 85px;
	z-index: 2;
}
.x-pg-layout-editorial .x-pg-layout-editorial-photo-wrap .x-pg-layout-editorial-photo,
.x-pg-layout-editorial .x-pg-layout-editorial-photo-wrap .x-pg-preview-photo-placeholder {
	width: 100px;
	height: 100px;
	min-width: 100px;
	min-height: 100px;
	max-width: 100px;
	max-height: 100px;
	border-radius: var(--x-pg-radius-xl);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
	background: transparent;
	border: none;
	box-shadow: none;
}
.x-pg-layout-editorial .x-pg-layout-editorial-photo-wrap .x-pg-preview-photo-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
}
.x-pg-layout-editorial .x-pg-layout-editorial-bottom {
	padding: var(--x-pg-inner-padding) var(--x-pg-inner-padding) var(--x-pg-row-inner-padding);
	min-height: 100px;
	/* 覆蓋 JSX inline style（0.5 mix）→ 改為極淡品牌底色，確保深色文字可讀 */
	background: color-mix(in srgb, var(--x-pg-primary) 8%, #ffffff) !important;
	border-top: 2px solid color-mix(in srgb, var(--x-pg-primary) 22%, transparent);
}
.x-pg-layout-editorial .x-pg-layout-editorial-body {
	margin-left: 130px;
	text-align: left;
}
.x-pg-layout-editorial .x-pg-layout-editorial-name {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.25;
	margin: 0 0 0.25rem 0;
	color: #1a1a1a;
}
.x-pg-layout-editorial .x-pg-layout-editorial-byline {
	font-size: 1.125rem;
	color: #0f172a;
	font-weight: 500;
	letter-spacing: -0.01em;
	margin: 0 0 0.5rem 0;
	line-height: 1.4;
	text-shadow: none;
}
.x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top {
	display: none;
}
.x-pg-layout-editorial .x-pg-layout-editorial-byline .x-pg-layout-editorial-company {
	color: #64748b;
}
.x-pg-layout-editorial .x-pg-layout-editorial-byline-separator {
	display: inline;
}
.x-pg-layout-editorial .x-pg-layout-editorial-highlights {
	display: block;
	margin-top: 0.35rem;
	padding-top: 0.5rem;
}
.x-pg-layout-editorial .x-pg-layout-editorial-highlight-item {
	display: inline;
	font-size: 0.9375rem;
	color: #334155;
	font-weight: 450;
	text-shadow: none;
}
.x-pg-layout-editorial .x-pg-layout-editorial-highlight-item:not(:last-child)::after {
	content: " \00b7 ";
	color: var(--x-pg-primary, #94a3b8);
	opacity: 0.7;
}
@media (max-width: 479px) {
	.x-pg-layout-editorial .x-pg-layout-editorial-top {
		flex-wrap: wrap;
		align-content: center;
		padding-top: 0.5rem;
		padding-bottom: 0.5rem;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-name-wrap {
		margin-left: 0;
		width: 100%;
		margin-top: 0.5rem;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-name-wrap .x-pg-layout-editorial-name {
		margin-bottom: 0.35rem;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top {
		display: flex;
		flex-wrap: wrap;
		gap: 0 0.35rem;
		align-items: flex-start;
		margin: 0;
		color: rgba(255, 255, 255, 0.92);
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-title,
	.x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-company {
		display: block;
		font-size: 1rem;
		line-height: 1.4;
		max-width: 100%;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-byline-separator {
		display: none;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-company {
		color: rgba(255, 255, 255, 0.82);
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-body {
		margin-left: 0;
		padding-top: 0.5rem;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-body > .x-pg-layout-editorial-byline {
		display: none;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-photo-wrap {
		position: static;
		margin-bottom: 0;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-bottom {
		padding-top: 1.25rem;
	}
}

/* 頁面模擬使用 .x-pg-preview-frame 的裝置 class，不一定會命中 viewport media query。
   這裡同步 editorial header/body 的左側位移，避免 name-wrap 與 body 在模擬尺寸下不一致。 */
.x-pg-preview-frame.desktop .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap,
.x-pg-preview-frame.tablet .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap,
.x-pg-preview-frame.size-desktop .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap,
.x-pg-preview-frame.size-tablet .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap {
	margin-left: calc(130px + var(--x-pg-inner-padding) - 2rem);
}

.x-pg-preview-frame.desktop .x-pg-layout-editorial .x-pg-layout-editorial-body,
.x-pg-preview-frame.tablet .x-pg-layout-editorial .x-pg-layout-editorial-body,
.x-pg-preview-frame.size-desktop .x-pg-layout-editorial .x-pg-layout-editorial-body,
.x-pg-preview-frame.size-tablet .x-pg-layout-editorial .x-pg-layout-editorial-body {
	margin-left: 130px;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap,
.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-body,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-body {
	margin-left: 0;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap {
	width: 100%;
	margin-top: 0.5rem;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap .x-pg-layout-editorial-name,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-name-wrap .x-pg-layout-editorial-name {
	margin-bottom: 0.35rem;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top {
	display: flex;
	flex-wrap: wrap;
	gap: 0 0.35rem;
	align-items: flex-start;
	margin: 0;
	color: rgba(255, 255, 255, 0.92);
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-title,
.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-company,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-title,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-company {
	display: block;
	font-size: 1rem;
	line-height: 1.4;
	max-width: 100%;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-byline-separator,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-byline-separator {
	display: none;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-company,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-byline-mobile-top .x-pg-layout-editorial-company {
	color: rgba(255, 255, 255, 0.82);
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-body,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-body {
	padding-top: 0.5rem;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-body > .x-pg-layout-editorial-byline,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-body > .x-pg-layout-editorial-byline {
	display: none;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-top,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-top {
	flex-wrap: wrap;
	align-content: center;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-photo-wrap,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-photo-wrap {
	position: static;
	margin-bottom: 0;
}

.x-pg-preview-frame.mobile .x-pg-layout-editorial .x-pg-layout-editorial-bottom,
.x-pg-preview-frame.size-mobile .x-pg-layout-editorial .x-pg-layout-editorial-bottom {
	padding-top: 1.25rem;
}

/* byline 手機/平板兩行：隱藏 " · " 文字節點，職稱/公司各占一行 */
@media (max-width: 767px) {
	.x-pg-layout-editorial .x-pg-layout-editorial-byline {
		font-size: 0;
		line-height: 0;
	}
	.x-pg-layout-editorial .x-pg-layout-editorial-byline .x-pg-layout-editorial-title,
	.x-pg-layout-editorial .x-pg-layout-editorial-byline .x-pg-layout-editorial-company {
		display: block;
		font-size: 1.0625rem;
		line-height: 1.4;
	}
}

/* ===== 版型：教育（圓潤 / 友善） ===== */
.x-pg-layout-education .x-pg-layout-education-header {
	padding: 2.5rem var(--x-pg-inner-padding);
}
.x-pg-layout-education .x-pg-layout-education-inner {
	max-width: 36rem;
	margin: 0 auto;
	padding: 2rem var(--x-pg-inner-padding);
	border-radius: var(--x-pg-radius-xl);
	box-shadow: var(--x-pg-shadow-card);
}
.x-pg-layout-education .x-pg-layout-education-photo {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	margin: 0 auto var(--x-pg-row-inner-padding);
	border: 3px solid rgba(255,255,255,0.4);
	box-shadow: var(--x-pg-shadow-lg);
}
.x-pg-layout-education .x-pg-layout-education-heading {
	text-align: center;
}
.x-pg-layout-education .x-pg-layout-education-name {
	font-size: 1.875rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin: 0 0 0.35rem 0;
	line-height: 1.2;
}
.x-pg-layout-education .x-pg-layout-education-title {
	font-size: 1.0625rem;
	opacity: 0.92;
	margin: 0;
}
.x-pg-layout-education .x-pg-layout-education-company {
	margin: 0.5rem 0 0 0;
	font-size: 0.9375rem;
	opacity: 0.9;
}
.x-pg-layout-education .x-pg-layout-education-highlights {
	margin-top: 1rem;
	text-align: left;
}

/* ===== 圓潤版型：頁首區塊為圓潤個人卡片 (僅 education 版型)，方塊顏色與主題一致 ===== */
.x-pg-layout-education .x-pg-page-header-section .profile-card {
	position: relative;
	border-radius: 24px;
	padding: 18px 18px 22px;
	box-shadow: var(--x-pg-shadow-card);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	overflow: hidden;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-no-radius {
	border-radius: 0;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tl,
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tr,
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-bl,
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tl {
	border-top-left-radius: 24px;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tr {
	border-top-right-radius: 24px;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-bl {
	border-bottom-left-radius: 24px;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-br {
	border-bottom-right-radius: 24px;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card::before {
	content: "";
	position: absolute;
	inset: 24px 24px auto auto;
	width: 180px;
	height: 180px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0) 72%);
	pointer-events: none;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: min(92%, 920px);
	height: 1px;
	transform: translate(-50%, -50%);
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(15, 23, 42, 0.12) 20%, rgba(15, 23, 42, 0.12) 80%, rgba(255, 255, 255, 0) 100%);
	pointer-events: none;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__main {
	display: grid;
	grid-template-columns: minmax(280px, 280px) minmax(280px, 460px);
	align-items: center;
	gap: 0;
	justify-content: center;
	justify-items: start;
	width: fit-content;
	max-width: 100%;
	margin: 0 auto;
	position: relative;
	z-index: 1;
	transform: translateX(32px);
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__image-wrapper {
	width: 100%;
	border-radius: 0;
	overflow: visible;
	background: transparent;
	position: relative;
	z-index: 1;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__image {
	width: 100%;
	height: clamp(220px, 28vw, 360px);
	max-width: 360px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
	vertical-align: middle;
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.06));
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__image-placeholder {
	height: clamp(220px, 28vw, 360px);
	max-width: 360px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.15);
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__image .x-pg-avatar-media,
.x-pg-layout-education .x-pg-page-header-section .profile-card__image-placeholder .x-pg-avatar-media {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__image-placeholder svg {
	width: 96px;
	height: 96px;
	opacity: 0.6;
	fill: var(--x-pg-edu-card-text, #fff);
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__content {
	display: flex;
	flex-direction: column;
	gap: 12px;
	min-width: 0;
	position: relative;
	z-index: 2;
	align-items: flex-start;
	width: fit-content;
	max-width: min(100%, 460px);
	margin-left: -64px;
	padding: 10px 0 0;
	background: transparent;
	box-shadow: none;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__name-row {
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	width: 100%;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__name {
	font-size: clamp(1.9rem, 3.8vw, 3rem);
	font-weight: 700;
	color: var(--x-pg-text, #1e293b);
	line-height: 1.05;
	letter-spacing: -0.04em;
	margin: 0;
	text-wrap: balance;
	display: inline-block;
	padding: 0.18em 0.42em 0.22em;
	background: color-mix(in srgb, var(--x-pg-primary, #2563eb) 12%, white);
	box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
	transform: none;
	border-radius: 0;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__title {
	font-size: 1rem;
	line-height: 1.5;
	color: var(--x-pg-text, #1e293b);
	margin: 0;
	font-weight: 500;
	max-width: 32ch;
	display: inline-block;
	width: fit-content;
	padding: 0.35rem 0.8rem;
	background: color-mix(in srgb, var(--x-pg-primary, #2563eb) 8%, white);
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
	border-radius: 0;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__company {
	font-size: 0.9375em;
	line-height: 1.4;
	color: var(--x-pg-text-muted, #64748b);
	margin: 0;
	display: inline-block;
	width: fit-content;
	padding: 0.32rem 0.75rem;
	background: color-mix(in srgb, var(--x-pg-primary, #2563eb) 5%, white);
	box-shadow: 0 8px 18px rgba(15, 23, 42, 0.07);
	border-radius: 0;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__highlights {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px solid rgba(15, 23, 42, 0.08);
	width: fit-content;
	max-width: 100%;
	position: relative;
	z-index: 1;
	margin-left: 0;
	margin-right: 0;
	padding-left: 0;
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__highlight-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.8125rem;
	line-height: 1.35;
	color: var(--x-pg-text, #1e293b);
	background: color-mix(in srgb, var(--x-pg-primary, #2563eb) 10%, white);
	padding: 6px 16px;
	border-radius: 0;
	white-space: normal;
	width: auto;
	max-width: 100%;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
	clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
}
.x-pg-layout-education .x-pg-page-header-section .profile-card__highlight-item i {
	opacity: 0.95;
	color: var(--x-pg-primary, #2563eb);
	font-size: 0.75em;
	flex-shrink: 0;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card {
	padding: 12px 12px 16px;
	border-radius: 20px;
	gap: 10px;
	align-items: stretch;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tl,
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tr,
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-bl,
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-br,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tl,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tr,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-bl,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-br {
	border-radius: 0;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tl,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tl {
	border-top-left-radius: 20px;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tr,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tr {
	border-top-right-radius: 20px;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-bl,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-bl {
	border-bottom-left-radius: 20px;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-br,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-br {
	border-bottom-right-radius: 20px;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card::before,
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card::after,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card::before,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card::after {
	display: none;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__main,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__main {
	grid-template-columns: 1fr;
	gap: 12px;
	width: 100%;
	max-width: none;
	transform: none;
	position: relative;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__image-wrapper,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__image-wrapper {
	position: static;
	width: 100%;
	transform: none;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__image,
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__image-placeholder,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__image,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__image-placeholder {
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
	max-width: min(100%, 320px);
	margin: 0;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__content,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__content {
	padding-top: 0;
	gap: 10px;
	margin-left: 10px;
	margin-top: -140px;
	width: 100%;
	max-width: none;
	padding: 0;
	background: transparent;
	box-shadow: none;
	position: relative;
	z-index: 2;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__name,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__name {
	font-size: 1.5rem;
	line-height: 1.08;
	transform: none;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__title,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__title {
	font-size: 0.875rem;
	line-height: 1.45;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__highlights,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__highlights {
	gap: 10px;
	align-items: flex-start;
	margin-top: 8px;
}
.x-pg-preview-frame.mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__highlight-item,
.x-pg-preview-frame.size-mobile .x-pg-layout-education .x-pg-page-header-section .profile-card__highlight-item {
	white-space: normal;
	padding: 5px 10px;
	font-size: 0.75rem;
}
@media (max-width: 767px) {
	.x-pg-layout-education .x-pg-page-header-section .profile-card {
		padding: 12px 12px 16px;
		border-radius: 20px;
		gap: 10px;
		align-items: stretch;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tl,
	.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tr,
	.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-bl,
	.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-br {
		border-radius: 0;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tl {
		border-top-left-radius: 20px;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-tr {
		border-top-right-radius: 20px;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-bl {
		border-bottom-left-radius: 20px;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card.x-pg-row-radius-br {
		border-bottom-right-radius: 20px;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card::before,
	.x-pg-layout-education .x-pg-page-header-section .profile-card::after {
		display: none;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__main {
		grid-template-columns: 1fr;
		gap: 12px;
		width: 100%;
		max-width: none;
		transform: none;
		position: relative;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__image-wrapper {
		border-radius: 14px;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__image,
	.x-pg-layout-education .x-pg-page-header-section .profile-card__image-placeholder {
		height: auto;
		aspect-ratio: 1 / 1;
		max-width: min(100%, 320px);
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__name {
		font-size: 1.5rem;
		transform: none;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__title {
		font-size: 0.875rem;
		margin-left: 0;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__content {
		margin-left: 10px;
		margin-top: -140px;
		width: 100%;
		max-width: none;
		padding: 0;
		background: transparent;
		box-shadow: none;
		position: relative;
		z-index: 2;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__company {
		margin-left: 0;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__highlights {
		padding-top: 10px;
		align-items: flex-start;
	}
	.x-pg-layout-education .x-pg-page-header-section .profile-card__highlight-item {
		padding: 5px 10px;
		font-size: 0.75rem;
	}
}
/* 版權區塊：無邊界、無方塊樣式，僅區塊底色；底色填滿全寬，內容最大 800px */
.x-pg-copyright-section {
	margin: 0;
	padding: 0;
	border: none;
	box-shadow: none;
	border-radius: 0;
}
.x-pg-copyright-row {
	width: 100%;
	box-sizing: border-box;
}
.x-pg-copyright-inner {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	padding-left: var(--x-pg-inner-padding, 1rem);
	padding-right: var(--x-pg-inner-padding, 1rem);
	box-sizing: border-box;
}
.x-pg-copyright-section a {
	color: inherit;
}

/* 科技巨頭風格頁尾（連結列 + 品牌/社群 + 客服） */
.x-pg-footer {
	--x-pg-footer-bg: #1d1d1f;
	--x-pg-footer-text: #86868b;
	--x-pg-footer-link: #86868b;
	--x-pg-footer-link-hover: #fff;
	--x-pg-footer-border: rgba(255, 255, 255, 0.1);
	background-color: var(--x-pg-footer-bg);
	color: var(--x-pg-footer-text);
	padding: 2.5rem 1.5rem 1.5rem;
	font-size: 0.9rem;
}
.x-pg-footer-inner {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--x-pg-inner-padding, 1rem);
	padding-right: var(--x-pg-inner-padding, 1rem);
	box-sizing: border-box;
}
.x-pg-footer-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 0.5rem 0.75rem;
	margin-bottom: 2rem;
}
.x-pg-footer-link {
	color: var(--x-pg-footer-link);
	text-decoration: none;
	transition: color 0.2s ease;
}
.x-pg-footer-link:hover {
	color: var(--x-pg-footer-link-hover);
}
.x-pg-footer-links-sep {
	color: var(--x-pg-footer-text);
	opacity: 0.6;
	user-select: none;
}
.x-pg-footer-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem 3rem;
	align-items: start;
}
.x-pg-footer-grid--brand-only {
	grid-template-columns: 1fr;
	justify-items: center;
}
.x-pg-footer-grid--brand-only .x-pg-footer-brand-block {
	text-align: center;
	max-width: 100%;
}
.x-pg-footer-grid--brand-only .x-pg-footer-logo {
	margin-left: auto;
	margin-right: auto;
}
.x-pg-footer-grid--brand-only .x-pg-footer-story {
	margin-left: auto;
	margin-right: auto;
}
@media (max-width: 768px) {
	.x-pg-footer-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}
}
.x-pg-footer-col {
	min-width: 0;
}
.x-pg-footer-brand-block {
	margin-bottom: 1rem;
}
.x-pg-footer-logo {
	width: 120px;
	height: 0;
	padding-bottom: 40px;
	position: relative;
	margin-bottom: 0.75rem;
}
.x-pg-footer-logo img {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: left;
}
.x-pg-footer-company-name {
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--x-pg-footer-link-hover);
	margin: 0 0 0.5rem;
	line-height: 1.3;
}

.x-pg-collapse-header .form-check.form-switch .form-check-input {
	width: 2.5rem;
	height: 1.25rem;
}

.x-pg-floating-actions {
	position: fixed;
	right: 1.5rem;
	bottom: 1.5rem;
	z-index: 50;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	pointer-events: none;
	align-items: flex-end;
}
.x-pg-floating-actions__btn {
	width: 3.25rem;
	height: 3.25rem;
	border-radius: 999px;
	border: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(17, 17, 17, 0.92);
	color: #fff;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.35);
	cursor: pointer;
	transition: background-color 0.18s ease, box-shadow 0.18s ease, transform 0.12s ease;
	pointer-events: auto;
}
.x-pg-floating-actions__btn i {
	font-size: 1.25rem;
}
.x-pg-floating-actions__btn:hover {
	background: #000;
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.45);
	transform: translateY(-1px);
}
.x-pg-floating-actions__btn:active {
	transform: translateY(0);
	box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35);
}
.x-pg-floating-actions__btn--primary {
	background: var(--x-pg-primary, #2563eb);
}
.x-pg-floating-actions__btn--primary:hover {
	background: var(--x-pg-primary-strong, #1d4ed8);
}
.x-pg-floating-actions__btn--soft {
	background: rgba(17, 17, 17, 0.78);
	backdrop-filter: blur(12px);
}
@media (max-width: 1024px) {
	.x-pg-floating-actions {
		right: 1rem;
		bottom: 1rem;
		gap: 0.5rem;
	}
	.x-pg-floating-actions__btn {
		width: 2.5rem;
		height: 2.5rem;
	}
	.x-pg-floating-actions__btn i {
		font-size: 1rem;
	}
}
@media (max-width: 768px) {
	.x-pg-floating-actions {
		right: 0.75rem;
		bottom: 0.75rem;
		gap: 0.4rem;
	}
	.x-pg-floating-actions__btn {
		width: 2.1rem;
		height: 2.1rem;
	}
	.x-pg-floating-actions__btn i {
		font-size: 0.875rem;
	}
}
/* 編輯器預覽模擬：平板 */
.x-pg-preview-frame.tablet .x-pg-floating-actions,
.x-pg-preview-frame.size-tablet .x-pg-floating-actions {
	right: 1rem;
	bottom: 1rem;
	gap: 0.5rem;
}
.x-pg-preview-frame.tablet .x-pg-floating-actions__btn,
.x-pg-preview-frame.size-tablet .x-pg-floating-actions__btn {
	width: 2.5rem;
	height: 2.5rem;
}
.x-pg-preview-frame.tablet .x-pg-floating-actions__btn i,
.x-pg-preview-frame.size-tablet .x-pg-floating-actions__btn i {
	font-size: 1rem;
}
/* 編輯器預覽模擬：手機 */
.x-pg-preview-frame.mobile .x-pg-floating-actions,
.x-pg-preview-frame.size-mobile .x-pg-floating-actions {
	right: 0.75rem;
	bottom: 0.75rem;
	gap: 0.4rem;
}
.x-pg-preview-frame.mobile .x-pg-floating-actions__btn,
.x-pg-preview-frame.size-mobile .x-pg-floating-actions__btn {
	width: 2.1rem;
	height: 2.1rem;
}
.x-pg-preview-frame.mobile .x-pg-floating-actions__btn i,
.x-pg-preview-frame.size-mobile .x-pg-floating-actions__btn i {
	font-size: 0.875rem;
}
.x-pg-floating-actions__popup {
	position: absolute;
	right: 3.75rem;
	bottom: 0;
	transform: translateY(-0.5rem);
	background: #fff;
	border-radius: 1rem;
	padding: 1.25rem 1.5rem 1.25rem;
	width: 320px;
	max-width: calc(100vw - 3rem);
	box-shadow: 0 18px 45px rgba(0, 0, 0, 0.24);
	pointer-events: auto;
}
.x-pg-floating-actions__title {
	font-size: 1.1rem;
	margin: 0 0 1.25rem;
	font-weight: 600;
	color: #111827;
}
.x-pg-floating-actions__qr-wrap {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.25rem;
}
.x-pg-floating-actions__qr-wrap img {
	width: 220px;
	height: 220px;
	object-fit: contain;
	border-radius: 0.75rem;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.16);
}
.x-pg-floating-actions__qr-placeholder {
	width: 220px;
	height: 220px;
	border-radius: 0.75rem;
	background: repeating-linear-gradient(45deg, #f3f4f6, #f3f4f6 6px, #e5e7eb 6px, #e5e7eb 12px);
}
.x-pg-floating-actions__qr-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.75rem;
	background: rgba(255, 255, 255, 0.45);
	backdrop-filter: blur(2px);
	pointer-events: none;
	overflow: hidden;
}
.x-pg-floating-actions__popup--sample .x-pg-floating-actions__qr-overlay {
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.16)),
		repeating-linear-gradient(
			-45deg,
			rgba(17, 24, 39, 0.1) 0,
			rgba(17, 24, 39, 0.1) 8px,
			rgba(255, 255, 255, 0) 8px,
			rgba(255, 255, 255, 0) 18px
		);
	backdrop-filter: blur(1.5px);
}
.x-pg-floating-actions__popup--sample .x-pg-floating-actions__qr-overlay::before,
.x-pg-floating-actions__popup--sample .x-pg-floating-actions__qr-overlay::after {
	content: "";
	position: absolute;
	pointer-events: none;
}
.x-pg-floating-actions__popup--sample .x-pg-floating-actions__qr-overlay::before {
	left: 50%;
	top: 50%;
	width: 68%;
	height: 2.1rem;
	transform: translate(-50%, -50%) rotate(-10deg);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.72);
	box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.12);
}
.x-pg-floating-actions__popup--sample .x-pg-floating-actions__qr-overlay::after {
	inset: 0.8rem;
	border-radius: 0.55rem;
	border: 2px solid rgba(255, 255, 255, 0.16);
}
.x-pg-floating-actions__qr-overlay span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.4rem 0.9rem;
	border-radius: 999px;
	background: rgba(17, 24, 39, 0.88);
	color: #fff;
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}
.x-pg-floating-actions__popup--sample .x-pg-floating-actions__qr-overlay span {
	position: relative;
	z-index: 1;
}
.x-pg-floating-actions__url-block {
	position: relative;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	background: #f3f4f6;
	border-radius: 999px;
	padding: 0.35rem 0.5rem 0.35rem 0.9rem;
}
.x-pg-floating-actions__url-block--disabled .x-pg-floating-actions__copy-btn {
	cursor: not-allowed;
	opacity: 0.6;
}
.x-pg-floating-actions__url-overlay {
	position: absolute;
	inset: 0;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.02);
	cursor: not-allowed;
}
.x-pg-floating-actions__url-text {
	flex: 1 1 auto;
	min-width: 0;
	font-size: 0.8rem;
	color: #374151;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.x-pg-floating-actions__copy-btn {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	border-radius: 999px;
	border: none;
	background: #111827;
	color: #fff;
	font-size: 0.78rem;
	padding: 0.35rem 0.7rem;
	cursor: pointer;
	transition: background-color 0.16s ease, box-shadow 0.16s ease;
}
.x-pg-floating-actions__copy-btn i {
	font-size: 0.9rem;
}
.x-pg-floating-actions__copy-btn:hover {
	background: #000;
	box-shadow: 0 6px 14px rgba(0, 0, 0, 0.28);
}
.x-pg-floating-actions__copy-btn:active {
	box-shadow: 0 3px 8px rgba(0, 0, 0, 0.24);
}
.x-pg-floating-actions__copy-btn:disabled {
	background: #111827;
	box-shadow: none;
}
.x-pg-floating-actions__copy-btn:disabled:hover {
	background: #111827;
	box-shadow: none;
}
.x-pg-floating-actions__close {
	position: absolute;
	right: 0.9rem;
	top: 0.9rem;
	border: none;
	background: transparent;
	color: #4b5563;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: 999px;
	transition: background-color 0.16s ease, color 0.16s ease;
}
.x-pg-floating-actions__close:hover {
	background: #f3f4f6;
	color: #111827;
}
.x-pg-footer-story {
	margin: 0;
	line-height: 1.6;
	max-width: 360px;
	color: var(--x-pg-footer-text);
}
.x-pg-footer-social {
	margin-top: 1rem;
}
.x-pg-footer .x-pg-footer-social.x-pg-page-social-links-row {
	justify-content: flex-start;
}
.x-pg-footer .x-pg-page-social-link.x-pg-footer-social-link {
	color: var(--x-pg-footer-link);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	padding: 0.5em;
	width: auto;
	height: auto;
	border-radius: 0;
	background: transparent !important;
	box-shadow: none !important;
	border: none !important;
	transition: color 0.2s ease;
}
.x-pg-footer .x-pg-page-social-link.x-pg-footer-social-link:hover {
	color: var(--x-pg-footer-link-hover);
	transform: none;
	background: transparent !important;
	box-shadow: none !important;
}
.x-pg-footer .x-pg-page-social-link.x-pg-footer-social-link i,
.x-pg-footer .x-pg-page-social-link.x-pg-footer-social-link span {
	color: inherit !important;
	font-size: 1em;
}
.x-pg-footer-cs-title {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--x-pg-footer-link-hover);
	margin: 0 0 1rem;
}
.x-pg-footer-cs-item {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
	border-top: 1px solid var(--x-pg-footer-border);
	padding-top: 0.75rem;
}
.x-pg-footer-cs-item:first-of-type {
	border-top: none;
	padding-top: 0;
}
.x-pg-footer-cs-label {
	flex-shrink: 0;
	color: var(--x-pg-footer-text);
	opacity: 0.9;
	font-size: 0.85rem;
}
.x-pg-footer-cs-value {
	flex: 1;
	min-width: 0;
	word-break: break-word;
}
.x-pg-footer-cs-value a {
	color: var(--x-pg-footer-link);
	text-decoration: none;
	transition: color 0.2s ease;
}
.x-pg-footer-cs-value a:hover {
	color: var(--x-pg-footer-link-hover);
}
/* ===== Portfolio Edit Modal ===== */
.x-pg-pmedit-overlay {
	position: fixed;
	inset: 0;
	z-index: 1050;
	background: rgba(15, 23, 42, 0.45);
	backdrop-filter: blur(2px);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1.5rem;
}
.x-pg-pmedit-dialog {
	background: var(--x-pg-surface, #fff);
	border-radius: var(--x-pg-radius-lg, 16px);
	box-shadow: var(--x-pg-shadow-lg, 0 10px 32px -4px rgba(15,23,42,0.12));
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 980px;
	max-height: 88vh;
	overflow: hidden;
	border: 1px solid var(--x-pg-border, #e8ecf1);
}
.x-pg-pmedit-dialog--portfolio {
	max-width: 890px;
	height: min(60vh, 760px);
	max-height: 60vh;
}
.x-pg-pmedit-dialog--experience {
	max-width: 720px;
	max-height: 64vh;
}

/* Header */
.x-pg-pmedit-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 1rem;
	height: 48px;
	min-height: 48px;
	border-bottom: 1px solid var(--x-pg-border, #e8ecf1);
	background: #f8fafc;
	gap: 0.75rem;
}
.x-pg-pmedit-header-left {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	overflow: hidden;
	min-width: 0;
}
.x-pg-pmedit-header-breadcrumb {
	font-size: 0.8rem;
	color: var(--x-pg-text-muted, #64748b);
	white-space: nowrap;
	flex-shrink: 0;
}
.x-pg-pmedit-header-sep {
	font-size: 0.65rem;
	color: #cbd5e1;
	flex-shrink: 0;
}
.x-pg-pmedit-header-title {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--x-pg-text, #1e293b);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.x-pg-pmedit-header-right {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-shrink: 0;
}
.x-pg-pmedit-nav {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	background: #f1f5f9;
	border: 1px solid var(--x-pg-border, #e8ecf1);
	border-radius: 8px;
	padding: 2px;
}
.x-pg-pmedit-nav-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	border: none;
	background: transparent;
	border-radius: 6px;
	color: var(--x-pg-text-muted, #64748b);
	cursor: pointer;
	transition: background 0.15s, color 0.15s;
	font-size: 0.75rem;
}
.x-pg-pmedit-nav-btn:hover:not(:disabled) {
	background: #fff;
	color: var(--x-pg-text, #1e293b);
}
.x-pg-pmedit-nav-btn:disabled {
	opacity: 0.35;
	cursor: not-allowed;
}
.x-pg-pmedit-nav-count {
	font-size: 0.7rem;
	color: var(--x-pg-text-muted, #64748b);
	font-weight: 500;
	padding: 0 0.25rem;
	min-width: 36px;
	text-align: center;
}
.x-pg-pmedit-header-divider {
	width: 1px;
	height: 20px;
	background: var(--x-pg-border, #e8ecf1);
	margin: 0 0.1rem;
}
.x-pg-pmedit-close-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	border: none;
	background: transparent;
	border-radius: 8px;
	color: var(--x-pg-text-muted, #64748b);
	cursor: pointer;
	font-size: 0.8rem;
	transition: background 0.15s, color 0.15s;
}
.x-pg-pmedit-close-btn:hover {
	background: #fee2e2;
	color: #dc2626;
}

/* Body: two-column layout */
.x-pg-pmedit-body {
	display: flex;
	flex: 1;
	min-height: 0;
	overflow: hidden;
}

/* Left panel */
.x-pg-pmedit-left {
	width: 300px;
	min-width: 300px;
	max-width: 300px;
	display: flex;
	flex-direction: column;
	gap: 0;
	overflow-y: auto;
	padding: 1.125rem 1rem 1rem;
	border-right: 1px solid var(--x-pg-border, #e8ecf1);
	background: #fff;
}
.x-pg-pmedit-field {
	margin-bottom: 1rem;
}
.x-pg-pmedit-field:last-child {
	margin-bottom: 0;
}
.x-pg-pmedit-label {
	display: block;
	font-size: 0.775rem;
	font-weight: 600;
	color: var(--x-pg-text-muted, #64748b);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 0.375rem;
}
.x-pg-pmedit-left textarea {
	min-height: calc(3 * 1.5em + 1rem);
}
.x-pg-pmedit-left .form-control,
.x-pg-pmedit-left input,
.x-pg-pmedit-left textarea {
	background: #fff;
	border-color: var(--x-pg-border, #e8ecf1);
	border-radius: var(--x-pg-radius-sm, 8px);
	font-size: 0.8125rem;
}
.x-pg-pmedit-left .form-control:focus,
.x-pg-pmedit-left input:focus,
.x-pg-pmedit-left textarea:focus {
	border-color: var(--x-pg-edit-accent, #434f84);
	box-shadow: 0 0 0 3px rgba(67, 79, 132, 0.12);
}
/* Add button in header */
.x-pg-pmedit-add-header-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	border: none;
	background: transparent;
	border-radius: 8px;
	color: var(--x-pg-text-muted, #64748b);
	cursor: pointer;
	font-size: 0.85rem;
	transition: background 0.15s, color 0.15s;
}
.x-pg-pmedit-add-header-btn:hover {
	background: #dcfce7;
	color: #16a34a;
}

/* Delete button in header (red) */
.x-pg-pmedit-delete-header-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	border: none;
	background: transparent;
	border-radius: 8px;
	color: #f87171;
	cursor: pointer;
	font-size: 0.8rem;
	transition: background 0.15s, color 0.15s;
}
.x-pg-pmedit-delete-header-btn:hover {
	background: #fee2e2;
	color: #dc2626;
}

/* Right panel */
.x-pg-pmedit-right {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: #fff;
}

/* Action type section (top of right panel) */
.x-pg-pmedit-action-section {
	padding: 1rem 1.125rem 0.875rem;
	border-bottom: 1px solid var(--x-pg-border, #e8ecf1);
}
.x-pg-pmedit-action-label {
	font-size: 0.775rem;
	font-weight: 600;
	color: var(--x-pg-text-muted, #64748b);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 0.6rem;
}

/* URL input section */
.x-pg-pmedit-url-section {
	padding: 1rem 1.125rem;
}
.x-pg-pmedit-url-section .form-control {
	background: #f8fafc;
	border-color: var(--x-pg-border, #e8ecf1);
	border-radius: var(--x-pg-radius-sm, 8px);
	font-size: 0.8125rem;
}
.x-pg-pmedit-url-section .form-control:focus {
	border-color: var(--x-pg-edit-accent, #434f84);
	box-shadow: 0 0 0 3px rgba(67, 79, 132, 0.12);
	background: #fff;
}

/* Editor section */
.x-pg-pmedit-editor-section {
	flex: 1;
	min-height: 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}
.x-pg-pmedit-editor-header {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	padding: 0.6rem 1.125rem;
	font-size: 0.775rem;
	font-weight: 600;
	color: var(--x-pg-text-muted, #64748b);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	border-bottom: 1px solid var(--x-pg-border, #e8ecf1);
	min-height: 38px;
	background: #f8fafc;
}
.x-pg-pmedit-editor-wrap {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	padding: 0.75rem 1rem 1rem;
}

/* Portfolio card grid in editor */
.x-pg-portfolio-card-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
	gap: 0.5rem;
	margin-top: 0.5rem;
	margin-bottom: 1rem;
}
.x-pg-portfolio-card {
	border: 1px solid var(--bs-border-color, #dee2e6);
	border-radius: 0.375rem;
	overflow: hidden;
	cursor: pointer;
	background: #fff;
	transition: border-color 0.15s, box-shadow 0.15s;
}
.x-pg-portfolio-card:hover {
	border-color: var(--bs-primary);
	box-shadow: 0 0 0 2px rgba(99,102,241,0.15);
}
.x-pg-portfolio-card-thumb {
	width: 100%;
	aspect-ratio: 4/3;
	background: #f1f5f9;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.x-pg-portfolio-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.x-pg-portfolio-card-no-img {
	color: #94a3b8;
	font-size: 1.5rem;
}
.x-pg-portfolio-card-label {
	padding: 0.3rem 0.4rem;
	font-size: 0.72rem;
	font-weight: 500;
	color: #334155;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.25rem;
}
.x-pg-portfolio-card-label span {
	overflow: hidden;
	text-overflow: ellipsis;
	flex: 1;
}
.x-pg-portfolio-card-edit-icon {
	font-size: 0.65rem;
	color: #94a3b8;
	flex-shrink: 0;
	opacity: 0;
	transition: opacity 0.15s;
}
.x-pg-portfolio-card:hover .x-pg-portfolio-card-edit-icon {
	opacity: 1;
}

/* Portfolio sortable list in editor */
.x-pg-portfolio-sort-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-top: 0.5rem;
	margin-bottom: 1rem;
}
.x-pg-portfolio-sort-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 7px 10px;
	background: #fff;
	border: 1px solid var(--bs-border-color, #dee2e6);
	border-radius: 8px;
	cursor: default;
	transition: box-shadow 0.15s, border-color 0.15s, opacity 0.15s;
	user-select: none;
}
.x-pg-portfolio-sort-item:hover {
	box-shadow: 0 2px 8px rgba(0,0,0,0.07);
}
.x-pg-portfolio-sort-actions {
	display: flex;
	align-items: center;
	gap: 2px;
	flex-shrink: 0;
}
.x-pg-portfolio-sort-move-btn {
	background: none;
	border: none;
	cursor: pointer;
	padding: 4px 6px;
	border-radius: 4px;
	line-height: 1;
	transition: background 0.15s;
}
.x-pg-portfolio-sort-move-btn:disabled {
	opacity: 0.2;
	cursor: default;
}
.x-pg-portfolio-sort-move-btn:not(:disabled):hover {
	background: #e8edf2;
}
.x-pg-portfolio-sort-move-btn i,
.x-pg-portfolio-sort-move-btn .bi {
	color: #6b7280 !important;
	font-size: 13px;
}
.x-pg-portfolio-sort-thumb {
	width: 38px;
	height: 38px;
	border-radius: 5px;
	background: #f1f5f9;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	color: #94a3b8;
	font-size: 1rem;
}
.x-pg-portfolio-sort-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.x-pg-portfolio-sort-title {
	flex: 1;
	font-size: 13px;
	font-weight: 500;
	color: #374151;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.x-pg-portfolio-sort-edit-btn,
.x-pg-portfolio-sort-delete-btn {
	flex-shrink: 0;
	background: none;
	border: none;
	cursor: pointer;
	padding: 5px 8px;
	border-radius: 5px;
	font-size: 13px;
	line-height: 1;
	transition: background 0.15s, color 0.15s;
}
.x-pg-portfolio-sort-edit-btn i,
.x-pg-portfolio-sort-edit-btn .bi,
.x-pg-portfolio-sort-delete-btn i,
.x-pg-portfolio-sort-delete-btn .bi {
	color: #8fa3b8 !important;
	transition: color 0.15s;
}
.x-pg-portfolio-sort-edit-btn:hover {
	background: #f1f5f9;
}
.x-pg-portfolio-sort-edit-btn:hover i,
.x-pg-portfolio-sort-edit-btn:hover .bi {
	color: #374151 !important;
}
.x-pg-portfolio-sort-delete-btn:hover {
	background: #fee2e2;
}
.x-pg-portfolio-sort-delete-btn:hover i,
.x-pg-portfolio-sort-delete-btn:hover .bi {
	color: #dc2626 !important;
}

#fixed-right-side-div,.is-ui{
	display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════
   Editor Modal — Premium Redesign (x-pg-editor-modal)
   Inspired by Linear / Vercel / Figma — clean, minimal, refined
   ═══════════════════════════════════════════════════════════════════ */

/* Backdrop */
.x-pg-editor-modal {
	backdrop-filter: blur(6px) saturate(1.4);
	-webkit-backdrop-filter: blur(6px) saturate(1.4);
	background: rgba(2, 8, 23, 0.48) !important;
}

/* Dialog entrance animation */
.x-pg-editor-modal .modal-dialog {
	animation: x-pg-modal-in 0.22s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes x-pg-modal-in {
	from {
		opacity: 0;
		transform: scale(0.96) translateY(8px);
	}
	to {
		opacity: 1;
		transform: scale(1) translateY(0);
	}
}

/* Card */
.x-pg-editor-modal .modal-content {
	border: none;
	border-radius: 18px;
	box-shadow:
		0 0 0 1px rgba(0, 0, 0, 0.05),
		0 4px 16px rgba(0, 0, 0, 0.1),
		0 24px 56px rgba(0, 0, 0, 0.14);
	overflow: hidden;
	background: #ffffff;
}

/* Header */
.x-pg-editor-modal .modal-header {
	padding: 1.25rem 1.5rem 1rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.07);
	background: #fff;
}

/* Title */
.x-pg-editor-modal .modal-title {
	font-size: 0.975rem;
	font-weight: 650;
	letter-spacing: -0.02em;
	color: #0f172a;
	line-height: 1.3;
}

/* Close button */
.x-pg-editor-modal .btn-close {
	width: 28px;
	height: 28px;
	min-width: 28px;
	padding: 0;
	border-radius: 8px;
	opacity: 0.4;
	background-size: 11px;
	transition: background-color 0.15s ease, opacity 0.15s ease;
}
.x-pg-editor-modal .btn-close:hover {
	background-color: rgba(0, 0, 0, 0.07);
	opacity: 0.85;
}
.x-pg-editor-modal .btn-close:focus {
	box-shadow: 0 0 0 3px rgba(26, 86, 219, 0.25);
}

/* Body */
.x-pg-editor-modal .modal-body {
	padding: 1.25rem 1.5rem;
	background: #fff;
}

/* Footer */
.x-pg-editor-modal .modal-footer {
	padding: 0.875rem 1.5rem;
	background: #f8fafc;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
	gap: 0.5rem;
}

/* ── Buttons ─────────────────────────────────────────────────────── */

/* Primary */
.x-pg-editor-modal .btn-primary {
	background: #1a56db;
	border-color: #1a56db;
	border-radius: 10px;
	font-size: 0.875rem;
	font-weight: 500;
	padding: 0.45rem 1.1rem;
	box-shadow: 0 1px 3px rgba(26, 86, 219, 0.3), 0 1px 1px rgba(0,0,0,0.06);
	transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
}
.x-pg-editor-modal .btn-primary:hover {
	background: #1648c8;
	border-color: #1648c8;
	box-shadow: 0 2px 8px rgba(26, 86, 219, 0.38), 0 1px 2px rgba(0,0,0,0.08);
	transform: translateY(-1px);
}
.x-pg-editor-modal .btn-primary:active {
	transform: translateY(0);
	box-shadow: 0 1px 3px rgba(26, 86, 219, 0.3);
}

/* Secondary / Light */
.x-pg-editor-modal .btn-secondary,
.x-pg-editor-modal .btn-light {
	background: #fff;
	border: 1px solid #e2e8f0;
	color: #475569;
	border-radius: 10px;
	font-size: 0.875rem;
	font-weight: 500;
	padding: 0.45rem 1.1rem;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.x-pg-editor-modal .btn-secondary:hover,
.x-pg-editor-modal .btn-light:hover {
	background: #f1f5f9;
	border-color: #cbd5e1;
	color: #1e293b;
}

/* Small toggle buttons (aspect ratio / shape in ImageCropper) */
.x-pg-editor-modal .btn-sm {
	border-radius: 8px;
	font-size: 0.8125rem;
	font-weight: 500;
	padding: 0.3rem 0.7rem;
}
.x-pg-editor-modal .btn-outline-secondary {
	border-color: #e2e8f0;
	color: #475569;
	background: #fff;
}
.x-pg-editor-modal .btn-outline-secondary:hover {
	background: #f1f5f9;
	border-color: #cbd5e1;
	color: #1e293b;
}
.x-pg-editor-modal .x-pg-description-toolbar button.btn-outline-secondary,
.x-pg-editor-modal .x-pg-portfolio-detail-toolbar button.btn-outline-secondary {
	border-color: transparent;
	background: transparent;
}
.x-pg-editor-modal .x-pg-description-toolbar button.btn-outline-secondary:hover,
.x-pg-editor-modal .x-pg-portfolio-detail-toolbar button.btn-outline-secondary:hover {
	border-color: transparent;
	background: #e9ecef;
}
.x-pg-editor-modal .x-pg-description-toolbar button.btn-outline-secondary.active,
.x-pg-editor-modal .x-pg-portfolio-detail-toolbar button.btn-outline-secondary.active {
	border-color: var(--x-pg-nav-accent);
	background-color: #f1f5f9;
}
.x-pg-editor-modal .btn-sm.btn-primary {
	box-shadow: none;
	padding: 0.3rem 0.7rem;
}

/* ── Insert block cards ──────────────────────────────────────────── */
.x-pg-editor-modal .x-pg-insert-block-card {
	border-radius: 12px;
	border: 1.5px solid #edf0f7;
	padding: 0.6rem 0.85rem;
	min-height: 3.6rem;
	background: #fff;
	transition:
		border-color 0.15s ease,
		box-shadow 0.15s ease,
		transform 0.12s ease,
		background 0.15s ease;
}
.x-pg-editor-modal .x-pg-insert-block-card:hover:not(:disabled) {
	border-color: #1a56db;
	box-shadow: 0 0 0 3px rgba(26, 86, 219, 0.1);
	transform: translateY(-1px);
	background: #fafcff;
}
.x-pg-editor-modal .x-pg-insert-block-card:active:not(:disabled) {
	transform: translateY(0);
}
.x-pg-editor-modal .x-pg-insert-block-card:disabled {
	border-color: #f0f3f8;
	background: #fafafa;
}

/* ── Nav tabs ────────────────────────────────────────────────────── */
.x-pg-editor-modal .nav-tabs {
	border-bottom: 1px solid #edf0f7;
	gap: 0.15rem;
}
.x-pg-editor-modal .nav-tabs .nav-link {
	border-radius: 8px 8px 0 0;
	font-size: 0.875rem;
	font-weight: 500;
	color: #64748b;
	border: none;
	padding: 0.45rem 1rem 0.5rem;
	transition: color 0.15s, background 0.15s;
}
.x-pg-editor-modal .nav-tabs .nav-link:hover {
	color: #1e293b;
	background: #f1f5f9;
}
.x-pg-editor-modal .nav-tabs .nav-link.active {
	color: #1a56db;
	background: #eff6ff;
	border-bottom: 2px solid #1a56db;
	font-weight: 600;
}

/* ── Checkbox list (TabGroupSectionPicker) ───────────────────────── */
.x-pg-editor-modal .modal-body label.border {
	border-radius: 10px !important;
	border-color: #edf0f7 !important;
	transition: border-color 0.15s, background 0.15s;
	cursor: pointer;
}
.x-pg-editor-modal .modal-body label.border:hover {
	border-color: #1a56db !important;
	background: #f0f5ff;
}

/* ── Form inputs inside modal body ──────────────────────────────── */
.x-pg-editor-modal .form-select,
.x-pg-editor-modal .form-control {
	border-radius: 9px;
	border-color: #e2e8f0;
	font-size: 0.875rem;
}
.x-pg-editor-modal .form-select:focus,
.x-pg-editor-modal .form-control:focus {
	border-color: #1a56db;
	box-shadow: 0 0 0 3px rgba(26, 86, 219, 0.14);
}

/* ── Range slider (zoom in ImageCropper) ────────────────────────── */
.x-pg-editor-modal .form-range {
	accent-color: #1a56db;
}
.x-pg-editor-modal .form-range::-webkit-slider-runnable-track {
	background: #e2e8f0;
	border-radius: 4px;
	height: 4px;
}
.x-pg-editor-modal .form-range::-webkit-slider-thumb {
	background: #1a56db;
	border: 2px solid #fff;
	box-shadow: 0 0 0 1px #1a56db;
}

/* ── Category headers (InsertSectionModal) ───────────────────────── */
.x-pg-editor-modal .modal-body h6.text-muted {
	font-size: 0.695rem;
	letter-spacing: 0.07em;
	color: #94a3b8 !important;
	font-weight: 600;
}

/* ── Badge ────────────────────────────────────────────────────────── */
.x-pg-editor-modal .badge.bg-secondary {
	background: #e2e8f0 !important;
	color: #64748b !important;
	border-radius: 5px;
	font-weight: 500;
}

/* ── hr in DevStateModal ──────────────────────────────────────────── */
.x-pg-editor-modal hr {
	border-color: #edf0f7;
	opacity: 1;
}

/* ── muted text ───────────────────────────────────────────────────── */
.x-pg-editor-modal .text-muted {
	color: #64748b !important;
}

/* ═══════════════════════════════════════════════════════════════════
   End Editor Modal Premium Redesign
   ═══════════════════════════════════════════════════════════════════ */

.x-pg-editor-device-overlay {
	position: fixed;
	inset: 0;
	z-index: 2000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}
body.x-pg-app-body--editor-device-blocked {
	overflow: hidden;
}
.x-pg-editor-device-overlay__backdrop {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at top, rgba(59, 130, 246, 0.2), transparent 40%),
		linear-gradient(135deg, rgba(15, 23, 42, 0.92), rgba(30, 41, 59, 0.9));
	backdrop-filter: blur(10px);
}
.x-pg-editor-device-overlay__panel {
	position: relative;
	z-index: 1;
	width: min(100%, 520px);
	padding: 28px 24px;
	border-radius: 28px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	background: rgba(255, 255, 255, 0.96);
	box-shadow: 0 28px 80px rgba(15, 23, 42, 0.32);
	text-align: center;
	color: #0f172a;
}
.x-pg-editor-device-overlay__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-width: 92px;
	padding: 12px 18px;
	border-radius: 999px;
	background: linear-gradient(135deg, #eff6ff, #dbeafe);
	color: #1d4ed8;
	font-size: 1.6rem;
	box-shadow: inset 0 0 0 1px rgba(29, 78, 216, 0.12);
}
.x-pg-editor-device-overlay__icon-arrow {
	font-size: 1.5rem;
	color: #64748b;
}
.x-pg-editor-device-overlay__badge {
	margin-top: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 12px;
	border-radius: 999px;
	background: #fff7ed;
	color: #c2410c;
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.08em;
}
.x-pg-editor-device-overlay__title {
	margin: 16px 0 10px;
	font-size: clamp(1.55rem, 4vw, 2.05rem);
	line-height: 1.2;
	font-weight: 800;
	letter-spacing: -0.02em;
}
.x-pg-editor-device-overlay__description {
	margin: 0;
	font-size: 1rem;
	line-height: 1.75;
	color: #334155;
}
.x-pg-editor-device-overlay__actions {
	margin-top: 20px;
	display: flex;
	justify-content: center;
}
.x-pg-editor-device-overlay__copy-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-width: 200px;
	padding: 12px 18px;
	border: 0;
	border-radius: 999px;
	background: linear-gradient(135deg, #2563eb, #1d4ed8);
	color: #fff;
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1;
	box-shadow: 0 16px 32px rgba(37, 99, 235, 0.28);
	transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}
.x-pg-editor-device-overlay__copy-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 20px 38px rgba(37, 99, 235, 0.34);
}
.x-pg-editor-device-overlay__copy-btn:active {
	transform: translateY(0);
}
.x-pg-editor-device-overlay__copy-btn.is-copied {
	background: linear-gradient(135deg, #16a34a, #15803d);
	box-shadow: 0 16px 32px rgba(22, 163, 74, 0.26);
}
.x-pg-editor-device-overlay__copy-btn i {
	font-size: 1rem;
	line-height: 1;
}
.x-pg-editor-device-overlay__footer {
	margin-top: 18px;
	padding: 14px 16px;
	border-radius: 18px;
	background: #f8fafc;
	color: #475569;
	font-size: 0.95rem;
	line-height: 1.7;
}
@media (max-width: 575.98px) {
	.x-pg-editor-device-overlay {
		padding: 16px;
	}
	.x-pg-editor-device-overlay__panel {
		padding: 24px 18px 20px;
		border-radius: 24px;
	}
	.x-pg-editor-device-overlay__description,
	.x-pg-editor-device-overlay__footer {
		font-size: 0.95rem;
		line-height: 1.65;
	}
	.x-pg-editor-device-overlay__copy-btn {
		width: 100%;
		min-width: 0;
	}
}
