/**
 * หน้าแรก Marketplace — จับคู่ stitch_sign_up/code.html (สี ระยะ โครงสร้าง)
 * ทุกกฎอยู่ภายใต้ .apptook-stitch เพื่อไม่ชนกับธีม
 *
 * ฟอนต์แบบ Apple: ใช้ San Francisco บน Safari/macOS/iOS ผ่าน -apple-system /
 * BlinkMacSystemFont (ไม่ฝังไฟล์ SF) — Windows ได้ Segoe UI, แพลตฟอร์มอื่น fallback
 */

.apptook-stitch {
	--st-on-surface: #161d1d;
	--st-on-surface-variant: #3c4949;
	--st-surface: #f4fbfa;
	--st-surface-container-low: #eff5f4;
	--st-surface-container-lowest: #ffffff;
	--st-surface-container: #e9efef;
	--st-surface-container-high: #e3e9e9;
	--st-primary: #81D8D0;
	--st-primary-rgb: 129, 216, 208;
	--st-outline: #6c7a7a;
	--st-outline-variant: #bbc9c9;
	--st-global-bg-image: none;
	--st-font-text: "Kanit", sans-serif;
	color: var(--st-on-surface);
	font-family: var(--st-font-text);
	font-size: 16px;
	line-height: 1.5;
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	background-color: var(--st-surface);
	background-image: linear-gradient(rgba(244, 251, 250, 0.82), rgba(244, 251, 250, 0.82)), var(--st-global-bg-image);
	background-position: center 8.2rem, center 8.2rem;
	background-size: 100% calc(100% - 8.2rem), contain;
	background-repeat: no-repeat, no-repeat;
	background-attachment: scroll;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.apptook-stitch *,
.apptook-stitch *::before,
.apptook-stitch *::after {
	box-sizing: border-box;
}

.apptook-stitch .material-symbols-outlined {
	font-family: "Material Symbols Outlined";
	font-weight: normal;
	font-style: normal;
	font-size: 24px;
	line-height: 1;
	letter-spacing: normal;
	text-transform: none;
	display: inline-block;
	white-space: nowrap;
	word-wrap: normal;
	direction: ltr;
	font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
	vertical-align: middle;
}

.apptook-stitch .material-symbols-outlined.ms-fill {
	font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

/* ---- Fixed nav (stitch nav) ---- */
.apptook-stitch .st-nav {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 50;
	background: #fff;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

body.admin-bar .apptook-stitch .st-nav {
	top: 32px;
}

@media screen and (max-width: 782px) {
	body.admin-bar .apptook-stitch .st-nav {
		top: 46px;
	}
}

.apptook-stitch .st-nav__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1rem 2rem;
	max-width: 96rem;
	margin: 0 auto;
	min-height: 64px;
}

.apptook-stitch .st-nav__logo {
	font-size: 1.5rem;
	line-height: 2rem;
	font-weight: 900;
	letter-spacing: -0.025em;
	color: var(--st-primary);
	text-decoration: none;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
}

.apptook-stitch .st-nav__logo-img {
	width: 28px;
	height: 28px;
	object-fit: contain;
	flex-shrink: 0;
	display: inline-block;
}

.apptook-stitch .st-nav__links {
	display: none;
	align-items: center;
	gap: 2rem;
}

.apptook-stitch .st-nav__links ul,
.apptook-stitch .st-nav__mobile-panel ul {
	display: contents;
	margin: 0;
	padding: 0;
	list-style: none;
}

.apptook-stitch .st-nav__links li,
.apptook-stitch .st-nav__mobile-panel li {
	margin: 0;
	padding: 0;
	list-style: none;
}

@media (min-width: 768px) {
	.apptook-stitch .st-nav__links {
		display: flex;
	}
}

.apptook-stitch .st-nav__links a {
	font-weight: 500;
	color: #475569;
	text-decoration: none;
	transition: color 0.15s ease;
}

.apptook-stitch .st-nav__links a:hover {
	color: var(--st-primary);
}

.apptook-stitch .st-nav__links a.is-active,
.apptook-stitch .st-nav__links .current-menu-item > a,
.apptook-stitch .st-nav__links .current_page_item > a,
.apptook-stitch .st-nav__links .current-menu-ancestor > a {
	color: var(--st-primary);
	font-weight: 700;
	border-bottom: 2px solid var(--st-primary);
	padding-bottom: 0.25rem;
}

.apptook-stitch .st-nav__right {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	min-height: 44px;
}

.apptook-stitch .st-nav__icon-btn.st-nav__mobile-trigger {
	display: none !important;
}

@media (max-width: 767px) {
	.apptook-stitch .st-nav__icon-btn.st-nav__mobile-trigger {
		display: inline-flex !important;
	}
}

.apptook-stitch .st-nav__mobile-panel {
	display: none;
}

.apptook-stitch .buyer-ticker-track {
	position: fixed;
	top: 4rem;
	left: 0;
	right: 0;
	z-index: 49;
	background: rgba(255, 255, 255, 0.95);
	color: #475569;
	overflow: hidden;
	border-top: 1px solid #e2e8f0;
	border-bottom: 1px solid #e2e8f0;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}

body.admin-bar .apptook-stitch .buyer-ticker-track {
	top: calc(4rem + 32px);
}

@media screen and (max-width: 782px) {
	body.admin-bar .apptook-stitch .buyer-ticker-track {
		top: calc(4rem + 46px);
	}
}

.apptook-stitch .buyer-ticker-track.py-2 {
	padding-top: 1.5rem;
	padding-bottom: 0.5rem;
}

.apptook-stitch .buyer-ticker-track__inner {
	display: inline-flex;
	align-items: center;
	gap: 1.6rem;
	white-space: nowrap;
	padding-left: 0;
	animation-name: apptookBuyerTickerMove;
	animation-duration: 100s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	will-change: transform;
}

.apptook-stitch .buyer-ticker-track__item {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	font-size: 0.82rem;
	font-weight: 600;
	padding: 0 0.35rem;
}

.apptook-stitch .buyer-ticker-track__buyer {
	font-size: 0.75rem;
	font-weight: 700;
	color: #334155;
}

.apptook-stitch .buyer-ticker-track__action {
	font-size: 0.74rem;
	font-weight: 700;
	color: #0f172a;
}

.apptook-stitch .buyer-ticker-track__product {
	font-size: 0.74rem;
	font-weight: 600;
	color: #64748b;
}

.apptook-stitch .buyer-ticker-track__time {
	font-size: 0.72rem;
	font-weight: 500;
	color: #94a3b8;
}

.apptook-stitch .buyer-ticker-track__item::after {
	content: '•';
	margin-left: 0.65rem;
	color: #cbd5e1;
}

.apptook-stitch .buyer-ticker-track:hover .buyer-ticker-track__inner,
.apptook-stitch .buyer-ticker-track:focus-within .buyer-ticker-track__inner {
	animation-play-state: paused;
}

@keyframes apptookBuyerTickerMove {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-50%);
	}
}

.apptook-stitch .st-nav__icons {
	display: flex;
	align-items: center;
	gap: 1rem;
	height: 44px;
}

.apptook-stitch .st-nav__icon-btn {
	color: var(--st-on-surface-variant);
	cursor: pointer;
	text-decoration: none;
	transition: color 0.15s ease;
	border: 0;
	background: none;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	height: 44px;
	min-height: 44px;
	min-width: 44px;
}
.apptook-stitch .st-nav__icon-btn .material-symbols-outlined {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	font-size: 26px;
	vertical-align: middle;
}

.apptook-stitch .st-nav__icon-btn:hover {
	color: var(--st-primary);
	box-shadow: none;
}

.apptook-stitch .st-nav__icon-btn--subscription {
	position: relative;
}

.apptook-stitch .st-nav__notification-badge {
	position: absolute;
	top: -4px;
	right: -6px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	border-radius: 999px;
	background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 10px;
	font-weight: 800;
	line-height: 1;
	text-align: center;
	transform: translateY(-1px);
	box-shadow: 0 8px 20px rgba(220, 38, 38, 0.3);
	border: 2px solid #fff;
}

.apptook-stitch .st-nav__profile-wrap {
	position: relative;
	padding-bottom: 12px;
	margin-bottom: -12px;
}

.apptook-stitch .st-nav__profile-trigger,
.apptook-stitch .st-nav__profile-trigger:focus,
.apptook-stitch .st-nav__profile-trigger:active,
.apptook-stitch .st-nav__profile-trigger[aria-expanded="true"] {
	box-shadow: none !important;
	outline: none !important;
	background: transparent !important;
}
.apptook-stitch .text-on-surface {
	color: var(--st-on-surface);
}

.apptook-stitch .st-nav__dropdown {
	display: none;
	position: absolute;
	right: 0;
	margin-top: 0.5rem;
	width: 14rem;
	background: #fff;
	border-radius: 1rem;
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
	border: 1px solid #f1f5f9;
	padding: 0.5rem 0;
	z-index: 50;
	overflow: hidden;
}

.apptook-stitch .st-nav__dropdown.is-open {
	display: block;
}

.apptook-stitch .st-nav__dropdown-head {
	padding: 0.75rem 1rem;
	border-bottom: 1px solid #f8fafc;
}

.apptook-stitch .st-nav__dropdown-head p {
	margin: 0;
	font-size: 0.75rem;
	color: #94a3b8;
}

.apptook-stitch .st-nav__dropdown-head strong {
	display: block;
	font-size: 0.875rem;
	color: #334155;
	margin-top: 0.125rem;
}

.apptook-stitch .st-nav__dropdown a {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	font-size: 0.875rem;
	color: #475569;
	text-decoration: none;
	transition: background 0.15s ease;
}

.apptook-stitch .st-nav__dropdown a:hover {
	background: var(--st-surface-container);
}

.apptook-stitch .st-nav__dropdown a .material-symbols-outlined {
	font-size: 1.125rem;
}

.apptook-stitch .st-nav__dropdown a.has-subscription-notification {
	justify-content: space-between;
}

.apptook-stitch .st-nav__dropdown-badge {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 22px;
	padding: 0 10px;
	border-radius: 999px;
	background: rgba(239, 68, 68, 0.12);
	color: #dc2626;
	font-size: 11px;
	font-weight: 800;
	white-space: nowrap;
}

.apptook-stitch .st-nav__dropdown-divider {
	border-top: 1px solid #f8fafc;
	margin-top: 0.25rem;
}

.apptook-stitch .st-nav__dropdown a.st-nav__logout {
	color: #ef4444;
}

.apptook-stitch .st-nav__dropdown a.st-nav__logout:hover {
	background: #fef2f2;
}

.apptook-stitch .st-nav__auth {
	display: none;
	align-items: center;
	gap: 0.75rem;
	height: 40px;
}
@media (min-width: 640px) {
	.apptook-stitch .st-nav__auth {
		display: flex;
	}
}

.apptook-stitch .st-nav__btn-ghost {
	padding: 0.5rem 1.25rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: #334155;
	background: transparent;
	border: 0;
	border-radius: 0.75rem;
	cursor: pointer;
	text-decoration: none;
	transition: background 0.15s ease;
	font-family: var(--st-font-text);
}

.apptook-stitch .st-nav__btn-ghost:hover {
	background: var(--st-surface-container);
}

.apptook-stitch .st-nav__btn-primary {
	padding: 0.5rem 1.25rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: #fff;
	background: var(--st-primary);
	border: 0;
	border-radius: 0.75rem;
	cursor: pointer;
	text-decoration: none;
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.08);
	transition: opacity 0.15s ease;
	font-family: var(--st-font-text);
}

.apptook-stitch .st-nav__btn-primary:hover {
	opacity: 0.9;
}

/* ---- Main ---- */
.apptook-stitch .st-main {
	padding-top: 8.2rem;
	padding-bottom: 5rem;
	background: transparent;
	flex: 1;
}

.apptook-stitch .apptook-ds-shop,
.apptook-stitch .apptook-ds-library,
.apptook-stitch .apptook-st-register {
	flex: 1;
	padding-top: 8.2rem;
	padding-left: 1rem;
	padding-right: 1rem;
	padding-bottom: 2rem;
}

/* ---- Hero + search ---- */
.apptook-stitch .st-hero {
	max-width: 80rem;
	margin: 0 auto;
	padding: 4rem 1.5rem;
	text-align: center;
}

.apptook-stitch .st-hero__title {
	font-size: 2.25rem;
	font-weight: 500;
	color: var(--st-on-surface);
	letter-spacing: -0.025em;
	margin: 0 0 3rem;
	line-height: 1.2;
}

@media (min-width: 768px) {
	.apptook-stitch .st-hero__title {
		font-size: 3rem;
	}
}

@media (min-width: 1024px) {
	.apptook-stitch .st-hero__title {
		font-size: 3.75rem;
	}
}

.apptook-stitch .st-hero__sub {
	font-size: 1rem;
	color: var(--st-on-surface-variant);
	margin: -2rem 0 2rem;
	max-width: 40rem;
	margin-left: auto;
	margin-right: auto;
}

.apptook-stitch .st-search-wrap {
	max-width: 42rem;
	margin: 0 auto;
	position: relative;
}

.apptook-stitch .st-search-pill {
	display: flex;
	align-items: center;
	background: var(--st-surface-container-lowest);
	border-radius: 9999px;
	padding: 0.5rem;
	box-shadow: 0 0 0 1px rgba(187, 201, 201, 0.35), 0 20px 25px -5px rgba(0, 0, 0, 0.08);
	transition: box-shadow 0.3s ease;
}

.apptook-stitch .st-search-pill:focus-within {
	box-shadow: 0 0 0 2px rgba(129, 216, 208, 0.24), 0 20px 25px -5px rgba(0, 0, 0, 0.08);
}

.apptook-stitch .st-search-pill .material-symbols-outlined {
	margin-left: 1rem;
	color: var(--st-outline);
	font-size: 1.35rem;
}

.apptook-stitch .st-search-input {
	flex: 1;
	border: 0;
	background: transparent;
	padding: 0.65rem 1rem;
	font-size: 1rem;
	font-family: var(--st-font-text);
	font-weight: 500;
	color: var(--st-on-surface);
	outline: none;
	box-shadow: none;
	min-width: 0;
}

.apptook-stitch .st-search-input:focus,
.apptook-stitch .st-search-input:focus-visible {
	outline: none;
	box-shadow: none;
}

.apptook-stitch .st-search-input::placeholder {
	color: var(--st-outline-variant);
}

.apptook-stitch .st-search-btn {
	border: 0;
	border-radius: 9999px;
	background: var(--st-primary);
	color: #fff;
	font-weight: 700;
	padding: 0.75rem 2rem;
	font-family: var(--st-font-text);
	font-size: 1rem;
	cursor: pointer;
	transition: opacity 0.15s ease, transform 0.1s ease;
	white-space: nowrap;
}

.apptook-stitch .st-search-btn:hover {
	opacity: 0.9;
}

.apptook-stitch .st-search-btn:active {
	transform: scale(0.97);
}

/* Sort (เพิ่มจากระบบเดิม — จัดให้เข้ากับ stitch) */
.apptook-stitch .st-sort-row {
	max-width: 80rem;
	margin: 0 auto;
	padding: 0 1.5rem 1rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.5rem;
}

.apptook-stitch .st-sort-label {
	font-size: 0.875rem;
	color: var(--st-on-surface-variant);
	font-weight: 500;
}

.apptook-stitch .st-sort-select {
	border-radius: 1rem;
	border: 1px solid #e2e8f0;
	background: #fff;
	padding: 0.5rem 0.85rem;
	font-size: 0.875rem;
	color: #475569;
	font-family: var(--st-font-text);
	cursor: pointer;
	min-width: 11rem;
}

/* ---- Category strip ---- */
.apptook-stitch .st-cats {
	background: var(--st-surface-container-low);
	margin-bottom: 3rem;
}

.apptook-stitch .st-cats__inner {
	max-width: 80rem;
	margin: 0 auto;
	padding: 1.5rem 1.5rem;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.apptook-stitch .st-cats__tabs {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	min-width: min-content;
}

.apptook-stitch .category-btn {
	border: 0;
	cursor: pointer;
	font-family: var(--st-font-text);
	border-radius: 1rem;
	transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
	background: transparent;
}

.apptook-stitch .category-btn--row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1.5rem;
	font-weight: 700;
}

.apptook-stitch .category-btn--stack {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.25rem;
	padding: 0.5rem 1.5rem;
}

.apptook-stitch .category-btn--stack .st-cat-label {
	font-size: 0.75rem;
	font-weight: 500;
}

.apptook-stitch .category-btn.is-inactive {
	color: var(--st-on-surface-variant);
}

.apptook-stitch .category-btn.is-inactive:hover {
	color: var(--st-primary);
	background: var(--st-surface-container-high);
}

.apptook-stitch .category-btn.is-active {
	background: var(--st-primary);
	color: #fff;
	box-shadow: 0 4px 6px -1px rgba(65, 225, 227, 0.35);
}

.apptook-stitch .category-btn.is-active .material-symbols-outlined {
	color: #fff;
}

/* ---- Grid section ---- */
.apptook-stitch .st-grid-section {
	max-width: 80rem;
	margin: 0 auto;
	padding: 0 1.5rem;
}

.apptook-stitch .st-product-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}

@media (min-width: 640px) {
	.apptook-stitch .st-product-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.apptook-stitch .st-product-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1280px) {
	.apptook-stitch .st-product-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* ---- Product card (stitch) ---- */
.apptook-stitch .product-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border-radius: 2rem;
	background: #fff;
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.apptook-stitch .product-card:hover {
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.08), 0 8px 10px -6px rgba(0, 0, 0, 0.05);
	transform: translateY(-4px);
}

.apptook-stitch .product-card.is-hidden {
	display: none !important;
}

.apptook-stitch .st-card-top {
	background: var(--st-surface-container-lowest);
	padding: 2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	position: relative;
	min-height: 160px;
}

.apptook-stitch .st-card-top img {
	width: 4rem;
	height: 4rem;
	object-fit: contain;
	margin-bottom: 1rem;
}

.apptook-stitch .st-card-top .st-card-icon-lg {
	font-size: 3rem;
	margin-bottom: 1rem;
	line-height: 1;
}

.apptook-stitch .st-card-badge {
	position: absolute;
	top: 1rem;
	right: 1rem;
	font-size: 0.625rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 0.25rem 0.75rem;
	border-radius: 9999px;
	max-width: 10rem;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.apptook-stitch .st-card-badge--mint {
	background: rgba(65, 225, 227, 0.12);
	color: #005254;
}

.apptook-stitch .st-card-badge--green {
	background: #dcfce7;
	color: #15803d;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	max-width: 11rem;
}

.apptook-stitch .st-card-badge--green .material-symbols-outlined {
	font-size: 0.75rem;
}

.apptook-stitch .st-card-title {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0;
	line-height: 1.25;
	color: var(--st-on-surface);
}

/* Wave bar — path เดียวกับ stitch */
.apptook-stitch .card-wave-bg {
	position: relative;
	background-image: url("../images/bg-price.png");
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: cover;
	background-color: rgb(65, 225, 227);
	padding-top: 2rem;
	padding-bottom: 1.5rem;
	text-align: center;
	overflow: hidden;
}

.apptook-stitch .card-wave-bg::before {
	display: none;
}

.apptook-stitch .st-card-price-buyer-wrap {
	overflow: hidden;
	margin: -0.55rem auto 0.32rem;
	max-width: 98%;
	padding: 0.08rem 0;
	min-height: 1.05rem;
}

.apptook-stitch .st-card-price-buyer-track {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 1.05rem;
}

.apptook-stitch .st-card-price-buyer-item {
	position: absolute;
	left: 50%;
	top: 50%;
	display: inline-flex;
	align-items: center;
	gap: 0.2rem;
	max-width: 100%;
	font-size: 0.68rem;
	font-weight: 600;
	color: #475569;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
	white-space: nowrap;
	opacity: 0;
	transform: translate(-50%, calc(-50% + 10px));
	pointer-events: none;
	transition: opacity 0.26s ease, transform 0.26s ease;
}

.apptook-stitch .st-card-price-buyer-item strong,
.apptook-stitch .st-card-price-buyer-item em {
	display: inline-block;
	overflow: hidden;
	text-overflow: ellipsis;
}

.apptook-stitch .st-card-price-buyer-item em {
	font-style: normal;
	font-weight: 500;
	color: #64748b;
	margin-left: 0.2rem;
}

.apptook-stitch .st-card-price-buyer-item.is-active {
	opacity: 1;
}

.apptook-stitch .st-card-price-buyer-item.is-active.is-entering {
	transform: translate(-50%, -50%);
}

.apptook-stitch .st-card-price-buyer-item .material-symbols-outlined {
	font-size: 0.85rem;
	color: #64748b;
}

.apptook-stitch .st-card-price {
	color: #ffffff;
	font-size: 30px;
	font-weight: 400;
	letter-spacing: -0.01em;
	line-height: 1;
	text-align: center;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.18), 0 3px 8px rgba(0, 0, 0, 0.18);
}

.apptook-stitch .st-card-price span {
	display: block;
	margin-top: 0.22rem;
	font-size: 18px;
	font-weight: 400;
	line-height: 1;
	white-space: nowrap;
	opacity: 0.98;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
}


.apptook-stitch .st-card-body {
	flex: 1;
	display: flex;
	flex-direction: column;
	background: var(--st-surface-container-low);
	padding: 1.5rem;
}

.apptook-stitch .st-card-body ul {
	list-style: none;
	margin: 0;
	padding: 0;
	flex: 1;
}

.apptook-stitch .st-card-body li {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--st-on-surface-variant);
	margin-bottom: 0.75rem;
	line-height: 1.4;
}

.apptook-stitch .st-card-body li .material-symbols-outlined {
	color: var(--st-primary);
	font-size: 1.125rem;
	flex-shrink: 0;
	margin-top: 0.05rem;
}

.apptook-stitch .st-card-body li.st-card-extra-feature {
	display: none;
}

.apptook-stitch .product-card.is-features-expanded .st-card-body li.st-card-extra-feature {
	display: flex;
}

.apptook-stitch .st-card-bounce-wrap {
	display: flex;
	justify-content: center;
	margin-bottom: 1rem;
}

.apptook-stitch button.st-card-bounce-wrap {
	width: 100%;
	padding: 0;
	border: 0;
	outline: 0;
	background: transparent;
	box-shadow: none;
	appearance: none;
	cursor: pointer;
}

.apptook-stitch button.st-card-bounce-wrap:hover,
.apptook-stitch button.st-card-bounce-wrap:focus,
.apptook-stitch button.st-card-bounce-wrap:focus-visible,
.apptook-stitch button.st-card-bounce-wrap:active {
	border: 0;
	outline: 0;
	background: transparent;
	box-shadow: none;
}

.apptook-stitch .product-card.is-features-expanded .st-card-bounce-wrap .material-symbols-outlined {
	transform: rotate(180deg);
}

@keyframes st-bounce-slow {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(5px); }
}

.apptook-stitch .animate-bounce-slow {
	animation: st-bounce-slow 2s infinite ease-in-out;
	color: var(--st-primary);
}

.apptook-stitch .buy-btn {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 0;
	border-radius: 9999px;
	background: var(--st-primary);
	color: #fff;
	font-weight: 700;
	font-size: 0.875rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-family: var(--st-font-text);
	cursor: pointer;
	transition: background-color 0.18s ease, box-shadow 0.18s ease, transform 0.12s ease;
}

.apptook-stitch .buy-btn:hover:not(:disabled) {
	background: #34d9db;
	box-shadow: 0 10px 20px rgba(65, 225, 227, 0.28);
}

.apptook-stitch .buy-btn:active:not(:disabled) {
	transform: scale(0.98);
}

.apptook-stitch .buy-btn:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.apptook-stitch .st-card-more {
	appearance: none;
	background: transparent;
	border: 0;
	cursor: pointer;
	font-family: var(--st-font-text);
	text-align: center;
	font-size: 0.75rem;
	color: var(--st-on-surface-variant);
	margin-top: 0.75rem;
	padding: 0;
	text-decoration: underline;
}

.apptook-stitch .st-card-more:hover,
.apptook-stitch .st-card-more:focus-visible {
	color: var(--st-primary);
}

.apptook-stitch .apptook-price-regular {
	display: inline-block;
	margin-right: 0.35rem;
	font-size: 0.58em;
	font-weight: 500;
	line-height: 1;
	color: rgba(255, 255, 255, 0.78);
	text-decoration: line-through;
	text-decoration-thickness: 1.5px;
}

.apptook-stitch .apptook-price-sale {
	display: inline-block;
	font-size: 1em;
	font-weight: 800;
	line-height: 1;
	color: inherit;
}

/* Show more */
.apptook-stitch .st-show-more-wrap {
	margin-top: 4rem;
	display: flex;
	justify-content: center;
}

.apptook-stitch .st-show-more-wrap.is-hidden {
	display: none;
}

.apptook-stitch .st-show-more-btn {
	padding: 0.75rem 3rem;
	background: #fff;
	color: var(--st-on-surface-variant);
	font-weight: 700;
	font-size: 0.875rem;
	border: 1px solid #e2e8f0;
	border-radius: 9999px;
	cursor: pointer;
	font-family: var(--st-font-text);
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	transition: background 0.15s ease;
	text-decoration: none;
	display: inline-block;
}

.apptook-stitch .st-show-more-btn:hover {
	background: #f8fafc;
}

/* Empty state */
.apptook-stitch .st-empty-grid {
	text-align: center;
	padding: 2rem;
	color: var(--st-on-surface-variant);
	display: none;
}

.apptook-stitch .st-empty-grid.is-visible {
	display: block;
}

/* Footer stitch */
.apptook-stitch .st-footer {
	width: 100%;
	margin-top: auto;
	background: #f1f5f9;
	border-top: 1px solid #e2e8f0;
}

.apptook-stitch.apptook-ds-product-detail-page + .st-footer,
.apptook-stitch.apptook-ds-product-detail-page .st-footer {
	margin-top: 3.5rem;
}

.apptook-stitch .st-footer__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding: 3rem;
	max-width: 96rem;
	margin: 0 auto;
}

@media (min-width: 768px) {
	.apptook-stitch .st-footer__inner {
		flex-direction: row;
		align-items: center;
		gap: 0;
	}
}

.apptook-stitch .st-footer__brand {
	text-align: center;
}

@media (min-width: 768px) {
	.apptook-stitch .st-footer__brand {
		text-align: left;
	}
}

.apptook-stitch .st-footer__logo {
	font-weight: 700;
	font-size: 1.5rem;
	color: #0f172a;
	letter-spacing: -0.025em;
	display: block;
	text-decoration: none;
}

.apptook-stitch .st-footer__copy {
	font-size: 0.875rem;
	color: #64748b;
	margin: 0.5rem 0 0;
}

.apptook-stitch .st-footer__links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 2rem;
}

.apptook-stitch .st-footer__links a {
	font-size: 0.875rem;
	color: #64748b;
	text-decoration: none;
	transition: color 0.15s ease;
}

.apptook-stitch .st-footer__links a:hover {
	color: var(--st-primary);
	text-decoration: underline;
}

.apptook-stitch .st-footer__social {
	display: flex;
	gap: 1rem;
}

.apptook-stitch .st-footer__social a {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 9999px;
	background: #e2e8f0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #475569;
	text-decoration: none;
	transition: background 0.15s ease, color 0.15s ease;
}

.apptook-stitch .st-footer__social a:hover {
	background: var(--st-primary);
	color: #fff;
}

.apptook-stitch .st-footer__social .material-symbols-outlined {
	font-size: 1.125rem;
}

/* ---- Login modal (stitch) ---- */
.apptook-stitch .apptook-st-modal-overlay {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 10060;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	background: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}

.apptook-stitch .apptook-st-modal-overlay.is-open {
	display: flex;
}

.apptook-stitch .apptook-st-modal {
	position: relative;
	background: #fff;
	border-radius: 2.5rem;
	width: 100%;
	max-width: 28rem;
	overflow: hidden;
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.2);
}

.apptook-stitch .apptook-st-modal-close {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	border: 0;
	background: none;
	cursor: pointer;
	color: #94a3b8;
	padding: 0.25rem;
	line-height: 1;
	transition: color 0.15s ease;
}

.apptook-stitch .apptook-st-modal-close:hover {
	color: #475569;
}

.apptook-stitch .apptook-st-modal-body {
	padding: 2.5rem;
}

.apptook-stitch .apptook-st-modal-title {
	font-size: 1.875rem;
	font-weight: 700;
	color: var(--st-on-surface);
	margin: 0 0 0.5rem;
	line-height: 1.2;
}

.apptook-stitch .apptook-st-modal-lead {
	color: #64748b;
	margin: 0 0 1rem;
	font-size: 1rem;
}

.apptook-stitch .apptook-st-modal .apptook-st-login-alert {
	margin: 0 0 1rem;
	padding: 0.85rem 1rem;
	border-radius: 1rem;
	background: #fef2f2 !important;
	color: #dc2626 !important;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.45;
	border: 1px solid #ef4444 !important;
}

.apptook-stitch .apptook-st-modal .apptook-st-login-alert,
.apptook-stitch .apptook-st-modal .apptook-st-login-alert * {
	color: #dc2626 !important;
}

.apptook-stitch .apptook-st-modal-form .apptook-st-field {
	margin-bottom: 1rem;
}

.apptook-stitch .apptook-st-label {
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	color: #334155;
	margin-bottom: 0.5rem;
}

.apptook-stitch .apptook-st-input {
	width: 100%;
	padding: 0.75rem 1.25rem;
	border-radius: 1rem;
	border: none;
	background: var(--st-surface-container-low);
	color: var(--st-on-surface);
	font-family: var(--st-font-text);
	font-size: 1rem;
	outline: none;
	box-shadow: 0 0 0 0 transparent;
	transition: box-shadow 0.15s ease;
}

.apptook-stitch .apptook-st-password-wrap {
	position: relative;
}

.apptook-stitch .apptook-st-input.apptook-st-input-password {
	padding-right: 3rem;
}

.apptook-stitch .apptook-st-password-toggle {
	position: absolute !important;
	right: 0.75rem !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	z-index: 5;
	width: 2rem !important;
	height: 2rem !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	margin: 0 !important;
	padding: 0 !important;
	min-height: 0 !important;
	border: 0 !important;
	border-radius: 0.5rem !important;
	background: transparent !important;
	box-shadow: none !important;
	color: #64748b !important;
	cursor: pointer;
	line-height: 1;
	appearance: none;
	-webkit-appearance: none;
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
	transition: opacity .15s ease;
}

.apptook-stitch .apptook-st-password-wrap.has-value .apptook-st-password-toggle {
	opacity: 1;
	pointer-events: auto;
	visibility: visible;
}

.apptook-stitch .apptook-st-password-toggle:hover {
	color: #334155 !important;
	background: rgba(15, 23, 42, 0.06) !important;
}

.apptook-stitch .apptook-st-password-toggle .material-symbols-outlined {
	font-size: 1.25rem;
	line-height: 1;
}

.apptook-stitch .apptook-st-input:focus {
	box-shadow: 0 0 0 2px var(--st-primary);
}

.apptook-stitch .apptook-st-input::placeholder {
	color: #94a3b8;
}

.apptook-stitch .apptook-st-remember {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: #475569;
	margin: 0.5rem 0 1rem;
	cursor: pointer;
}

.apptook-stitch .apptook-st-submit {
	width: 100%;
	margin-top: 1.5rem;
	padding: 1rem 1.25rem;
	border: 0;
	border-radius: 1rem;
	background: var(--st-primary);
	color: #fff;
	font-weight: 700;
	font-size: 1rem;
	font-family: var(--st-font-text);
	cursor: pointer;
	box-shadow: 0 10px 15px -3px rgba(65, 225, 227, 0.25);
	transition: opacity 0.15s ease;
}

.apptook-stitch .apptook-st-login-divider {
	position: relative;
	margin: 1.1rem 0 0.9rem;
	text-align: center;
}

.apptook-stitch .apptook-st-login-divider::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 50%;
	height: 1px;
	background: linear-gradient(90deg, rgba(148, 163, 184, 0.12), rgba(148, 163, 184, 0.4), rgba(148, 163, 184, 0.12));
}

.apptook-stitch .apptook-st-login-divider span {
	position: relative;
	display: inline-block;
	padding: 0 0.75rem;
	background: #fff;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #94a3b8;
}

.apptook-stitch .apptook-st-social-auth {
	display: grid;
	gap: 0.75rem;
}

.apptook-stitch .apptook-st-google-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.625rem;
	width: 100%;
	padding: 0.78rem 1rem;
	border-radius: 0.95rem;
	border: 1px solid #dbe3ed;
	background: #fff;
	color: #0f172a;
	text-decoration: none;
	font-weight: 650;
	font-size: 0.9375rem;
	box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06);
	transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}

.apptook-stitch .apptook-st-google-btn:hover {
	background: #f8fafc;
	border-color: #cbd5e1;
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.12);
	transform: translateY(-1px);
}

.apptook-stitch .apptook-st-google-btn:active {
	transform: translateY(0);
}

.apptook-stitch .apptook-st-google-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.35rem;
	height: 1.35rem;
	border-radius: 999px;
	flex: 0 0 1.35rem;
	overflow: hidden;
}

.apptook-stitch .apptook-st-google-icon img,
.apptook-stitch .apptook-st-google-icon svg {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: contain;
}

.apptook-stitch .apptook-st-link-btn {
	background: none;
	border: 0;
	padding: 0;
	margin: 0;
	font: inherit;
	font-weight: 600;
	color: var(--st-primary);
	cursor: pointer;
	text-decoration: none;
}

.apptook-stitch .apptook-st-link-btn:hover {
	text-decoration: underline;
}

.apptook-stitch .apptook-st-google-text {
	line-height: 1;
}

.apptook-stitch .apptook-st-submit:hover {
	opacity: 0.92;
}

.apptook-stitch .apptook-st-modal-meta {
	text-align: center;
	margin: 1.25rem 0 0;
	font-size: 0.875rem;
	color: #64748b;
}

.apptook-stitch .apptook-st-modal-meta a {
	color: var(--st-primary);
	text-decoration: none;
	font-weight: 600;
}

.apptook-stitch .apptook-st-modal-meta a:hover {
	text-decoration: underline;
}

.apptook-stitch .apptook-st-modal-meta-sep {
	margin: 0 0.35rem;
}

.apptook-stitch .st-nav__dropdown-item-btn {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	width: 100%;
	padding: 0.75rem 1rem;
	border: 0;
	background: none;
	text-align: left;
	font-size: 0.875rem;
	color: #475569;
	font-family: var(--st-font-text);
	cursor: pointer;
	transition: background 0.15s ease;
}

.apptook-stitch .st-nav__dropdown-item-btn:hover {
	background: var(--st-surface-container);
}

/* ---- Register page (stitch card) ---- */
.apptook-st-register {
	min-height: 60vh;
	padding: 2rem 1rem 4rem;
	background: var(--st-surface);
}

.apptook-st-register .apptook-st-register-card {
	max-width: 28rem;
	margin: 0 auto;
	background: #fff;
	border-radius: 2.5rem;
	padding: 2.5rem;
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.08);
}

.apptook-st-register .apptook-st-register-title {
	font-size: 1.875rem;
	font-weight: 700;
	color: var(--st-on-surface);
	margin: 0 0 0.5rem;
}

.apptook-st-register .apptook-st-register-lead {
	color: #64748b;
	margin: 0 0 0.75rem;
}

.apptook-st-register .apptook-st-register-hint {
	font-size: 0.8125rem;
	color: #64748b;
	line-height: 1.45;
	margin: 0 0 1.5rem;
}

.apptook-st-register .apptook-st-register-error,
.apptook-stitch .apptook-st-modal .apptook-st-register-error {
	margin: 0 0 1rem;
	padding: 0.85rem 1rem;
	border-radius: 1rem;
	background: #fef2f2;
	color: #b91c1c !important;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.45;
	border: 1px solid #fecaca;
}

.apptook-st-register .apptook-st-register-footer {
	margin-top: 1.5rem;
	text-align: center;
}

.apptook-st-register .apptook-st-register-warning,
.apptook-st-register-note {
	max-width: 36rem;
	margin: 0 auto;
	padding: 1.25rem;
	background: #fef3c7;
	border-radius: 1rem;
	color: #92400e;
	text-align: center;
}

.apptook-st-register-note.apptook-ds {
	background: var(--st-surface-container-low);
	color: var(--st-on-surface);
}

/* ---- My Subscription page ---- */
.apptook-stitch .apptook-my-subscription {
	background: var(--st-surface);
	padding-top: 8.2rem;
	padding-bottom: 4rem;
}

.apptook-stitch .apptook-my-subscription__container {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.apptook-stitch .apptook-my-subscription__head {
	margin-bottom: 1.5rem;
	margin-top: 1.5rem;
}

.apptook-stitch .apptook-my-subscription__head--with-action {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
}

.apptook-stitch .apptook-my-subscription__head-main {
	min-width: 0;
}

.apptook-stitch .apptook-my-subscription__back {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.55rem 1.1rem;
	border-radius: 999px;
	border: 1px solid #9fd8d9;
	background: var(--st-surface-container-low);
	font-size: 0.98rem;
	font-weight: 700;
	color: #1db6b8;
	text-decoration: none;
	white-space: nowrap;
	flex-shrink: 0;
	transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.apptook-stitch .apptook-my-subscription__back:hover {
	background: #dff7f7;
	color: #12989b;
	border-color: #84cbcc;
	box-shadow: 0 6px 14px rgba(65, 225, 227, 0.2);
}

.apptook-stitch .apptook-my-subscription__back .material-symbols-outlined {
	font-size: 1.1rem;
}

@media (max-width: 767px) {
	.apptook-stitch .apptook-my-subscription__head--with-action {
		flex-direction: column;
		align-items: flex-start;
	}
}

.apptook-stitch .apptook-my-subscription__title {
	margin: 0;
	font-size: clamp(1.8rem, 2.8vw, 2.5rem);
	line-height: 1.2;
	color: var(--st-on-surface);
}

.apptook-stitch .apptook-my-subscription__subtitle {
	margin: 0.5rem 0 0;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-my-subscription__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}

@media (min-width: 1200px) {
	.apptook-stitch .apptook-my-subscription__layout {
		grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr);
		align-items: start;
	}
}

.apptook-stitch .apptook-my-subscription__panel {
	background: #fff;
	border: 1px solid #e8efef;
	border-radius: 2rem;
	padding: 1rem;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

@media (min-width: 768px) {
	.apptook-stitch .apptook-my-subscription__panel {
		padding: 1.25rem;
	}
}

.apptook-stitch .apptook-my-subscription__panel--empty,
.apptook-stitch .apptook-my-subscription__panel--error,
.apptook-stitch .apptook-my-subscription--guest .apptook-my-subscription__panel {
	text-align: center;
	padding: 2rem 1.25rem;
}

.apptook-stitch .apptook-my-subscription__panel--error {
	border-color: #fecaca;
	background: #fff5f5;
}

.apptook-stitch .apptook-my-subscription__panel h2 {
	margin: 0;
	font-size: 1.2rem;
	line-height: 1.3;
}

.apptook-stitch .apptook-my-subscription__panel-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 0.65rem;
	margin-bottom: 2rem;
}

.apptook-stitch .apptook-my-subscription__panel-head h2 {
	margin: 0;
}

.apptook-stitch .apptook-my-subscription__count-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	padding: 0.38rem 0.7rem;
	border-radius: 999px;
	background: color-mix(in srgb, var(--st-primary) 18%, #ffffff);
	color: color-mix(in srgb, var(--st-primary) 72%, #0891b2);
	font-size: 0.78rem;
	font-weight: 700;
	line-height: 1;
	white-space: nowrap;
}

.apptook-stitch .apptook-my-subscription__count-pill .material-symbols-outlined {
	font-size: 0.95rem;
}

.apptook-stitch .apptook-my-subscription__panel > p {
	margin: 1rem 0 0;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-my-subscription__list {
	margin-top: 1rem;
	display: grid;
	gap: 0.75rem;
}

.apptook-stitch .apptook-my-subscription__item {
	background: var(--st-surface-container-lowest);
	border: 1px solid #edf2f2;
	border-radius: 2rem;
	padding: 2rem;
}

.apptook-stitch .apptook-my-subscription__item-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
}

.apptook-stitch .apptook-my-subscription__item-head-main {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	min-width: 0;
}

.apptook-stitch .apptook-my-subscription__product-thumb {
	width: 48px;
	height: 48px;
	object-fit: cover;
	border-radius: 0.9rem;
	border: 1px solid #e2e8f0;
	background: #fff;
	flex: 0 0 48px;
}

.apptook-stitch .apptook-my-subscription__item-head h3 {
	margin: 0;
	font-size: 1.05rem;
	line-height: 1.25;
}

.apptook-stitch .apptook-my-subscription__item-head p {
	margin: 0.2rem 0 0;
	font-size: 0.78rem;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-my-subscription__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.2rem;
	padding: 0.28rem 0.6rem;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 700;
	white-space: nowrap;
}

.apptook-stitch .apptook-my-subscription__badge .material-symbols-outlined {
	font-size: 0.9rem;
}

.apptook-stitch .apptook-my-subscription__badge.is-active {
	background: #dcfce7;
	color: #166534;
}

.apptook-stitch .apptook-my-subscription__badge.is-inactive {
	background: #fef3c7;
	color: #92400e;
}

.apptook-stitch .apptook-my-subscription__badge.is-cancelled {
	background: #fee2e2;
	color: #991b1b;
}

.apptook-stitch .apptook-my-subscription__item-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.6rem;
}

@media (min-width: 680px) {
	.apptook-stitch .apptook-my-subscription__item-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.apptook-stitch .apptook-my-subscription__timeline {
	margin: 0.9rem 0 0;
	padding: 0.9rem;
	border-radius: 1.5rem;
	border: 1px solid #dcefee;
	background: linear-gradient(180deg, #fbffff 0%, #f7fbfb 100%);
	display: grid;
	gap: 0.55rem;
}

.apptook-stitch .apptook-my-subscription__timeline-step {
	position: relative;
	display: grid;
	grid-template-columns: 2rem 1fr;
	align-items: center;
	gap: 0.65rem;
	color: #94a3b8;
	font-size: 0.84rem;
	font-weight: 700;
}

.apptook-stitch .apptook-my-subscription__timeline-step:not(:last-child)::after {
	content: "";
	position: absolute;
	left: 1rem;
	top: 2rem;
	bottom: -0.55rem;
	width: 2px;
	background: #dbe6ef;
}

.apptook-stitch .apptook-my-subscription__timeline-step.is-done:not(:last-child)::after {
	background: #99f6e4;
}

.apptook-stitch .apptook-my-subscription__timeline-number {
	position: relative;
	z-index: 1;
	width: 2rem;
	height: 2rem;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #e2e8f0;
	color: #64748b;
	font-size: 0.78rem;
}

.apptook-stitch .apptook-my-subscription__timeline-label {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.apptook-stitch .apptook-my-subscription__timeline-step.is-done {
	color: #0f766e;
}

.apptook-stitch .apptook-my-subscription__timeline-step.is-done .apptook-my-subscription__timeline-number {
	background: #ccfbf1;
	color: #0f766e;
}

.apptook-stitch .apptook-my-subscription__timeline-step.is-current {
	color: #0f172a;
}

.apptook-stitch .apptook-my-subscription__timeline-step.is-current .apptook-my-subscription__timeline-number {
	background: var(--st-primary);
	color: #ffffff;
	box-shadow: 0 8px 18px rgba(65, 225, 227, 0.28);
}

@media (min-width: 860px) {
	.apptook-stitch .apptook-my-subscription__timeline {
		grid-template-columns: repeat(5, minmax(0, 1fr));
		gap: 0;
	}
	.apptook-stitch .apptook-my-subscription__timeline-step {
		grid-template-columns: 1fr;
		justify-items: center;
		text-align: center;
		gap: 0.42rem;
		min-width: 0;
	}
	.apptook-stitch .apptook-my-subscription__timeline-step:not(:last-child)::after {
		left: calc(50% + 1rem);
		right: calc(-50% + 1rem);
		top: 1rem;
		bottom: auto;
		width: auto;
		height: 2px;
	}
	.apptook-stitch .apptook-my-subscription__timeline-label {
		max-width: 100%;
	}
}

.apptook-stitch .apptook-my-subscription__meta-card {
	background: rgb(239 245 244 / var(--tw-bg-opacity, 1));
	border: 1px solid #e5e7eb;
	border-radius: 1.5rem;
	padding: 1.2rem 1.5rem;
}

.apptook-stitch .apptook-my-subscription__meta-label {
	margin: 0;
	font-size: 0.72rem;
	line-height: 1.1;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-my-subscription__meta-value {
	margin: 0.4rem 0 0;
	font-size: 0.88rem;
	font-weight: 600;
	line-height: 1.15;
	color: var(--st-on-surface);
}

.apptook-stitch .apptook-my-subscription__meta-value--alert.is-safe {
	color: #166534;
}

.apptook-stitch .apptook-my-subscription__meta-value--alert.is-warning {
	color: #92400e;
}

.apptook-stitch .apptook-my-subscription__meta-value--alert.is-danger {
	color: #991b1b;
}

.apptook-stitch .apptook-my-subscription__license-row {
	margin: 0.75rem 0 0;
	padding-top: 1.5rem;
	border-top: 1px solid #eef3f3;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.9rem;
}

.apptook-stitch .apptook-my-subscription__license-row .apptook-my-subscription__license {
	flex: 1;
}

.apptook-stitch .apptook-my-subscription__license {
	margin: 0;
	font-size: 0.8rem;
	color: var(--st-on-surface-variant);
	overflow-wrap: anywhere;
}

.apptook-stitch .apptook-my-subscription__license code {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 0.76rem;
	padding: 0.1rem 0.35rem;
}

.apptook-stitch .apptook-my-subscription__delivery-card {
	margin-top: 1rem;
	padding: 1rem;
	border-radius: 20px;
	border: 1px solid #dcefee;
	background: linear-gradient(180deg, #fbffff 0%, #f4fbfa 100%);
}

.apptook-stitch .apptook-my-subscription__delivery-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 0.9rem;
}

.apptook-stitch .apptook-my-subscription__delivery-head p {
	margin: 0 0 0.25rem;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-my-subscription__delivery-head strong {
	font-size: 1rem;
	color: var(--st-on-surface);
}

.apptook-stitch .apptook-my-subscription__delivery-head .material-symbols-outlined {
	font-size: 1.5rem;
	color: #0f9488;
}

.apptook-stitch .apptook-my-subscription__delivery-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.75rem;
}

.apptook-stitch .apptook-my-subscription__delivery-line {
	padding: 0.85rem 0.95rem;
	border-radius: 16px;
	background: #fff;
	border: 1px solid #e5f1f1;
	min-width: 0;
}

.apptook-stitch .apptook-my-subscription__delivery-line.is-wide {
	grid-column: 1 / -1;
}

.apptook-stitch .apptook-my-subscription__delivery-line span {
	display: block;
	margin-bottom: 0.4rem;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-my-subscription__delivery-line code,
.apptook-stitch .apptook-my-subscription__delivery-line p {
	margin: 0;
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 0.83rem;
	color: var(--st-on-surface);
	white-space: pre-wrap;
	word-break: break-word;
}

@media (max-width: 782px) {
	.apptook-stitch .apptook-my-subscription__delivery-grid {
		grid-template-columns: 1fr;
	}

	border-radius: 0.4rem;
	background: #f1f5f9;
	color: #0f172a;
}

.apptook-stitch .apptook-my-subscription__howto-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 10px;
	height: 34px;
	padding: 0 0.9rem;
	border-radius: 999px;
	border: 1px solid #14b8a6;
	background: #ccfbf1;
	color: #0f766e;
	font-size: 0.8rem;
	font-weight: 700;
	text-decoration: none;
	white-space: nowrap;
	transition: all 0.18s ease;
}

.apptook-stitch .apptook-my-subscription__howto-btn:hover {
	background: #99f6e4;
	border-color: #0d9488;
	color: #115e59;
}

.apptook-stitch .apptook-my-subscription__summary {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: grid;
	gap: 0.7rem;
}

.apptook-stitch .apptook-my-subscription__summary li {
	display: flex;
	justify-content: space-between;
	gap: 0.75rem;
	font-size: 0.9rem;
}

.apptook-stitch .apptook-my-subscription__summary span {
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-my-subscription__summary strong {
	color: var(--st-on-surface);
	font-weight: 700;
}

.apptook-stitch .apptook-my-subscription__summary strong.is-active {
	color: #166534;
}

.apptook-stitch .apptook-my-subscription__summary strong.is-inactive {
	color: #92400e;
}

.apptook-stitch .apptook-my-subscription__summary strong.is-cancelled {
	color: #991b1b;
}

.apptook-stitch .apptook-my-subscription__guest-actions {
	margin-top: 1rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	justify-content: center;
}

.apptook-stitch .apptook-my-subscription__btn,
.apptook-stitch .apptook-my-subscription__btn-secondary {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	text-decoration: none;
	min-width: 148px;
}

.apptook-stitch .apptook-my-subscription a:focus-visible,
.apptook-stitch .apptook-my-subscription button:focus-visible {
	outline: 2px solid var(--st-primary);
	outline-offset: 2px;
}

/* ---- Order History page ---- */
.apptook-stitch .apptook-order-history {
	background: var(--st-surface);
	padding-top: 8.2rem;
	padding-bottom: 0;
}

.apptook-stitch .apptook-order-history__container {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	margin-top: 50px;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	min-height: calc(100vh - 13.5rem);
	display: flex;
	flex-direction: column;
	padding-bottom: 0;
}

.apptook-stitch .apptook-order-history__head {
	margin-bottom: 1.5rem;
}

.apptook-stitch .apptook-order-history__head--with-action {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
}

.apptook-stitch .apptook-order-history__title {
	margin: 0;
	font-size: clamp(1.8rem, 2.8vw, 2.5rem);
	line-height: 1.2;
	color: var(--st-on-surface);
}

.apptook-stitch .apptook-order-history__subtitle {
	margin: 0.5rem 0 0;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-order-history__panel {
	background: #fff;
	border: 1px solid #e8efef;
	border-radius: 2rem;
	padding: 1rem;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

@media (min-width: 768px) {
	.apptook-stitch .apptook-order-history__panel {
		padding: 1.25rem;
	}
}

.apptook-stitch .apptook-order-history__panel--empty,
.apptook-stitch .apptook-order-history__panel--error,
.apptook-stitch .apptook-order-history--guest .apptook-order-history__panel {
	text-align: center;
	padding: 2rem 1.25rem;
}

.apptook-stitch .apptook-order-history__panel--error {
	border-color: #fecaca;
	background: #fff5f5;
}

.apptook-stitch .apptook-order-history__panel h2 {
	margin: 0;
	font-size: 1.2rem;
	line-height: 1.3;
}

.apptook-stitch .apptook-order-history__panel h3 {
	margin: 0;
	font-size: 1.05rem;
	line-height: 1.3;
}

.apptook-stitch .apptook-order-history__panel p {
	margin: 0.4rem 0 0;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-order-history__actions {
	margin-top: 1rem;
	display: flex;
	justify-content: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.apptook-stitch .apptook-order-history__panel--filter {
	margin-bottom: 1rem;
}

.apptook-stitch .apptook-order-history__filter-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 1rem;
}

.apptook-stitch .apptook-order-history__filter-head h3 {
	margin-bottom: 0.2rem;
}

.apptook-stitch .apptook-order-history__filter-head p {
	margin: 0;
	font-size: 0.86rem;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-order-history__all-btn {
	appearance: none;
	border: 1px solid color-mix(in srgb, var(--st-primary) 48%, #d7e1ea);
	border-radius: 999px;
	background: #fff;
	color: #0f4d57;
	font: inherit;
	font-size: 0.86rem;
	font-weight: 800;
	padding: 0.62rem 1rem;
	cursor: pointer;
	white-space: nowrap;
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.apptook-stitch .apptook-order-history__all-btn:hover,
.apptook-stitch .apptook-order-history__all-btn.is-active {
	background: var(--st-primary);
	color: #073033;
	box-shadow: 0 14px 28px rgba(65, 225, 227, 0.24);
	transform: translateY(-1px);
}

.apptook-stitch .apptook-order-history__filters {
	margin-top: 0.85rem;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.75rem;
}

.apptook-stitch .apptook-order-history__filters--monitor-style {
	align-items: end;
	grid-template-columns: minmax(160px, 0.9fr) repeat(2, minmax(150px, 1fr)) auto;
}

.apptook-stitch .apptook-order-history__filters label {
	display: block;
	margin-bottom: 0.35rem;
	font-size: 0.78rem;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-order-history__date-input,
.apptook-stitch .apptook-order-history__select {
	width: 100%;
	min-height: 46px;
	padding: 0.65rem 0.9rem;
	border-radius: 2rem;
	border: 1px solid #d7e1ea;
	background: #fff;
	color: #334155;
	font: inherit;
	font-weight: 600;
	cursor: pointer;
	accent-color: var(--st-primary);
}

.apptook-stitch .apptook-order-history__date-input:focus,
.apptook-stitch .apptook-order-history__date-input:focus-visible,
.apptook-stitch .apptook-order-history__select:focus,
.apptook-stitch .apptook-order-history__select:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px rgba(65, 225, 227, 0.22);
	border-color: color-mix(in srgb, var(--st-primary) 46%, #d7e1ea);
}

.apptook-stitch .apptook-order-history__date-input::-webkit-calendar-picker-indicator {
	cursor: pointer;
	opacity: 0.9;
	filter: saturate(0.85) contrast(1.05);
}

.apptook-stitch .apptook-order-history__filter-actions {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.apptook-stitch .apptook-order-history__filter-apply,
.apptook-stitch .apptook-order-history__filter-clear {
	min-height: 46px;
	padding: 0.65rem 1rem;
	border-radius: 999px;
	border: 1px solid #d7e1ea;
	font-weight: 500;
	cursor: pointer;
}

.apptook-stitch .apptook-order-history__filter-apply {
	border-color: color-mix(in srgb, var(--st-primary) 65%, #d7e1ea);
	background: var(--st-primary);
	color: #073642;
}

.apptook-stitch .apptook-order-history__filter-clear {
	background: #fff;
	color: #334155;
}

.apptook-stitch .apptook-order-history__tabs {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin: 0 0 1rem;
}

.apptook-stitch .apptook-order-history__tabs a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 0.45rem 0.9rem;
	border-radius: 999px;
	border: 1px solid #d7e1ea;
	background: #fff;
	color: #334155;
	font-weight: 500;
	text-decoration: none;
}

.apptook-stitch .apptook-order-history__tabs a.is-active {
	border-color: color-mix(in srgb, var(--st-primary) 60%, #d7e1ea);
	background: color-mix(in srgb, var(--st-primary) 18%, #ffffff);
	color: #073642;
}

.apptook-stitch .apptook-order-history__date-input::-webkit-datetime-edit,
.apptook-stitch .apptook-order-history__date-input::-webkit-datetime-edit-fields-wrapper,
.apptook-stitch .apptook-order-history__date-input::-webkit-datetime-edit-text,
.apptook-stitch .apptook-order-history__date-input::-webkit-datetime-edit-month-field,
.apptook-stitch .apptook-order-history__date-input::-webkit-datetime-edit-day-field,
.apptook-stitch .apptook-order-history__date-input::-webkit-datetime-edit-year-field {
	color: #334155;
}

.apptook-stitch .apptook-order-history__date-input.is-all-time {
	background: #f8fafc;
	color: #94a3b8;
}

.apptook-order-calendar {
	position: absolute;
	z-index: 10000;
	width: min(360px, calc(100vw - 1.5rem));
	max-width: calc(100vw - 1.5rem);
	box-sizing: border-box;
	background: #fff;
	border: 1px solid color-mix(in srgb, var(--st-primary) 28%, #d7e1ea);
	border-radius: 1.35rem;
	box-shadow: 0 22px 48px rgba(15, 23, 42, 0.16);
	padding: 0.95rem;
}

.apptook-order-calendar__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	margin-bottom: 0.6rem;
}

.apptook-order-calendar__head strong {
	font-size: 0.9rem;
	font-weight: 700;
	color: #1e293b;
}

.apptook-order-calendar__head button {
	width: 34px;
	height: 34px;
	border: 0;
	border-radius: 999px;
	background: color-mix(in srgb, var(--st-primary) 12%, var(--st-surface-container-low));
	color: #334155;
	font-size: 1.08rem;
	font-weight: 800;
	cursor: pointer;
}

.apptook-order-calendar__head button:hover {
	background: #dffbfb;
	color: #0f172a;
}

.apptook-order-calendar__week,
.apptook-order-calendar__grid {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 0.38rem;
}

.apptook-order-calendar__week {
	margin-bottom: 0.35rem;
}

.apptook-order-calendar__week span {
	text-align: center;
	font-size: 0.72rem;
	font-weight: 600;
	color: #64748b;
}

.apptook-order-calendar__day,
.apptook-order-calendar__spacer {
	width: 100%;
	aspect-ratio: 1 / 1;
	min-height: 34px;
}

.apptook-order-calendar__day {
	border: 0;
	border-radius: 999px;
	background: transparent;
	color: #334155;
	font-size: 0.84rem;
	font-weight: 700;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	justify-self: stretch;
	transition: background-color 0.16s ease, color 0.16s ease, transform 0.12s ease, box-shadow 0.16s ease;
}

.apptook-order-calendar__day:hover {
	background: color-mix(in srgb, var(--st-primary) 18%, #fff);
	color: #0f172a;
	transform: translateY(-1px);
}

.apptook-order-calendar .apptook-order-calendar__day.is-today,
.apptook-order-calendar .apptook-order-calendar__day[aria-current="date"] {
	background-color: var(--apptook-calendar-primary, var(--st-primary, #81D8D0)) !important;
	background: var(--apptook-calendar-primary, var(--st-primary, #81D8D0)) !important;
	color: #ffffff !important;
	border-radius: 999px !important;
	box-shadow: 0 8px 18px color-mix(in srgb, var(--st-primary) 34%, transparent) !important;
}

.apptook-order-calendar .apptook-order-calendar__day.is-active,
.apptook-order-calendar .apptook-order-calendar__day[aria-current="true"],
.apptook-order-calendar .apptook-order-calendar__day.is-today.is-active {
	background-color: var(--apptook-calendar-primary, var(--st-primary, #81D8D0)) !important;
	background: var(--apptook-calendar-primary, var(--st-primary, #81D8D0)) !important;
	color: #ffffff !important;
	border-radius: 999px !important;
	box-shadow: 0 8px 18px color-mix(in srgb, var(--apptook-calendar-primary, var(--st-primary, #81D8D0)) 42%, transparent), inset 0 0 0 2px rgba(255, 255, 255, 0.65) !important;
}

.apptook-order-calendar .apptook-order-calendar__day.is-today:not(.is-active),
.apptook-order-calendar .apptook-order-calendar__day[aria-current="date"]:not(.is-active) {
	opacity: 0.58;
	filter: saturate(0.72);
}

.apptook-stitch .apptook-order-history__btn,
.apptook-stitch .apptook-order-history__btn-secondary {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	text-decoration: none;
	min-width: 148px;
}

.apptook-stitch .apptook-order-history__table-wrap {
	overflow-x: auto;
}

.apptook-stitch .apptook-order-history__table {
	width: 100%;
	border-collapse: collapse;
	min-width: 720px;
}

.apptook-stitch .apptook-order-history__table th,
.apptook-stitch .apptook-order-history__table td {
	padding: 0.9rem 0.75rem;
	text-align: left;
	border-bottom: 1px solid #eef3f3;
	font-size: 0.9rem;
}

.apptook-stitch .apptook-order-history__table th {
	color: var(--st-on-surface-variant);
	font-weight: 700;
	font-size: 0.82rem;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.apptook-stitch .apptook-order-history__badge {
	display: inline-flex;
	align-items: center;
	padding: 0.3rem 0.65rem;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 700;
}

.apptook-stitch .apptook-order-history__badge.is-paid {
	background: #dcfce7;
	color: #166534;
}

.apptook-stitch .apptook-order-history__badge.is-pending {
	background: #fef3c7;
	color: #92400e;
}

.apptook-stitch .apptook-order-history__badge.is-cancelled {
	background: #fee2e2;
	color: #991b1b;
}

.apptook-stitch .apptook-order-history__empty {
	margin: 0.85rem 0 0;
	font-size: 0.9rem;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-order-history__summary-grid {
	margin-top: 1rem;
	padding-top: 0.9rem;
	border-top: 1px solid #eef3f3;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.75rem;
}

.apptook-stitch .apptook-order-history__summary-box {
	padding: 0.8rem;
	border-radius: 2rem;
	background: var(--st-surface-container-low);
}

.apptook-stitch .apptook-order-history__summary-box p {
	margin: 0;
	font-size: 0.76rem;
	color: var(--st-on-surface-variant);
}

.apptook-stitch .apptook-order-history__summary-box strong {
	display: block;
	margin-top: 0.2rem;
	font-size: 1.1rem;
	font-weight: 500;
	line-height: 1.2;
	color: var(--st-on-surface);
}

.apptook-stitch .apptook-order-history__summary-box--highlight {
	background: color-mix(in srgb, var(--st-primary) 12%, #fff);
	border: 1px solid color-mix(in srgb, var(--st-primary) 26%, #dbe5e5);
}

.apptook-stitch .apptook-order-history__summary-box--highlight strong {
	color: var(--st-primary);
}

.apptook-stitch .apptook-order-history a:focus-visible,
.apptook-stitch .apptook-order-history button:focus-visible {
	outline: 2px solid var(--st-primary);
	outline-offset: 2px;
}

@media (max-width: 767px) {
	.apptook-stitch .apptook-order-history__head--with-action {
		flex-direction: column;
		align-items: flex-start;
	}

	.apptook-stitch .apptook-order-history__filter-head {
		flex-direction: column;
	}
	.apptook-stitch .apptook-order-history__filters,
	.apptook-stitch .apptook-order-history__filters--monitor-style,
	.apptook-stitch .apptook-order-history__summary-grid {
		grid-template-columns: 1fr;
	}

	.apptook-stitch .apptook-order-history__container {
		min-height: calc(100vh - 11rem);
	}
}

/* ---- Product Detail (Stitch-like) ---- */
.apptook-stitch.apptook-ds-product-detail-page {
	background: var(--st-surface);
	padding-top: 6.8rem;
	padding-bottom: 4.5rem;
	width: 100%;
	max-width: none;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-back,
.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-card,
.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-icon-wrap,
.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-thumb,
.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-meta-item,
.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-type-chip,
.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-buy-btn,
.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-chat-btn {
	border-radius: 2rem !important;
}

.apptook-stitch .apptook-ds-pd-wrap {
	max-width: 1280px;
	margin: 0 auto;
	padding: 2.2rem 1.25rem 5rem;
}

.apptook-stitch .apptook-ds-pd-back-wrap {
	margin-bottom: 1.25rem;
}

.apptook-stitch .apptook-ds-pd-back {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.55rem 0.95rem;
	border-radius: 0.75rem;
	border: 1px solid #e2e8f0;
	background: #fff;
	font-size: 0.88rem;
	font-weight: 600;
	color: #475569;
	text-decoration: none;
	transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.apptook-stitch .apptook-ds-pd-back:hover {
	background: var(--st-surface-container-low);
	color: var(--st-primary);
	border-color: color-mix(in srgb, var(--st-primary) 28%, #e2e8f0);
	box-shadow: 0 6px 14px rgba(65, 225, 227, 0.16);
}

.apptook-stitch .apptook-ds-pd-back:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px rgba(65, 225, 227, 0.25);
}
.apptook-stitch .apptook-ds-pd-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.78fr) minmax(0, 1fr);
	gap: 1.35rem;
	align-items: start;
}

.apptook-stitch .apptook-ds-pd-main {
	display: grid;
	gap: 1.6rem;
}

.apptook-stitch .apptook-ds-pd-card {
	background: #fff;
	border: 1px solid #f1f5f9;
	border-radius: 2rem;
	box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
	padding: 1.55rem;
}

.apptook-stitch .apptook-ds-pd-hero-head {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	margin-bottom: 1rem;
}

.apptook-stitch .apptook-ds-pd-icon-wrap {
	width: 64px;
	height: 64px;
	border-radius: 1rem;
	background: transparent;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	flex-shrink: 0;
}

.apptook-stitch .apptook-ds-pd-icon-wrap .material-symbols-outlined {
	font-size: 2rem;
}

.apptook-stitch .apptook-ds-pd-thumb {
	width: 100%;
	height: 100%;
	object-fit: contain;
	border-radius: 0.7rem;
}

.apptook-stitch .apptook-ds-pd-kicker {
	margin: 0;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #0ea5a9;
}

.apptook-stitch .apptook-ds-pd-title {
	margin: 0.12rem 0 0;
	font-size: clamp(1.65rem, 2.2vw, 2.1rem);
	line-height: 1.16;
	letter-spacing: -0.014em;
}

.apptook-stitch .apptook-ds-pd-meta-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.75rem;
	margin-bottom: 1rem;
}

.apptook-stitch .apptook-ds-pd-meta-item {
	background: var(--st-surface-container-low);
	border-radius: 1.1rem;
	padding: 0.95rem 1.1rem;
	min-height: 80px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.apptook-stitch .apptook-ds-pd-meta-item p {
	margin: 0 0 0.28rem;
	font-size: 0.8rem;
	color: #64748b;
}

.apptook-stitch .apptook-ds-pd-meta-item strong {
	font-size: 1.08rem;
	color: #334155;
}

.apptook-stitch .apptook-ds-pd-desc {
	margin: 0;
	color: #475569;
	line-height: 1.65;
}

.apptook-stitch .apptook-ds-pd-section-title {
	margin: 0 0 0.8rem;
	font-size: 1.25rem;
}

.apptook-stitch .apptook-ds-pd-feature-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 0.65rem;
}

.apptook-stitch .apptook-ds-pd-feature-list li {
	display: flex;
	align-items: flex-start;
	gap: 0.45rem;
	color: #475569;
}

.apptook-stitch .apptook-ds-pd-feature-list .material-symbols-outlined {
	font-size: 1.1rem;
	color: var(--st-primary);
	margin-top: 0.08rem;
}

.apptook-stitch .apptook-ds-pd-side {
	position: sticky;
	top: 8.35rem;
	align-self: start;
	height: max-content;
}

body.admin-bar .apptook-stitch .apptook-ds-pd-side {
	top: calc(8.35rem + 32px);
}

@media screen and (max-width: 782px) {
	body.admin-bar .apptook-stitch .apptook-ds-pd-side {
		top: calc(8.35rem + 46px);
	}
}

.apptook-stitch .apptook-ds-pd-purchase-card {
	position: relative;
	padding: 1rem 1rem 0.95rem;
	border-radius: 1.35rem;
	display: grid;
	gap: 0.72rem;
	align-content: start;
}

.apptook-stitch .apptook-ds-pd-price-label {
	margin: 0 0 0.15rem;
	font-size: 0.78rem;
	color: #64748b;
}

.apptook-stitch .apptook-ds-pd-price {
	font-size: clamp(2rem, 4vw, 2.35rem);
	line-height: 1;
	font-weight: 900;
	letter-spacing: -0.02em;
}

.apptook-stitch .apptook-ds-pd-period {
	margin: 0.25rem 0 1rem;
	font-size: 0.82rem;
	color: #64748b;
}

.apptook-stitch .apptook-ds-pd-static-block {
	margin-bottom: 0.8rem;
}

.apptook-stitch .apptook-ds-pd-static-title {
	margin: 0 0 0.42rem;
	font-size: 0.88rem;
	font-weight: 700;
	color: #334155;
}

.apptook-stitch .apptook-ds-pd-duration-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0.45rem;
}

.apptook-stitch .apptook-ds-pd-duration-pill {
	position: relative;
	min-height: 64px;
	padding: 0.48rem 0.6rem 1.2rem;
	border-radius: 0.95rem !important;
	border: 1.5px solid #e8e8eb;
	background: #f4f4f6;
	color: #13294b;
	font-size: 0.76rem;
	font-weight: 400;
	text-align: center;
	overflow: hidden;
}

.apptook-stitch .apptook-ds-pd-duration-pill .month-title {
	font-weight: 500;
}

.apptook-stitch .apptook-ds-pd-duration-pill::after {
	content: "Subscribe";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	font-size: 11px;
	line-height: 1;
	padding: 0.32rem 0.35rem 0.4rem;
	background: rgba(0, 0, 0, 0.07);
	color: #8f95a3;
	text-align: center;
	font-weight: 600;
}

.apptook-stitch .apptook-ds-pd-duration-pill.is-active {
	border-color: rgb(65, 225, 227);
	background: #ffffff;
	color: rgb(15, 77, 87);
	box-shadow: inset 0 0 0 1px rgba(65, 225, 227, 0.35);
}

.apptook-stitch .apptook-ds-pd-duration-pill.is-active::after {
	background: rgb(65, 225, 227);
	color: rgb(15, 77, 87);
}

.apptook-stitch .apptook-ds-pd-type-chip {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 28px;
	padding: 0.45rem 1.5rem;
	border-radius: 1.75rem;
	border: 1px solid #e2e8f0;
	background: #fff;
	font-size: 0.78rem;
	font-weight: 600;
	color: #475569;
	text-align: center;
}

.apptook-stitch .apptook-ds-pd-type-select-wrap {
	position: relative;
}

.apptook-stitch .apptook-ds-pd-type-select {
	width: 100%;
	padding: 0.95rem 2.5rem 0.95rem 1rem;
	border-radius: 1rem;
	border: 0;
	background: var(--st-surface-container-low);
	color: #334155;
	font-size: 0.92rem;
	font-weight: 600;
	font-family: var(--st-font-text);
	appearance: none;
	-webkit-appearance: none;
	opacity: 1;
}

.apptook-stitch .apptook-ds-pd-type-select:focus {
	outline: none;
	box-shadow: 0 0 0 2px rgba(65, 225, 227, 0.28);
}

.apptook-stitch .apptook-ds-pd-type-select:disabled {
	opacity: 1;
	color: #334155;
	-webkit-text-fill-color: #334155;
	cursor: default;
}

.apptook-stitch .apptook-ds-pd-type-select-wrap .material-symbols-outlined {
	position: absolute;
	right: 0.85rem;
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.15rem;
	color: #64748b;
	pointer-events: none;
}

.apptook-stitch .apptook-ds-pd-buy-btn,
.apptook-stitch .apptook-ds-pd-chat-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 48px;
	border-radius: 1.75rem;
	font-weight: 700;
	font-size: 0.96rem;
	text-decoration: none;
	border: 0;
	cursor: pointer;
}

.apptook-stitch .apptook-ds-pd-buy-btn {
	background: #ff5a5f;
	color: #fff;
	box-shadow: 0 12px 22px rgba(255, 90, 95, 0.28);
	margin: 1rem 0 0.6rem;
}

.apptook-stitch .apptook-ds-pd-buy-btn.is-login {
	background: var(--st-primary);
	box-shadow: 0 10px 20px rgba(65, 225, 227, 0.25);
}

.apptook-stitch .apptook-ds-pd-gate-article {
	max-width: 760px;
	margin: 0 auto;
}

.apptook-stitch .apptook-ds-pd-member-gate {
	text-align: center;
	display: grid;
	justify-items: center;
	gap: 0.9rem;
	padding: clamp(2rem, 5vw, 3.5rem);
}

.apptook-stitch .apptook-ds-pd-member-gate-icon {
	width: 4.5rem;
	height: 4.5rem;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(65, 225, 227, 0.18);
	color: rgb(15, 77, 87);
}

.apptook-stitch .apptook-ds-pd-member-gate-icon .material-symbols-outlined {
	font-size: 2rem;
}

.apptook-stitch .apptook-ds-pd-member-gate-copy {
	max-width: 34rem;
	margin: 0;
	color: #475569;
	font-size: 1rem;
	line-height: 1.65;
	font-weight: 500;
}

.apptook-stitch .apptook-ds-pd-member-gate-actions {
	width: min(100%, 420px);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
	margin-top: 0.4rem;
}

.apptook-stitch .apptook-ds-pd-member-gate-actions .apptook-ds-pd-buy-btn,
.apptook-stitch .apptook-ds-pd-member-gate-actions .apptook-ds-pd-chat-btn {
	margin: 0;
}

.apptook-stitch .apptook-ds-pd-member-gate-actions .apptook-ds-pd-chat-btn:only-child {
	grid-column: 1 / -1;
}

.apptook-stitch .apptook-ds-pd-chat-btn {
	border: 1px solid #e2e8f0;
	background: #fff;
	color: #334155;
}

.apptook-stitch .apptook-ds-pd-config-card {
	border: 1px solid #dce6eb;
	border-radius: 1.6rem;
	background: #fff;
	padding: 1.1rem 1.1rem 0.9rem;
	display: grid;
	gap: 0.9rem;
}

.apptook-stitch .apptook-ds-pd-config-head p {
	margin: 0;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.1;
	color: #1e293b;
}

.apptook-stitch .apptook-ds-pd-config-head span {
	display: block;
	margin-top: 0.24rem;
	font-size: 0.86rem;
	color: #64748b;
}

.apptook-stitch .apptook-ds-pd-duration-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0.45rem;
}

.apptook-stitch .apptook-ds-pd-duration-pill {
	position: relative;
	padding: 0.5rem 0.4rem 1.15rem;
	border-radius: 1rem !important;
	border: 1.5px solid #e8e8eb;
	background: #f4f4f6;
	color: #13294b;
	font-size: 0.76rem;
	font-weight: 500;
	min-height: 62px;
	overflow: hidden;
}

.apptook-stitch .apptook-ds-pd-duration-pill .month-title {
	position: relative;
	z-index: 1;
	font-size: 1rem;
	font-weight: 500;
}

.apptook-stitch .apptook-ds-pd-duration-pill::after {
	content: "Subscribe";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	font-size: 11px;
	line-height: 1;
	padding: 0.32rem 0.3rem 0.4rem;
	background: rgba(0, 0, 0, 0.07);
	color: #8f95a3;
	font-weight: 600;
}

.apptook-stitch .apptook-ds-pd-duration-pill.is-active {
	border-color: rgb(65, 225, 227);
	background: #fff;
	color: rgb(15, 77, 87);
	box-shadow: inset 0 0 0 1px rgba(65, 225, 227, 0.35);
}

.apptook-stitch .apptook-ds-pd-duration-pill.is-active::after {
	background: rgb(65, 225, 227);
	color: rgb(15, 77, 87);
}

.apptook-stitch .apptook-ds-pd-overview-card {
	border: 1px solid #d9cffa;
	border-radius: 1.85rem;
	background: #fbfafc;
	padding: 1.45rem 1.5rem 1.6rem;
	box-shadow: 0 0 0 1px rgba(187, 168, 251, 0.08) inset;
}

.apptook-stitch .apptook-ds-pd-overview-head p {
	margin: 0;
	font-size: 0.86rem;
	line-height: 1.1;
	text-transform: uppercase;
	letter-spacing: 0.11em;
	font-weight: 700;
	color: #6938ef;
}

.apptook-stitch .apptook-ds-pd-overview-head h2 {
	margin: 0.48rem 0 0;
	font-size: 2.05rem;
	line-height: 1.05;
	letter-spacing: -0.025em;
	font-weight: 800;
	color: #0b1735;
}

.apptook-stitch .apptook-ds-pd-overview-head span {
	display: block;
	margin-top: 0.46rem;
	font-size: 0.95rem;
	line-height: 1.5;
	font-weight: 500;
	color: #51607d;
}

.apptook-stitch .apptook-ds-pd-overview-summary {
	margin: 1.25rem 0 0;
	font-size: 1.03rem;
	line-height: 1.68;
	font-weight: 500;
	color: #22304a;
}

.apptook-stitch .apptook-ds-pd-feature-list {
	margin-top: 1.2rem;
	gap: 0.85rem;
}

.apptook-stitch .apptook-ds-pd-feature-list li {
	padding: 0.9rem 1rem;
	border-radius: 999px;
	background: #f9fafc;
	border: 1px solid #dde5f0;
	font-size: 0.98rem;
	line-height: 1.45;
	font-weight: 500;
	color: #253450;
}

.apptook-stitch .apptook-ds-pd-terms-card {
	margin-top: 1.1rem;
	border-color: #fde68a;
	background: linear-gradient(180deg, #fffbeb 0%, #fff 100%);
}

.apptook-stitch details.apptook-ds-pd-terms-card {
	display: block;
}

.apptook-stitch .apptook-ds-pd-terms-summary {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 1rem;
	cursor: pointer;
	list-style: none;
}

.apptook-stitch .apptook-ds-pd-terms-summary::-webkit-details-marker {
	display: none;
}

.apptook-stitch .apptook-ds-pd-terms-toggle {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 999px;
	background: rgba(245, 158, 11, 0.12);
	color: #b45309;
	font-size: 1.85rem;
	line-height: 1;
	transition: transform 0.18s ease, background 0.18s ease;
}

.apptook-stitch details.apptook-ds-pd-terms-card[open] .apptook-ds-pd-terms-toggle {
	transform: rotate(180deg);
	background: rgba(245, 158, 11, 0.18);
}

.apptook-stitch .apptook-ds-pd-terms-preview {
	margin-top: 1rem;
	font-size: 0.98rem;
	line-height: 1.7;
	font-weight: 600;
	color: #5f4b16;
}

.apptook-stitch details.apptook-ds-pd-terms-card[open] .apptook-ds-pd-terms-preview {
	display: none;
}

.apptook-stitch .apptook-ds-pd-terms-content {
	display: none;
	margin-top: 1.15rem;
	font-size: 0.98rem;
	line-height: 1.72;
	font-weight: 500;
	color: #3f3214;
}

.apptook-stitch details.apptook-ds-pd-terms-card[open] .apptook-ds-pd-terms-content {
	display: block;
}

.apptook-stitch .apptook-ds-pd-terms-content p {
	margin: 0 0 0.85rem;
}

.apptook-stitch .apptook-ds-pd-terms-content ul,
.apptook-stitch .apptook-ds-pd-terms-content ol {
	margin: 0.75rem 0 0.95rem 1.35rem;
}

.apptook-stitch .apptook-ds-pd-terms-content li {
	margin-bottom: 0.45rem;
}

.apptook-stitch .apptook-ds-pd-overview-card .apptook-ds-pd-feature-list .material-symbols-outlined {
	font-size: 1rem;
	color: #6d28d9;
	margin-top: 0.03rem;
}

.apptook-stitch .apptook-ds-pd-purchase-card {
	padding: 1.25rem 1.15rem;
	border-radius: 2rem;
	border: 1px solid #e2e8f0;
	background: rgba(255, 255, 255, 0.92);
}

.apptook-stitch .apptook-ds-pd-summary-lines {
	display: grid;
	gap: 0.42rem;
	padding: 0.12rem 0.15rem 0.2rem;
}

.apptook-stitch .apptook-ds-pd-summary-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.65rem;
}

.apptook-stitch .apptook-ds-pd-summary-row:not(.is-grand),
.apptook-stitch .apptook-ds-pd-summary-row:not(.is-grand) .detail-muted-label,
.apptook-stitch .apptook-ds-pd-summary-row:not(.is-grand) .apptook-ds-pd-summary-value {
	color: #64748b;
	font-size: 0.88rem;
}

.apptook-stitch .apptook-ds-pd-summary-row:nth-child(2) {
	padding-bottom: 0.6rem;
	margin-bottom: 0.05rem;
	border-bottom: 1px solid #e2e8f0;
}

.apptook-stitch .apptook-ds-pd-summary-value {
	font-size: 0.95rem;
	font-weight: 500;
	color: #334155;
}

.apptook-stitch .apptook-price-regular {
	display: inline-block;
	margin-right: 0.38rem;
	font-size: 0.78em;
	font-weight: 600;
	color: #94a3b8;
	text-decoration-line: line-through;
	text-decoration-thickness: 2px;
	text-decoration-color: #64748b;
}

.apptook-stitch .apptook-price-sale {
	display: inline-block;
	font-weight: 800;
	color: inherit;
}

.apptook-stitch .apptook-ds-pd-summary-value[data-pd-live-net] {
	display: inline-flex;
	align-items: baseline;
	justify-content: flex-end;
	gap: 0.15rem;
	flex-wrap: wrap;
	text-align: right;
}

.apptook-stitch .apptook-ds-pd-summary-value[data-pd-live-net] .apptook-price-regular {
	font-size: 0.78rem;
}

.apptook-stitch .apptook-ds-pd-summary-value[data-pd-live-net] .apptook-price-sale {
	font-size: 0.98rem;
}

.apptook-stitch .apptook-ds-pd-summary-row.is-grand {
	padding-top: 0.2rem;
}

.apptook-stitch .apptook-ds-pd-summary-total {
	font-size: 1.58rem;
	line-height: 1;
	font-weight: 400;
	color: var(--st-primary);
}

.apptook-stitch .apptook-ds-pd-total-monthly {
	margin: 0.12rem 0 0;
	text-align: right;
	font-size: 0.74rem;
	color: #64748b;
}

.apptook-stitch .apptook-ds-pd-promo-wrap {
	margin-top: 0.55rem;
	margin-bottom: 0.18rem;
	padding: 0;
	border-radius: 1.7rem;
	border: 1px solid #d7dee7;
	background: #fff;
	overflow: hidden;
	transition: none;
}

.apptook-stitch .apptook-ds-pd-promo-wrap.is-open {
	border-radius: 1.7rem;
}

.apptook-stitch .apptook-ds-pd-promo-toggle {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border: 0;
	background: transparent;
	padding: 0.95rem 1rem;
	font-size: 0.82rem;
	font-weight: 700;
	color: #334155;
	cursor: default;
	text-align: left;
	transition: none;
	box-shadow: none;
	filter: none;
}

.apptook-stitch .apptook-ds-pd-promo-panel {
	margin-top: 0;
	padding: 0 0.72rem 0.8rem;
	border: 0;
	background: transparent;
	min-height: 56px;
}

.apptook-stitch .apptook-ds-pd-promo-row {
	display: flex;
	align-items: center;
	gap: 0.45rem;
}

.apptook-stitch .apptook-ds-pd-promo-input {
	flex: 1;
	height: 48px;
	padding: 0 0.95rem;
	border-radius: 999px;
	border: 1px solid #d7dee7;
	background: #f8fafc;
	font-size: 0.94rem;
	font-weight: 700;
	font-family: var(--st-font-text);
	color: #64748b;
}

.apptook-stitch .apptook-ds-pd-promo-input:focus {
	outline: none;
	border-color: #41e1e3;
	box-shadow: 0 0 0 2px rgba(65, 225, 227, 0.2);
}

.apptook-stitch .apptook-ds-pd-promo-apply {
	height: 46px;
	padding: 0 1.05rem;
	border-radius: 999px;
	border: 0;
	background: rgba(65, 225, 227, 0.95);
	color: #fff;
	font-size: 0.9rem;
	font-weight: 700;
	font-family: var(--st-font-text);
}

.apptook-stitch .apptook-ds-pd-buy-btn,
.apptook-stitch .apptook-ds-pd-chat-btn {
	border-radius: 999px;
	min-height: 50px;
	font-size: 0.95rem;
	font-weight: 600;
	transition: background-color 0.18s ease, box-shadow 0.18s ease, transform 0.12s ease, border-color 0.18s ease, color 0.18s ease;
}

.apptook-stitch .apptook-ds-pd-buy-btn {
	background: var(--st-primary);
	box-shadow: 0 12px 24px rgba(65, 225, 227, 0.3);
	margin: 0.65rem 0 0.4rem;
	border-radius: 0.82rem;
}

.apptook-stitch .apptook-ds-pd-buy-btn:hover {
	background: #34d9db;
}

.apptook-stitch .apptook-ds-pd-buy-btn:active {
	transform: scale(0.98);
}

.apptook-stitch .apptook-ds-pd-chat-btn {
	border: 1px solid #e2e8f0;
	background: #ffffff;
	color: #334155;
	border-radius: 0.82rem;
}

.apptook-stitch .apptook-ds-pd-chat-btn:hover {
	background: #f8fafc;
	border-color: #cbd5e1;
	color: #334155;
}

.apptook-stitch .apptook-ds-pd-choice-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
}

.apptook-stitch .apptook-ds-pd-choice-btn {
	padding: 0.45rem 0.72rem;
	border-radius: 0.7rem;
	border: 1px solid #d6dde5;
	background: #ffffff;
	color: #475569;
	font-size: 0.78rem;
	line-height: 1.1;
	font-weight: 500;
	transition: all 0.18s ease;
	cursor: pointer;
	font-family: var(--st-font-text);
}

.apptook-stitch .apptook-ds-pd-choice-btn:hover {
	border-color: #8ee7e9;
	color: #0f4d57;
	background: #f8ffff;
}

.apptook-stitch .apptook-ds-pd-choice-btn.is-active {
	border-color: rgb(65, 225, 227);
	background: rgba(65, 225, 227, 0.16);
	color: rgb(15, 77, 87);
	box-shadow: inset 0 0 0 1px rgba(65, 225, 227, 0.32);
}

.apptook-stitch .apptook-ds-pd-recent-buyer {
	margin-top: 0.86rem;
	padding-top: 0.86rem;
	border-top: 1px solid #edf2f7;
	display: grid;
	gap: 0.55rem;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.5rem;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-head span {
	font-size: 0.72rem;
	font-weight: 600;
	color: #1f2937;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-head a {
	font-size: 0.68rem;
	color: #94a3b8;
	text-decoration: none;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-ticker-wrap {
	overflow: hidden;
	border-radius: 0.85rem;
	background: #f1f5f9;
	padding: 0.45rem 0.55rem;
	position: relative;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-ticker {
	display: flex;
	align-items: center;
	width: 100%;
	white-space: nowrap;
	transform: translateX(0);
	will-change: transform;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-inline-item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	font-size: 0.72rem;
	color: #475569;
	text-align: center;
	min-width: 100%;
	flex: 0 0 100%;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-inline-item .material-symbols-outlined {
	font-size: 1rem;
	color: #f59e0b;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-inline-item strong {
	font-weight: 600;
	color: #1f2937;
}

.apptook-stitch .apptook-ds-pd-recent-buyer-inline-item em {
	font-style: normal;
	color: #64748b;
}

@keyframes apptookPdRecentTicker {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-100%);
	}
}

/* Product Detail sync with code.html template (left main shell) */
.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-main {
	gap: 1.35rem;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-left-shell {
	background: #ffffff;
	border: 1px solid #e6edf2;
	border-radius: 2rem;
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.045);
	padding: 1.5rem 1.55rem;
	display: grid;
	gap: 1.25rem;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-left-shell > .apptook-ds-pd-card {
	margin: 0;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-hero-head {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 0;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-icon-wrap {
	width: 80px;
	height: 80px;
	padding: 0;
	border-radius: 0;
	background: transparent;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-kicker {
	font-size: 0.72rem;
	letter-spacing: 0.09em;
	margin: 0 0 0.25rem;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-title {
	font-size: clamp(2rem, 3.2vw, 2.45rem);
	font-weight: 700;
	line-height: 1.05;
	margin: 0;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-config-card {
	margin-top: 0.15rem;
	border-radius: 1rem;
	padding: 1rem 1rem;
	background: rgba(248, 250, 252, 0.75);
	border: 1px solid #dbe3ea;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-config-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.7rem;
	margin-bottom: 0.35rem;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-config-head p {
	font-size: 0.88rem;
	margin: 0;
	line-height: 1.1;
	font-weight: 600;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-config-head span {
	font-size: 0.66rem;
	line-height: 1.2;
	color: #94a3b8;
	white-space: nowrap;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-static-block {
	margin-bottom: 0.6rem;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-static-title {
	font-size: 0.78rem;
	font-weight: 500;
	margin-bottom: 0.34rem;
	color: #64748b;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-duration-grid {
	display: grid;
	grid-template-columns: repeat(5, 100px);
	grid-auto-rows: 65px;
	gap: 0.48rem;
	justify-content: flex-start;
	max-width: calc((100px * 5) + (0.48rem * 4));
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-duration-pill {
	width: 100px;
	height: 65px;
	min-height: 65px;
	padding: 0.42rem 0.35rem 1.08rem;
	border-radius: 0.7rem !important;
	font-size: 0.72rem;
	font-weight: 500;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-duration-pill .month-title {
	font-size: 0.78rem;
	font-weight: 500;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-duration-pill::after {
	font-size: 9px;
	padding: 0.28rem 0.26rem 0.33rem;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-choice-grid {
	gap: 0.42rem;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-choice-btn {
	padding: 0.45rem 0.78rem;
	border-radius: 0.7rem;
	font-size: 0.76rem;
	font-weight: 500;
	min-height: 32px;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-summary-grand-right {
	text-align: right;
}



.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-recent-buyer-ticker-wrap {
	border-radius: 1rem;
	background: #eef2f6;
}

.apptook-stitch.apptook-ds-product-detail-page .apptook-ds-pd-recent-buyer-inline-item {
	font-size: 0.8rem;
}

/* ---- Blog page (Stitch-like) ---- */
.apptook-stitch.apptook-blog-page {
	background: var(--st-surface);
	padding-top: 6.8rem;
	padding-bottom: 4rem;
}

.apptook-stitch .apptook-blog-main {
	width: 100%;
}

.apptook-stitch .apptook-blog-wrap {
	max-width: 1280px;
	margin: 0 auto;
	padding: 2.2rem 1.25rem 0;
}

.apptook-stitch .apptook-blog-head {
	margin-bottom: 1.15rem;
}

.apptook-stitch .apptook-blog-head h1 {
	margin: 0;
	font-size: clamp(1.9rem, 3vw, 2.5rem);
	line-height: 1.08;
	letter-spacing: -0.02em;
	font-weight: 800;
	color: #0f172a;
}

.apptook-stitch .apptook-blog-head p {
	margin: 0.4rem 0 0;
	font-size: 0.95rem;
	color: #64748b;
}

.apptook-stitch .apptook-blog-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.apptook-stitch .apptook-blog-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid #e8eef4;
	border-radius: 2rem;
	overflow: hidden;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.apptook-stitch .apptook-blog-thumb-link {
	display: block;
	text-decoration: none;
}

.apptook-stitch .apptook-blog-thumb {
	display: block;
	width: 100%;
	height: 230px;
	object-fit: cover;
}

.apptook-stitch .apptook-blog-thumb.is-fallback {
	height: 230px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #edf7f7;
	color: #0f766e;
}

.apptook-stitch .apptook-blog-thumb.is-fallback .material-symbols-outlined {
	font-size: 44px;
}

.apptook-stitch .apptook-blog-content {
	display: grid;
	gap: 0.55rem;
	padding: 1rem 1rem 1.1rem;
}

.apptook-stitch .apptook-blog-date {
	margin: 0;
	font-size: 0.75rem;
	color: #94a3b8;
}

.apptook-stitch .apptook-blog-content h2 {
	margin: 0;
	font-size: 1.2rem;
	line-height: 1.3;
	font-weight: 700;
}

.apptook-stitch .apptook-blog-content h2 a {
	color: #0f172a;
	text-decoration: none;
}

.apptook-stitch .apptook-blog-content h2 a:hover {
	color: var(--st-primary);
}

.apptook-stitch .apptook-blog-excerpt {
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.65;
	color: #475569;
}

.apptook-stitch .apptook-blog-readmore {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	padding: 0.48rem 0.86rem;
	border-radius: 0.75rem;
	background: var(--st-primary);
	color: #fff;
	font-size: 0.82rem;
	font-weight: 600;
	text-decoration: none;
	transition: background-color 0.18s ease, box-shadow 0.18s ease;
}

.apptook-stitch .apptook-blog-readmore:hover {
	background: #34d9db;
	box-shadow: 0 8px 18px rgba(65, 225, 227, 0.25);
}

.apptook-stitch .apptook-blog-empty {
	padding: 1.2rem;
	text-align: center;
	background: #fff;
	border: 1px solid #e8eef4;
	border-radius: 1rem;
	color: #64748b;
}

@media (max-width: 1200px) {
	.apptook-stitch .apptook-blog-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* ---- Blog single ---- */
.apptook-stitch.apptook-blog-single-page {
	padding-bottom: 4.5rem;
}

.apptook-stitch .apptook-blog-single-wrap {
	max-width: 980px;
}

.apptook-stitch .apptook-blog-single-back-wrap {
	margin-bottom: 1rem;
}

.apptook-stitch .apptook-blog-single-article {
	background: #fff;
	border: 1px solid #e8eef4;
	border-radius: 2rem;
	overflow: hidden;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.apptook-stitch .apptook-blog-single-hero {
	background: #edf7f7;
}

.apptook-stitch .apptook-blog-single-thumb {
	display: block;
	width: 100%;
	height: auto;
	max-height: 430px;
	object-fit: cover;
}

.apptook-stitch .apptook-blog-single-content-wrap {
	padding: 1.4rem 1.4rem 1.7rem;
}

.apptook-stitch .apptook-blog-single-title {
	margin: 0.25rem 0 1rem;
	font-size: clamp(1.8rem, 3vw, 2.5rem);
	line-height: 1.14;
	letter-spacing: -0.02em;
	color: #0f172a;
}

.apptook-stitch .apptook-blog-article-content {
	font-size: 1rem;
	line-height: 1.75;
	color: #334155;
}

.apptook-stitch .apptook-blog-article-content p {
	margin-bottom: 1rem;
}

.apptook-stitch .apptook-blog-article-content h1,
.apptook-stitch .apptook-blog-article-content h2,
.apptook-stitch .apptook-blog-article-content h3 {
	margin: 1.1rem 0 0.65rem;
	line-height: 1.3;
	color: #0f172a;
}

.apptook-stitch .apptook-blog-article-content img {
	max-width: 100%;
	height: auto;
	border-radius: 1rem;
}

.apptook-stitch.apptook-support-page .apptook-support-main {
	padding-top: 12rem;
	padding-bottom: 3.25rem;
	background: transparent;
}

.apptook-stitch.apptook-support-page .apptook-support-wrap {
	width: min(1280px, calc(100% - 2rem));
	margin: 0 auto;
}

.apptook-stitch.apptook-support-page .apptook-support-grid {
	display: grid;
	grid-template-columns: 1.35fr 1fr;
	gap: 1.1rem;
}

.apptook-stitch.apptook-support-page .apptook-support-side {
	display: grid;
	gap: 1rem;
}

.apptook-stitch.apptook-support-page .apptook-support-card {
	background: #ffffff;
	border-radius: 1.45rem;
	padding: 1.4rem 1.5rem;
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.045);
}

.apptook-stitch.apptook-support-page .apptook-support-card--primary {
	padding: 1.6rem 1.55rem;
}

.apptook-stitch.apptook-support-page .apptook-support-kicker {
	margin: 0 0 0.2rem;
	font-size: 0.68rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	color: #0ea5a8;
}

.apptook-stitch.apptook-support-page .apptook-support-card h1 {
	margin: 0;
	font-size: 2rem;
	line-height: 1.18;
	color: #0f172a;
}

.apptook-stitch.apptook-support-page .apptook-support-lead {
	margin: 0.8rem 0 1rem;
	color: #475569;
	font-size: 0.96rem;
}

.apptook-stitch.apptook-support-page .apptook-support-meta-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
	margin-bottom: 1rem;
}

.apptook-stitch.apptook-support-page .apptook-support-meta-box {
	background: #eff3f4;
	border-radius: 1rem;
	padding: 0.8rem 1rem;
	display: grid;
	gap: 0.28rem;
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.045);
}

.apptook-stitch.apptook-support-page .apptook-support-meta-box span {
	font-size: 0.75rem;
	color: #64748b;
}

.apptook-stitch.apptook-support-page .apptook-support-meta-box strong {
	font-size: 1rem;
	color: #0f172a;
}

.apptook-stitch.apptook-support-page .apptook-support-line-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	background: #22c55e;
	color: #fff;
	text-decoration: none;
	font-weight: 700;
	border-radius: 999px;
	padding: 0.6rem 1rem;
}

.apptook-stitch.apptook-support-page .apptook-support-card h2 {
	margin: 0 0 0.65rem;
	font-size: 1.35rem;
	color: #0f172a;
}

.apptook-stitch.apptook-support-page .apptook-support-checklist {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 0.55rem;
}

.apptook-stitch.apptook-support-page .apptook-support-checklist li {
	position: relative;
	padding-left: 1.4rem;
	color: #334155;
}

.apptook-stitch.apptook-support-page .apptook-support-checklist li::before {
	content: '✓';
	position: absolute;
	left: 0;
	top: 0;
	color: #14b8a6;
	font-weight: 700;
}

.apptook-stitch.apptook-support-page .apptook-support-faq-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
}

.apptook-stitch.apptook-support-page .apptook-support-faq-tags span {
	background: #f1f5f9;
	color: #334155;
	font-size: 0.8rem;
	font-weight: 600;
	padding: 0.42rem 0.72rem;
	border-radius: 999px;
}

@media (max-width: 1024px) {
	.apptook-stitch.apptook-support-page .apptook-support-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 767px) {
	.apptook-stitch.apptook-support-page .apptook-support-main {
		padding-top: 8.4rem;
	}

	.apptook-stitch.apptook-support-page .apptook-support-wrap {
		width: calc(100% - 1rem);
	}

	.apptook-stitch.apptook-support-page .apptook-support-card h1 {
		font-size: 1.6rem;
	}

	.apptook-stitch.apptook-support-page .apptook-support-meta-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 1024px) {
	.apptook-stitch .apptook-blog-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 767px) {
	.apptook-stitch .st-nav {
		background: rgba(255, 255, 255, 0.95);
	}

	.apptook-stitch .buyer-ticker-track {
		top: 3.7rem;
	}

	body.admin-bar .apptook-stitch .buyer-ticker-track {
		top: calc(3.7rem + 46px);
	}

	body.admin-bar .apptook-stitch .st-nav {
		top: 46px;
	}

	.apptook-stitch .st-nav__mobile-panel {
		display: none;
		position: absolute;
		top: calc(100% + 0.25rem);
		left: 0.75rem;
		right: 0.75rem;
		background: #fff;
		border: 1px solid #e2e8f0;
		border-radius: 0.9rem;
		box-shadow: 0 20px 25px -10px rgba(15, 23, 42, 0.2);
		padding: 0.4rem;
		z-index: 60;
	}

	.apptook-stitch .st-nav__mobile-panel.is-open {
		display: grid;
		gap: 0.2rem;
	}

	.apptook-stitch .st-nav__mobile-panel a {
		display: flex;
		align-items: center;
		min-height: 44px;
		padding: 0.6rem 0.7rem;
		border-radius: 0.65rem;
		font-size: 0.92rem;
		text-decoration: none;
		color: #334155;
		font-weight: 600;
	}

	.apptook-stitch .st-nav__mobile-panel a:hover,
	.apptook-stitch .st-nav__mobile-panel a.is-active,
	.apptook-stitch .st-nav__mobile-panel .current-menu-item > a,
	.apptook-stitch .st-nav__mobile-panel .current_page_item > a,
	.apptook-stitch .st-nav__mobile-panel .current-menu-ancestor > a {
		background: #eff5f4;
		color: #00696b;
	}

	.apptook-stitch .st-nav__inner {
		padding: 0.75rem 0.875rem;
		min-height: 56px;
		gap: 0.5rem;
	}

	.apptook-stitch .st-nav__logo {
		font-size: 1.125rem;
		line-height: 1.2;
		letter-spacing: -0.01em;
		max-width: 48vw;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
		gap: 0.4rem;
	}

	.apptook-stitch .st-nav__logo-img {
		width: 24px;
		height: 24px;
	}

	.apptook-stitch .st-nav__right {
		gap: 0.5rem;
		min-height: 36px;
	}

	.apptook-stitch .st-nav__icons {
		gap: 0.45rem;
		height: 36px;
	}

	.apptook-stitch .st-nav__icon-btn {
		height: 36px;
		min-height: 36px;
	}

	.apptook-stitch .st-nav__icon-btn .material-symbols-outlined {
		font-size: 22px;
	}

	.apptook-stitch .st-nav__dropdown {
		right: -0.25rem;
		margin-top: 0.4rem;
		width: min(88vw, 18rem);
	}

	.apptook-stitch .st-nav__auth {
		display: none;
	}

	.apptook-stitch .st-nav__links {
		display: none;
	}

	.apptook-stitch .st-main {
		padding-top: 7.2rem;
		padding-bottom: 2.5rem;
	}

	.apptook-stitch .apptook-ds-shop,
	.apptook-stitch .apptook-ds-library,
	.apptook-stitch .apptook-st-register {
		padding-top: 7.2rem;
		padding-left: 0.75rem;
		padding-right: 0.75rem;
		padding-bottom: 1.5rem;
	}

	.apptook-stitch .st-hero {
		padding: 2.2rem 0.75rem 1.25rem;
	}

	.apptook-stitch .st-hero__title {
		font-size: clamp(1.55rem, 7vw, 2.1rem);
		margin-bottom: 1.1rem;
		line-height: 1.25;
	}

	.apptook-stitch .st-hero__sub {
		margin: 0 0 1rem;
		font-size: 0.92rem;
	}

	.apptook-stitch .st-search-pill {
		padding: 0.3rem;
		gap: 0.2rem;
	}

	.apptook-stitch .st-search-pill .material-symbols-outlined {
		margin-left: 0.45rem;
		font-size: 1.1rem;
	}

	.apptook-stitch .st-search-input {
		padding: 0.55rem 0.5rem;
		font-size: 0.92rem;
	}

	.apptook-stitch .st-search-btn {
		padding: 0.6rem 0.85rem;
		font-size: 0.86rem;
	}

	.apptook-stitch .st-sort-row {
		padding: 0 0.75rem 0.75rem;
		justify-content: flex-start;
	}

	.apptook-stitch .st-sort-select {
		min-width: 0;
		width: 100%;
	}

	.apptook-stitch .st-cats {
		margin-bottom: 1.25rem;
	}

	.apptook-stitch .st-cats__inner {
		padding: 0.55rem 0.45rem;
	}

	.apptook-stitch .st-cats__tabs {
		gap: 0.25rem;
	}

	.apptook-stitch .category-btn--row,
	.apptook-stitch .category-btn--stack {
		padding: 0.35rem 0.25rem;
		border-radius: 0.72rem;
	}

	.apptook-stitch .st-grid-section {
		padding: 0 0.75rem 1.5rem;
	}

	.apptook-stitch .st-product-grid {
		grid-template-columns: 1fr;
		gap: 0.8rem;
	}

	.apptook-stitch .product-card {
		border-radius: 1.15rem;
	}

	.apptook-stitch .st-card-top {
		padding: 1rem 1rem 0.75rem;
	}

	.apptook-stitch .st-card-title {
		font-size: 1rem;
	}

	.apptook-stitch .st-card-body {
		padding: 0.9rem 1rem 1rem;
	}

	.apptook-stitch .st-footer {
		margin-top: auto;
	}

	.apptook-stitch .st-footer__inner {
		padding: 1rem 0.75rem;
		gap: 0.9rem;
	}

	.apptook-stitch .st-footer__copy {
		font-size: 0.8rem;
	}

	.apptook-stitch.apptook-ds-product-detail-page {
		padding-top: 5.3rem;
		padding-bottom: 2rem;
	}

	.apptook-stitch .apptook-ds-pd-wrap {
		padding: 0 0.75rem;
	}

	.apptook-stitch .apptook-ds-pd-grid {
		grid-template-columns: 1fr;
		gap: 0.9rem;
	}

	.apptook-stitch .apptook-ds-pd-card {
		padding: 1rem;
		border-radius: 2rem;
	}

	.apptook-stitch .apptook-ds-pd-hero-head {
		gap: 0.65rem;
	}

	.apptook-stitch .apptook-ds-pd-icon-wrap {
		width: 52px;
		height: 52px;
		border-radius: 0.8rem;
	}

	.apptook-stitch .apptook-ds-pd-meta-grid {
		grid-template-columns: 1fr;
	}

	.apptook-stitch .apptook-ds-pd-side {
		position: static;
		display: block;
		min-height: 0;
		height: auto;
	}

	.apptook-stitch .apptook-ds-pd-purchase-card {
		position: relative;
		height: auto;
		min-height: 0;
		display: grid;
	}

	.apptook-stitch .apptook-ds-pd-trust {
		margin-top: 1rem;
	}

	.apptook-stitch .apptook-ds-pd-duration-grid {
		grid-template-columns: repeat(2, 100px);
		grid-auto-rows: 65px;
		justify-content: flex-start;
	}

	.apptook-stitch .st-footer__links {
		width: 100%;
		justify-content: center;
		gap: 0.6rem 0.9rem;
	}

	.apptook-stitch .apptook-st-register-card {
		padding: 1.1rem 0.9rem;
		border-radius: 1.1rem;
	}

	.apptook-stitch .apptook-ds-library-list,
	.apptook-stitch .apptook-ds-shop-list {
		gap: 0.7rem;
	}

	.apptook-stitch .apptook-ds-library-item,
	.apptook-stitch .apptook-ds-shop-item {
		padding: 0.8rem;
		border-radius: 0.9rem;
	}

	.apptook-stitch .apptook-ds-key-value {
		font-size: 0.86rem;
		padding: 0.6rem 0.7rem;
		line-height: 1.45;
	}
}

/* Register success (post–email signup) */
.apptook-st-register .apptook-st-register-card--success {
	max-width: 32rem;
	text-align: center;
}

.apptook-st-register .apptook-st-register-success-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 4.5rem;
	height: 4.5rem;
	margin: 0 auto 1.25rem;
	border-radius: 50%;
	background: color-mix(in srgb, var(--st-primary) 18%, transparent);
	color: var(--st-primary);
}

.apptook-st-register .apptook-st-register-success-icon .material-symbols-outlined {
	font-size: 2.25rem;
	font-variation-settings: 'FILL' 1, 'wght' 500;
}

.apptook-st-register .apptook-st-register-success-lead {
	margin-bottom: 0;
	line-height: 1.55;
}

.apptook-st-register .apptook-st-register-steps {
	margin: 1.35rem 0 1.75rem;
	padding: 1rem 1rem 1rem 2.25rem;
	text-align: left;
	background: var(--st-surface-container-low);
	border-radius: 1.25rem;
	color: #475569;
	font-size: 0.9375rem;
	line-height: 1.55;
	counter-reset: apptook-reg-step;
	list-style: none;
}

.apptook-st-register .apptook-st-register-steps li {
	position: relative;
	margin: 0.5rem 0;
	padding-left: 0.25rem;
}

.apptook-st-register .apptook-st-register-steps li::before {
	counter-increment: apptook-reg-step;
	content: counter(apptook-reg-step);
	position: absolute;
	left: -1.65rem;
	top: 0.1rem;
	width: 1.35rem;
	height: 1.35rem;
	border-radius: 50%;
	background: var(--st-primary);
	color: #fff;
	font-size: 0.6875rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}

.apptook-st-register .apptook-st-register-success-actions {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 0.25rem;
}

.apptook-stitch .apptook-st-register a.apptook-st-submit.apptook-st-register-success-primary {
	display: block;
	margin-top: 0;
	text-align: center;
	text-decoration: none;
	box-sizing: border-box;
}

.apptook-st-register .apptook-st-btn-secondary {
	display: block;
	width: 100%;
	box-sizing: border-box;
	padding: 1rem 1.25rem;
	border-radius: 1rem;
	border: 2px solid var(--st-surface-container-high, #e2e8f0);
	background: #fff;
	color: var(--st-on-surface);
	font-weight: 700;
	font-size: 1rem;
	font-family: var(--st-font-text);
	text-align: center;
	text-decoration: none;
	transition: background 0.15s ease, border-color 0.15s ease;
}

.apptook-st-register .apptook-st-btn-secondary:hover {
	background: var(--st-surface-container-low);
	border-color: #cbd5e1;
}

.apptook-st-register .apptook-st-register-success-meta {
	margin-top: 1.5rem;
}
