/*
Theme Name: Tops Wedding
Theme URI: https://topswedding.com/
Description: A wedding-editorial child theme for Kadence. Includes a purpose-built homepage, wedding content hubs, and a warm editorial design system.
Author: Tops Wedding
Author URI: https://topswedding.com/
Template: kadence
Version: 1.8.1
Text Domain: tops-wedding
Requires at least: 6.3
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/

:root {
	--tw-paper: #fcfaf7;
	--tw-white: #ffffff;
	--tw-ink: #1d1918;
	--tw-muted: #756a65;
	--tw-rose: #bd7672;
	--tw-rose-deep: #9e5d59;
	--tw-blush: #f4e9e4;
	--tw-sand: #f6f1eb;
	--tw-line: #e8d9d1;
	--tw-sage: #7c8174;
	--tw-shadow: 0 16px 35px rgba(73, 50, 40, .08);
	--tw-serif: "Cormorant Garamond", Georgia, serif;
	--tw-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Shared typography and parent-theme refinements */
body {
	background: var(--tw-paper);
	color: var(--tw-ink);
	font-family: var(--tw-sans);
}

body .entry-content,
body .site-main,
body .content-area {
	color: var(--tw-ink);
}

body a {
	text-underline-offset: .18em;
}

body .site-header-wrap {
	background: rgba(255,255,255,.96);
	border-bottom: 1px solid rgba(232, 217, 209, .8);
}

body .site-header-row-container-inner {
	min-height: 76px;
}

body .header-navigation .header-menu-container > ul > li > a,
body .header-navigation .header-menu-container > ul > li > .menu-link {
	font-family: var(--tw-sans);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .045em;
	text-transform: uppercase;
}

body .site-branding .site-title,
body .site-branding .site-title a {
	font-family: var(--tw-serif);
	font-size: clamp(1.55rem, 2.3vw, 2.1rem);
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
}

body .site-branding .site-description {
	color: var(--tw-rose);
	font-size: 8px;
	font-weight: 700;
	letter-spacing: .26em;
	text-transform: uppercase;
}

body .site-footer {
	border-top: 1px solid var(--tw-line);
}

/* Homepage */
.tw-home {
	background: var(--tw-paper);
	overflow: hidden;
}

.tw-shell {
	width: min(1180px, calc(100% - 40px));
	margin: 0 auto;
}

.tw-hero {
	position: relative;
	isolation: isolate;
	min-height: min(615px, 78vh);
	display: grid;
	align-items: center;
	background: var(--tw-blush);
}

.tw-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -2;
	background: linear-gradient(90deg, rgba(252,250,247,1) 0%, rgba(252,250,247,.97) 38%, rgba(252,250,247,.25) 64%, rgba(252,250,247,.05) 100%);
}

.tw-hero__media {
	position: absolute;
	inset: 0;
	z-index: -3;
	background-color: #ddc8bd;
	background-position: right center;
	background-size: cover;
	background-repeat: no-repeat;
}

.tw-hero__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 68% 50%, transparent 0, rgba(74, 54, 44, .1) 100%);
}

.tw-hero__inner {
	width: min(1180px, calc(100% - 40px));
	margin: 0 auto;
	padding: 85px 0;
}

.tw-kicker,
.tw-section-kicker {
	margin: 0 0 13px;
	color: var(--tw-rose-deep);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .17em;
	line-height: 1.4;
	text-transform: uppercase;
}

.tw-hero__content {
	width: min(570px, 100%);
}

.tw-hero h1 {
	max-width: 620px;
	margin: 0;
	color: var(--tw-ink);
	font-family: var(--tw-serif);
	font-size: clamp(3.1rem, 5.2vw, 5.55rem);
	font-weight: 500;
	letter-spacing: -.045em;
	line-height: .91;
}

.tw-hero h1 .tw-accent {
	display: block;
	margin-top: .12em;
	color: var(--tw-rose);
	font-style: italic;
	font-weight: 500;
}

.tw-hero__text {
	max-width: 460px;
	margin: 28px 0 0;
	font-size: 15px;
	line-height: 1.7;
}

.tw-button-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 28px;
}

.tw-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 45px;
	padding: 13px 21px;
	border: 1px solid var(--tw-rose);
	background: var(--tw-rose);
	color: #fff;
	font-family: var(--tw-sans);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .11em;
	line-height: 1;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	transition: background .2s ease, border-color .2s ease, transform .2s ease;
}

.tw-button:hover,
.tw-button:focus-visible {
	background: var(--tw-rose-deep);
	border-color: var(--tw-rose-deep);
	color: #fff;
	transform: translateY(-2px);
}

.tw-button--outline {
	background: rgba(255,255,255,.52);
	color: var(--tw-rose-deep);
}

.tw-button--outline:hover,
.tw-button--outline:focus-visible {
	background: #fff;
	color: var(--tw-rose-deep);
}

.tw-section {
	padding: clamp(54px, 7vw, 88px) 0;
}

.tw-section--tight {
	padding-top: 38px;
	padding-bottom: 54px;
}

.tw-section--sand {
	background: var(--tw-sand);
}

.tw-section-heading {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 24px;
}

.tw-section-heading--center {
	display: block;
	margin-bottom: 28px;
	text-align: center;
}

.tw-section-title {
	margin: 0;
	font-family: var(--tw-sans);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: .085em;
	line-height: 1.25;
	text-transform: uppercase;
}

.tw-section-title--large {
	font-family: var(--tw-serif);
	font-size: clamp(2.15rem, 3.15vw, 3.25rem);
	font-weight: 500;
	letter-spacing: -.035em;
	line-height: .98;
	text-transform: none;
}

.tw-section-heading__link,
.tw-read-more {
	color: var(--tw-rose-deep);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .105em;
	line-height: 1.2;
	text-decoration: none;
	text-transform: uppercase;
}

.tw-section-heading__link::after,
.tw-read-more::after {
	content: "→";
	margin-left: 6px;
}

.tw-moments-grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	border: 1px solid var(--tw-line);
	background: var(--tw-white);
}

.tw-moment-card {
	min-width: 0;
	border-right: 1px solid var(--tw-line);
	color: var(--tw-ink);
	text-align: center;
	text-decoration: none;
	transition: background .2s ease, transform .2s ease;
}

.tw-moment-card:last-child { border-right: 0; }
.tw-moment-card:hover,
.tw-moment-card:focus-visible { background: #fffaf7; color: var(--tw-ink); transform: translateY(-3px); }

.tw-card-image {
	position: relative;
	aspect-ratio: 1.11 / 1;
	overflow: hidden;
	background: linear-gradient(135deg, #eeded5, #dec6bb);
}

.tw-card-image img,
.tw-post-card__image img,
.tw-feature-card__image img,
.tw-plan-image img,
.tw-latest-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .45s ease;
}

.tw-moment-card:hover img,
.tw-post-card:hover img,
.tw-feature-card:hover img,
.tw-latest-card:hover img { transform: scale(1.045); }

.tw-moment-card__content {
	padding: 16px 12px 17px;
}

.tw-moment-card__number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	margin-bottom: 10px;
	border: 1px solid var(--tw-rose);
	border-radius: 50%;
	color: var(--tw-rose-deep);
	font-size: 9px;
	font-weight: 700;
}

.tw-moment-card h3 {
	margin: 0;
	font-family: var(--tw-sans);
	font-size: 10px;
	font-weight: 800;
	letter-spacing: .08em;
	line-height: 1.35;
	text-transform: uppercase;
}

.tw-moment-card p {
	margin: 8px 0 0;
	color: var(--tw-muted);
	font-size: 11px;
	line-height: 1.45;
}

.tw-post-grid,
.tw-feature-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.tw-post-card,
.tw-feature-card {
	position: relative;
	min-width: 0;
	overflow: hidden;
	background: var(--tw-white);
	box-shadow: 0 0 0 1px var(--tw-line);
	transition: box-shadow .2s ease, transform .2s ease;
}

.tw-post-card:hover,
.tw-feature-card:hover {
	box-shadow: var(--tw-shadow);
	transform: translateY(-3px);
}

.tw-post-card__image {
	aspect-ratio: .95 / 1;
	overflow: hidden;
	background: linear-gradient(135deg, #e9d9d0, #d9bfaf);
}

.tw-post-card__body {
	padding: 17px 16px 18px;
}

.tw-post-card__eyebrow,
.tw-latest-card__date {
	margin: 0 0 8px;
	color: var(--tw-muted);
	font-size: 9px;
	font-weight: 700;
	letter-spacing: .095em;
	line-height: 1.35;
	text-transform: uppercase;
}

.tw-post-card h3,
.tw-feature-card h3,
.tw-latest-card h3 {
	margin: 0;
	font-family: var(--tw-serif);
	font-size: 21px;
	font-weight: 600;
	letter-spacing: -.02em;
	line-height: 1.04;
}

.tw-post-card h3 a,
.tw-feature-card h3 a,
.tw-latest-card h3 a { color: inherit; text-decoration: none; }

.tw-post-card .tw-read-more,
.tw-feature-card .tw-read-more { display: inline-block; margin-top: 15px; }

.tw-planning {
	display: grid;
	grid-template-columns: .94fr 1.32fr;
	gap: clamp(28px, 6vw, 76px);
	align-items: center;
}

.tw-plan-image {
	aspect-ratio: .95 / 1;
	overflow: hidden;
	background: linear-gradient(135deg, #e5d9ca, #d1bfb0);
}

.tw-planning__content { padding: 15px 0; }
.tw-planning__content .tw-section-kicker { text-align: center; }
.tw-planning__content .tw-section-title { max-width: 455px; margin: 0 auto; text-align: center; }

.tw-plan-links {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
	margin-top: 31px;
}

.tw-plan-link {
	color: var(--tw-ink);
	text-decoration: none;
}

.tw-plan-link__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 33px;
	height: 33px;
	margin-bottom: 10px;
	border: 1px solid var(--tw-rose);
	color: var(--tw-rose-deep);
	font-size: 13px;
	font-weight: 700;
}

.tw-plan-link h3 {
	margin: 0;
	font-size: 11px;
	font-weight: 800;
	line-height: 1.35;
}

.tw-plan-link p {
	margin: 7px 0 0;
	color: var(--tw-muted);
	font-size: 11px;
	line-height: 1.45;
}

.tw-planning__cta { display: flex; justify-content: center; margin-top: 30px; }

.tw-feature-card__image {
	aspect-ratio: 1.25 / 1;
	overflow: hidden;
	background: linear-gradient(135deg, #eadad0, #d5bbac);
}

.tw-feature-card__body {
	padding: 15px 16px 18px;
	text-align: center;
}

.tw-feature-card h3 { font-size: 19px; }

.tw-latest-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.tw-latest-card {
	display: grid;
	grid-template-columns: 88px minmax(0, 1fr);
	gap: 13px;
	align-items: start;
	color: var(--tw-ink);
	text-decoration: none;
}

.tw-latest-card__image {
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: linear-gradient(135deg, #eaded6, #d7c1b5);
}

.tw-latest-card h3 { font-size: 17px; line-height: 1.03; }
.tw-latest-card .tw-read-more { display: inline-block; margin-top: 10px; }

.tw-newsletter {
	padding: 28px 0;
	border-top: 1px solid var(--tw-line);
	background: #f7eee9;
}

.tw-newsletter__inner {
	display: grid;
	grid-template-columns: 1fr minmax(280px, .95fr) auto;
	gap: 22px;
	align-items: center;
}

.tw-newsletter__title {
	margin: 0;
	font-family: var(--tw-serif);
	font-size: 29px;
	font-weight: 600;
	letter-spacing: -.02em;
	line-height: 1;
}

.tw-newsletter__text {
	margin: 6px 0 0;
	color: var(--tw-muted);
	font-size: 12px;
	line-height: 1.45;
}

.tw-newsletter form,
.tw-newsletter .wpforms-form,
.tw-newsletter .mc4wp-form { margin: 0; }

.tw-newsletter input[type="email"] {
	width: 100%;
	min-height: 44px;
	padding: 10px 14px;
	border: 1px solid var(--tw-line);
	border-radius: 0;
	background: #fff;
	box-shadow: none;
	font-family: var(--tw-sans);
	font-size: 12px;
}

.tw-newsletter input[type="submit"],
.tw-newsletter button,
.tw-newsletter .wp-element-button {
	min-height: 44px;
	padding: 12px 18px;
	border: 1px solid var(--tw-rose);
	border-radius: 0;
	background: var(--tw-rose);
	color: #fff;
	font-family: var(--tw-sans);
	font-size: 10px;
	font-weight: 800;
	letter-spacing: .1em;
	text-transform: uppercase;
}

.tw-newsletter__note {
	margin: 0;
	color: var(--tw-muted);
	font-size: 11px;
}

/* Hub template */
.tw-hub-hero {
	padding: clamp(64px, 8vw, 106px) 0 clamp(42px, 6vw, 75px);
	background: var(--tw-blush);
	text-align: center;
}

.tw-hub-hero h1 {
	max-width: 760px;
	margin: 0 auto;
	font-family: var(--tw-serif);
	font-size: clamp(3rem, 5vw, 5rem);
	font-weight: 500;
	letter-spacing: -.045em;
	line-height: .92;
}

.tw-hub-hero .entry-content {
	max-width: 620px;
	margin: 22px auto 0;
	color: var(--tw-muted);
	font-size: 16px;
	line-height: 1.7;
}

.tw-hub-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.tw-hub-grid .tw-post-card__image { aspect-ratio: 1.15 / 1; }

/* Article and archive polish */
.single-post .entry-hero-container-inner,
.archive .entry-hero-container-inner,
.blog .entry-hero-container-inner {
	background: var(--tw-blush);
}

.single-post .entry-title,
.archive .entry-title,
.blog .entry-title {
	font-family: var(--tw-serif);
	font-weight: 600;
	letter-spacing: -.035em;
}

.single-post .entry-content {
	font-size: 17px;
	line-height: 1.78;
}

.single-post .entry-content h2,
.single-post .entry-content h3 {
	font-family: var(--tw-serif);
	font-weight: 600;
	letter-spacing: -.025em;
}

.single-post .entry-content h2 { font-size: clamp(2rem, 3vw, 2.75rem); }
.single-post .entry-content h3 { font-size: clamp(1.5rem, 2.3vw, 2rem); }

.single-post .wp-block-quote,
.single-post blockquote {
	margin: 2em 0;
	padding: 24px 28px;
	border-left: 3px solid var(--tw-rose);
	background: var(--tw-blush);
	font-family: var(--tw-serif);
	font-size: 1.45em;
	line-height: 1.2;
}

/* WordPress admin bar safety */
.admin-bar .tw-hero { min-height: calc(min(615px, 78vh) - 32px); }

@media (max-width: 1050px) {
	.tw-moments-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.tw-moment-card:nth-child(3) { border-right: 0; }
	.tw-moment-card:nth-child(-n+3) { border-bottom: 1px solid var(--tw-line); }
	.tw-post-grid,
	.tw-feature-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.tw-plan-links { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.tw-latest-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); row-gap: 28px; }
	.tw-newsletter__inner { grid-template-columns: 1fr 1fr; }
	.tw-newsletter__note { grid-column: 1 / -1; }
}

@media (max-width: 767px) {
	.tw-shell,
	.tw-hero__inner { width: min(100% - 32px, 1180px); }
	.tw-hero { min-height: 655px; align-items: end; }
	.tw-hero::before { background: linear-gradient(180deg, rgba(252,250,247,.08) 0%, rgba(252,250,247,.93) 44%, rgba(252,250,247,1) 67%); }
	.tw-hero__media { background-position: 64% center; }
	.tw-hero__inner { padding: 65px 0 42px; }
	.tw-hero h1 { font-size: clamp(3rem, 14vw, 4.75rem); }
	.tw-hero__text { font-size: 14px; }
	.tw-button-row { gap: 9px; }
	.tw-button { flex: 1 1 100%; }
	.tw-section { padding: 52px 0; }
	.tw-section-heading { align-items: start; flex-direction: column; gap: 10px; }
	.tw-moments-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.tw-moment-card { border-right: 1px solid var(--tw-line) !important; border-bottom: 1px solid var(--tw-line); }
	.tw-moment-card:nth-child(even) { border-right: 0 !important; }
	.tw-moment-card:nth-last-child(-n+2) { border-bottom: 0; }
	.tw-post-grid,
	.tw-feature-grid,
	.tw-hub-grid { grid-template-columns: 1fr; }
	.tw-planning { grid-template-columns: 1fr; gap: 30px; }
	.tw-plan-image { aspect-ratio: 1.28 / 1; }
	.tw-plan-links { gap: 18px 14px; }
	.tw-latest-grid { grid-template-columns: 1fr; }
	.tw-newsletter__inner { grid-template-columns: 1fr; gap: 13px; }
	.tw-newsletter__note { grid-column: auto; }
	.tw-newsletter form .mc4wp-form-fields { display: grid; gap: 10px; }
	.tw-section-title--large { font-size: 2.45rem; }
}

@media (max-width: 480px) {
	.tw-plan-links { grid-template-columns: 1fr; }
	.tw-card-image { aspect-ratio: 1.25 / 1; }
	.tw-moment-card__content { padding: 13px 8px 15px; }
	.tw-moment-card p { display: none; }
}

/* Version 1.1: live hub pages and the dedicated Wedding Picks page */
.tw-hub-hero__intro > :last-child,
.tw-picks-hero__intro > :last-child { margin-bottom: 0; }

.tw-hub-listing .tw-section-heading { margin-bottom: 30px; }

.tw-empty-state {
	grid-column: 1 / -1;
	padding: clamp(34px, 5vw, 58px);
	border: 1px solid var(--tw-line);
	background: var(--tw-white);
	text-align: center;
}

.tw-empty-state h2 {
	margin: 0;
	font-family: var(--tw-serif);
	font-size: clamp(2rem, 3vw, 2.75rem);
	font-weight: 600;
	letter-spacing: -.03em;
}

.tw-empty-state p {
	max-width: 480px;
	margin: 12px auto 0;
	color: var(--tw-muted);
	font-size: 15px;
	line-height: 1.65;
}

.tw-picks-hero {
	padding: clamp(68px, 9vw, 116px) 0 clamp(46px, 6vw, 78px);
	background: linear-gradient(120deg, var(--tw-blush) 0%, #fbf6f1 58%, #f5ece6 100%);
	text-align: center;
}

.tw-picks-hero h1 {
	max-width: 760px;
	margin: 0 auto;
	font-family: var(--tw-serif);
	font-size: clamp(3.25rem, 5.7vw, 5.55rem);
	font-weight: 500;
	letter-spacing: -.05em;
	line-height: .9;
}

.tw-picks-hero__intro {
	max-width: 640px;
	margin: 22px auto 0;
	color: var(--tw-muted);
	font-size: 16px;
	line-height: 1.7;
}

.tw-picks-listing { background: var(--tw-paper); }

.tw-picks-note {
	max-width: 690px;
	margin: 0 auto clamp(34px, 5vw, 58px);
	text-align: center;
}

.tw-picks-note .tw-section-kicker { margin-bottom: 12px; }

.tw-picks-note h2 {
	margin: 0;
	font-family: var(--tw-serif);
	font-size: clamp(2.3rem, 4vw, 3.8rem);
	font-weight: 500;
	letter-spacing: -.04em;
	line-height: .95;
}

.tw-picks-note > p:last-child {
	max-width: 530px;
	margin: 17px auto 0;
	color: var(--tw-muted);
	font-size: 15px;
	line-height: 1.7;
}

body a:focus-visible,
body button:focus-visible,
body input:focus-visible,
body textarea:focus-visible {
	outline: 2px solid var(--tw-rose-deep);
	outline-offset: 3px;
}

@media (max-width: 767px) {
	.tw-picks-hero { padding-top: 70px; }
	.tw-picks-note h2 { font-size: 2.6rem; }
}


/* Version 1.2: scale, intentional image fallbacks, Start Here, and Page-based Wedding Picks */
body .site-header-row-container-inner { min-height: 90px; }
body .site-branding .brand img,
body .site-branding a.brand img,
body .site-branding .site-logo img { max-height: 72px; width: auto; }
body .header-navigation .header-menu-container > ul { column-gap: 20px; }
body .header-navigation .header-menu-container > ul > li > a,
body .header-navigation .header-menu-container > ul > li > .menu-link {
	font-size: 10.75px;
	letter-spacing: .035em;
}

.tw-section--moments { padding-top: 42px; padding-bottom: 60px; background: var(--tw-white); }
.tw-section--guide-library { position: relative; border-top: 1px solid rgba(232, 217, 209, .72); background: #fdfbf9; }
.tw-section--guide-library::before,
.tw-section--picks-home::before {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	height: 4px;
	background: linear-gradient(90deg, transparent, rgba(189, 118, 114, .45), transparent);
}
.tw-section--guide-library,
.tw-section--picks-home { position: relative; }
.tw-section--picks-home { background: #f9f2ee; border-top: 1px solid var(--tw-line); border-bottom: 1px solid var(--tw-line); }
.tw-section--latest { background: var(--tw-white); }

.tw-card-image { background: #ead7cd; }
.tw-placeholder-art,
.tw-category-art {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	min-height: 100%;
	overflow: hidden;
	color: rgba(89, 60, 53, .83);
	background: linear-gradient(135deg, #eddcd3 0%, #d9bfb2 100%);
	isolation: isolate;
}
.tw-placeholder-art::before,
.tw-category-art::before {
	content: "";
	position: absolute;
	inset: 14%;
	border: 1px solid rgba(255, 255, 255, .68);
	z-index: -1;
}
.tw-placeholder-art::after,
.tw-category-art::after {
	content: "";
	position: absolute;
	width: 68%;
	aspect-ratio: 1;
	border: 1px solid rgba(255, 255, 255, .35);
	border-radius: 50%;
	z-index: -1;
}
.tw-placeholder-art__line { position: absolute; left: 24%; right: 24%; top: 50%; height: 1px; background: rgba(255,255,255,.68); transform: rotate(-24deg); }
.tw-placeholder-art__label,
.tw-category-art__label {
	max-width: 76%;
	font-family: var(--tw-serif);
	font-size: clamp(1rem, 1.75vw, 1.5rem);
	font-weight: 600;
	letter-spacing: -.025em;
	line-height: .95;
	text-align: center;
}
.tw-placeholder-art__mark,
.tw-category-art__mark { position: absolute; right: 16%; top: 16%; color: var(--tw-rose-deep); font-size: 19px; }
.tw-category-art__ring { position: absolute; left: 17%; bottom: 15%; width: 40%; aspect-ratio: 1; border: 1px solid rgba(255,255,255,.62); border-radius: 50%; }
.tw-category-art--wedding-guest-attire { background: linear-gradient(145deg, #eed9d3 0%, #cfaaa0 100%); }
.tw-category-art--bridal-couple-style { background: linear-gradient(145deg, #f1e6de 0%, #dcc1b7 100%); }
.tw-category-art--wedding-party { background: linear-gradient(145deg, #e8d8d2 0%, #cdaea5 100%); }
.tw-category-art--planning-etiquette { background: linear-gradient(145deg, #ede4d8 0%, #cdbba8 100%); }
.tw-category-art--gifts-accessories { background: linear-gradient(145deg, #f2e7df 0%, #d8c0b6 100%); }
.tw-category-art--special-occasions { background: linear-gradient(145deg, #e8dcd2 0%, #c5aa9d 100%); }

.tw-inline-empty {
	grid-column: 1 / -1;
	padding: clamp(36px, 6vw, 76px) clamp(24px, 5vw, 76px);
	border: 1px solid var(--tw-line);
	background: var(--tw-white);
	text-align: center;
}
.tw-inline-empty h3 { margin: 0; font-family: var(--tw-serif); font-size: clamp(2rem, 3.3vw, 3rem); font-weight: 600; letter-spacing: -.035em; line-height: .98; }
.tw-inline-empty p:last-child { max-width: 560px; margin: 15px auto 0; color: var(--tw-muted); font-size: 15px; line-height: 1.68; }
.tw-inline-empty--picks { background: linear-gradient(135deg, #fffdfb, #f4e7e0); }

.tw-plan-image .tw-category-art { min-height: 100%; }
.tw-plan-image .tw-category-art__label { font-size: clamp(1.8rem, 3.7vw, 3.7rem); }
.tw-picks-home__intro { max-width: 620px; margin: -7px 0 28px; color: var(--tw-muted); font-size: 15px; line-height: 1.7; }
.tw-pick-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 22px; }
.tw-pick-card { overflow: hidden; border: 1px solid var(--tw-line); background: var(--tw-white); transition: box-shadow .2s ease, transform .2s ease; }
.tw-pick-card:hover { box-shadow: var(--tw-shadow); transform: translateY(-3px); }
.tw-pick-card__image { display: block; aspect-ratio: 1.18 / 1; overflow: hidden; background: #eaded6; }
.tw-pick-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.tw-pick-card:hover .tw-pick-card__image img { transform: scale(1.045); }
.tw-pick-card__body { padding: 17px 16px 20px; }
.tw-pick-card h3 { margin: 0; font-family: var(--tw-serif); font-size: 21px; font-weight: 600; letter-spacing: -.024em; line-height: 1.05; }
.tw-pick-card h3 a { color: inherit; text-decoration: none; }
.tw-pick-card__excerpt { margin: 10px 0 0; color: var(--tw-muted); font-size: 13px; line-height: 1.58; }
.tw-pick-card .tw-read-more { display: inline-block; margin-top: 15px; }

.tw-picks-trust { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px 17px; margin-top: 28px; color: var(--tw-rose-deep); font-size: 10px; font-weight: 700; letter-spacing: .095em; text-transform: uppercase; }
.tw-picks-trust span { display: inline-flex; align-items: center; gap: 8px; }
.tw-picks-trust span:not(:last-child)::after { content: ""; width: 4px; height: 4px; border-radius: 50%; background: var(--tw-rose); }
.tw-picks-disclosure { max-width: 850px; margin: 48px auto 0; padding: 18px 20px; border-left: 2px solid var(--tw-rose); background: var(--tw-sand); color: var(--tw-muted); font-size: 13px; line-height: 1.65; }
.tw-picks-disclosure p { margin: 0; }
.tw-picks-disclosure a { color: var(--tw-rose-deep); font-weight: 700; }
.tw-empty-state--picks { background: linear-gradient(135deg, #fffdfb, #f4e7e0); }

/* Start Here */
.tw-start-hero { padding: clamp(76px, 11vw, 138px) 0 clamp(64px, 8vw, 94px); background: linear-gradient(125deg, #f5e9e4 0%, #fcfaf7 57%, #efe0d7 100%); text-align: center; }
.tw-start-hero h1 { max-width: 920px; margin: 0 auto; font-family: var(--tw-serif); font-size: clamp(3.5rem, 6vw, 6.5rem); font-weight: 500; letter-spacing: -.055em; line-height: .88; }
.tw-start-hero__text { max-width: 620px; margin: 26px auto 0; color: var(--tw-muted); font-size: 17px; line-height: 1.7; }
.tw-start-paths { background: var(--tw-white); }
.tw-start-paths__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
.tw-start-path { position: relative; min-height: 365px; padding: clamp(30px, 4vw, 52px); overflow: hidden; border: 1px solid var(--tw-line); color: var(--tw-ink); text-decoration: none; transition: transform .2s ease, box-shadow .2s ease; }
.tw-start-path::before { content: ""; position: absolute; width: 270px; aspect-ratio: 1; right: -62px; bottom: -110px; border: 1px solid rgba(255,255,255,.7); border-radius: 50%; }
.tw-start-path::after { content: "✦"; position: absolute; right: 34px; top: 27px; color: var(--tw-rose-deep); font-size: 24px; }
.tw-start-path:hover { box-shadow: var(--tw-shadow); transform: translateY(-3px); color: var(--tw-ink); }
.tw-start-path--planning { background: linear-gradient(135deg, #f1dfd8 0%, #e2c4bb 100%); }
.tw-start-path--guest { background: linear-gradient(135deg, #f5ede8 0%, #dbc0b5 100%); }
.tw-start-path__number { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; margin-bottom: 34px; border: 1px solid rgba(157,93,89,.68); color: var(--tw-rose-deep); font-size: 12px; font-weight: 800; }
.tw-start-path .tw-section-kicker { margin-bottom: 12px; }
.tw-start-path h2 { max-width: 390px; margin: 0; font-family: var(--tw-serif); font-size: clamp(2.5rem, 4vw, 4rem); font-weight: 600; letter-spacing: -.045em; line-height: .93; }
.tw-start-path > p:not(.tw-section-kicker) { max-width: 430px; margin: 19px 0 0; font-size: 15px; line-height: 1.7; }
.tw-start-path .tw-read-more { display: inline-block; margin-top: 28px; }
.tw-start-more__heading { max-width: 720px; margin: 0 auto 36px; text-align: center; }
.tw-start-more__heading h2 { margin: 0; font-family: var(--tw-serif); font-size: clamp(2.6rem, 4.5vw, 4.4rem); font-weight: 500; letter-spacing: -.04em; line-height: .94; }
.tw-start-more__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 19px; }
.tw-start-more__grid a { padding: 24px; border: 1px solid var(--tw-line); background: rgba(255,255,255,.62); color: var(--tw-ink); text-decoration: none; transition: background .2s ease, transform .2s ease; }
.tw-start-more__grid a:hover { background: var(--tw-white); color: var(--tw-ink); transform: translateY(-3px); }
.tw-start-more__grid span { color: var(--tw-rose-deep); font-size: 10px; font-weight: 800; letter-spacing: .1em; }
.tw-start-more__grid h3 { margin: 17px 0 0; font-family: var(--tw-serif); font-size: 25px; font-weight: 600; letter-spacing: -.025em; line-height: 1.02; }
.tw-start-more__grid p { margin: 10px 0 0; color: var(--tw-muted); font-size: 13px; line-height: 1.6; }
.tw-start-latest__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }

@media (max-width: 1050px) {
	.tw-pick-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.tw-start-more__grid { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
	body .site-header-row-container-inner { min-height: 74px; }
	body .site-branding .brand img,
	body .site-branding a.brand img,
	body .site-branding .site-logo img { max-height: 54px; }
	.tw-section--moments { padding-top: 34px; }
	.tw-pick-grid,
	.tw-start-paths__grid,
	.tw-start-latest__grid { grid-template-columns: 1fr; }
	.tw-start-hero { padding-top: 76px; }
	.tw-start-hero h1 { font-size: clamp(3.2rem, 15vw, 5.1rem); }
	.tw-start-path { min-height: 320px; }
	.tw-picks-trust { gap: 8px 12px; }
}

/* Version 1.5: respect the WordPress menu, page-driven moment images, and a theme-controlled Wedding Picks hub */
/*
 * The header menu is managed entirely in Appearance > Menus / Kadence Header.
 * This child theme deliberately does not add, rename, remove, group, or style
 * individual menu items beyond the site's shared typography.
 */

/* Wedding Picks: keep all template-controlled content centered and compact. */
.tw-picks-hero .tw-shell,
.tw-picks-listing .tw-shell {
	text-align: center;
}

.tw-picks-hero__intro {
	max-width: 690px;
	margin-right: auto;
	margin-left: auto;
}

.tw-picks-hero__intro p {
	max-width: 660px;
	margin-right: auto;
	margin-left: auto;
}

.tw-picks-listing .tw-pick-grid {
	justify-content: center;
}

.tw-picks-listing .tw-empty-state {
	width: min(100%, 900px);
	justify-self: center;
}

/* Homepage: show the featured image assigned to each hub Page. */
.tw-moment-card .tw-card-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tw-moment-card .tw-card-image .tw-category-art,
.tw-moment-card .tw-card-image .tw-placeholder-art {
	display: flex;
}

/* Wedding Websites service block on the homepage */
.tw-section--service {
	border-top: 1px solid var(--tw-line);
	border-bottom: 1px solid var(--tw-line);
	background: var(--tw-white);
}

.tw-service {
	display: grid;
	grid-template-columns: minmax(260px, .9fr) minmax(0, 1.15fr);
	align-items: center;
	gap: clamp(42px, 7vw, 110px);
}

.tw-service__art {
	position: relative;
	min-height: 370px;
	overflow: hidden;
	border: 1px solid var(--tw-line);
	background: linear-gradient(135deg, #f1ded7 0%, #e3c7bc 100%);
}

.tw-service__art::before,
.tw-service__art::after {
	content: "";
	position: absolute;
	border: 1px solid rgba(255,255,255,.65);
	border-radius: 50%;
}

.tw-service__art::before {
	width: 310px;
	height: 310px;
	right: -118px;
	bottom: -148px;
}

.tw-service__art::after {
	width: 210px;
	height: 210px;
	left: -104px;
	top: -104px;
}

.tw-service__mockup {
	position: absolute;
	inset: 50% auto auto 50%;
	width: min(78%, 305px);
	padding: 18px;
	border: 1px solid rgba(149, 90, 85, .18);
	background: #fffdfb;
	box-shadow: 0 18px 30px rgba(88, 53, 48, .14);
	transform: translate(-50%, -50%);
}

.tw-service__mockup-head {
	margin: 0;
	color: var(--tw-ink);
	font-family: var(--tw-serif);
	font-size: 24px;
	font-weight: 600;
	line-height: 1;
}

.tw-service__mockup-rule {
	width: 44px;
	height: 2px;
	margin: 12px 0 20px;
	background: var(--tw-rose);
}

.tw-service__mockup-line {
	height: 7px;
	margin-top: 9px;
	background: #d6b7aa;
}
.tw-service__mockup-line--short { width: 60%; }
.tw-service__mockup-line--mid { width: 82%; }
.tw-service__mockup-button { width: 72px; height: 26px; margin-top: 20px; background: var(--tw-rose); }

.tw-service__content {
	max-width: 635px;
}

.tw-service__content .tw-section-title--large {
	max-width: 530px;
}

.tw-service__text {
	max-width: 590px;
	margin: 22px 0 0;
	color: var(--tw-muted);
	font-size: 15px;
	line-height: 1.75;
}

.tw-service__benefits {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 19px;
	margin: 22px 0 0;
	padding: 0;
	color: var(--tw-rose-deep);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .015em;
	list-style: none;
}

.tw-service__benefits li::before {
	content: "✦";
	margin-right: 7px;
	color: var(--tw-rose);
}

.tw-service__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 27px;
}

.tw-service__note {
	margin: 17px 0 0;
	color: var(--tw-muted);
	font-size: 11px;
	line-height: 1.6;
}

/* Dedicated Wedding Websites service page */
.tw-websites-hero {
	padding: clamp(84px, 12vw, 155px) 0 clamp(72px, 9vw, 110px);
	background: linear-gradient(125deg, #f2e3dd 0%, #fcfaf7 56%, #e9d2c8 100%);
	text-align: center;
}

.tw-websites-hero h1,
.tw-websites-heading {
	margin: 0;
	font-family: var(--tw-serif);
	font-weight: 500;
	letter-spacing: -.05em;
	line-height: .9;
}

.tw-websites-hero h1 {
	max-width: 900px;
	margin-right: auto;
	margin-left: auto;
	font-size: clamp(3.8rem, 7vw, 7.25rem);
}

.tw-websites-hero__text {
	max-width: 660px;
	margin: 28px auto 0;
	color: var(--tw-muted);
	font-size: 17px;
	line-height: 1.72;
}

.tw-websites-hero__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px;
	margin-top: 31px;
}

.tw-websites-intro {
	max-width: 770px;
	margin: 0 auto;
	text-align: center;
}

.tw-websites-intro .tw-websites-heading {
	font-size: clamp(2.8rem, 5vw, 4.6rem);
}

.tw-websites-intro p:last-child {
	max-width: 650px;
	margin: 22px auto 0;
	color: var(--tw-muted);
	font-size: 16px;
	line-height: 1.75;
}

.tw-websites-features {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	margin-top: clamp(42px, 6vw, 70px);
}

.tw-websites-feature {
	min-height: 220px;
	padding: 29px;
	border: 1px solid var(--tw-line);
	background: rgba(255,255,255,.7);
}

.tw-websites-feature__number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 35px;
	height: 35px;
	border: 1px solid var(--tw-rose);
	color: var(--tw-rose-deep);
	font-size: 10px;
	font-weight: 800;
}

.tw-websites-feature h3 {
	margin: 24px 0 0;
	font-family: var(--tw-serif);
	font-size: 28px;
	font-weight: 600;
	letter-spacing: -.032em;
	line-height: .98;
}

.tw-websites-feature p {
	margin: 12px 0 0;
	color: var(--tw-muted);
	font-size: 14px;
	line-height: 1.68;
}

.tw-websites-process {
	display: grid;
	grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
	gap: clamp(38px, 7vw, 100px);
	align-items: start;
}

.tw-websites-process__intro .tw-websites-heading {
	font-size: clamp(2.8rem, 4.8vw, 4.6rem);
}

.tw-websites-process__intro p:last-child {
	margin: 22px 0 0;
	color: var(--tw-muted);
	font-size: 16px;
	line-height: 1.7;
}

.tw-websites-steps {
	counter-reset: website-step;
	margin: 0;
	padding: 0;
	list-style: none;
}

.tw-websites-steps li {
	position: relative;
	padding: 0 0 29px 70px;
	border-bottom: 1px solid var(--tw-line);
}

.tw-websites-steps li + li { margin-top: 25px; }

.tw-websites-steps li::before {
	counter-increment: website-step;
	content: "0" counter(website-step);
	position: absolute;
	left: 0;
	top: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border: 1px solid var(--tw-rose);
	color: var(--tw-rose-deep);
	font-size: 11px;
	font-weight: 800;
}

.tw-websites-steps h3 {
	margin: 0;
	font-family: var(--tw-serif);
	font-size: 28px;
	font-weight: 600;
	letter-spacing: -.027em;
	line-height: 1;
}

.tw-websites-steps p {
	margin: 10px 0 0;
	color: var(--tw-muted);
	font-size: 14px;
	line-height: 1.68;
}

.tw-websites-cta {
	padding: clamp(62px, 9vw, 110px) 0;
	border-top: 1px solid var(--tw-line);
	background: linear-gradient(135deg, #f3e7e2, #f8f4ef);
	text-align: center;
}

.tw-websites-cta .tw-websites-heading {
	max-width: 750px;
	margin: 0 auto;
	font-size: clamp(3rem, 5.8vw, 5.7rem);
}

.tw-websites-cta p {
	max-width: 595px;
	margin: 21px auto 0;
	color: var(--tw-muted);
	font-size: 16px;
	line-height: 1.72;
}

.tw-websites-cta .tw-button { margin-top: 28px; }

@media (max-width: 1050px) {
	body .header-navigation .header-menu-container > ul > li > a,
	body .header-navigation .header-menu-container > ul > li > .menu-link {
		padding-left: 6px;
		padding-right: 6px;
		font-size: 9.65px;
	}
	body .header-navigation .header-menu-container > ul > li.tw-menu-service-cta > a,
	body .header-navigation .header-menu-container > ul > li.tw-menu-service-cta > .menu-link {
		margin-left: 3px;
		padding-right: 10px;
		padding-left: 10px;
		font-size: 8.75px;
	}
	.tw-service,
	.tw-websites-process { gap: 46px; }
}

@media (max-width: 767px) {
	.tw-section--picks-home .tw-section-heading { display: block; }
	.tw-section--picks-home .tw-section-heading__link { position: static; display: inline-block; margin-top: 13px; }
	.tw-section--picks-home .tw-pick-grid { grid-template-columns: 1fr; }
	.tw-service,
	.tw-websites-process { grid-template-columns: 1fr; }
	.tw-service__art { min-height: 320px; }
	.tw-service__content { text-align: center; }
	.tw-service__content .tw-section-title--large,
	.tw-service__text { margin-right: auto; margin-left: auto; }
	.tw-service__benefits,
	.tw-service__actions { justify-content: center; }
	.tw-websites-features { grid-template-columns: 1fr; }
	.tw-websites-hero h1 { font-size: clamp(3.5rem, 15vw, 5.5rem); }
}

/* Version 1.5.1: force the Wedding Picks overview sentence to center independently of Kadence entry-content styles. */
.tw-picks-hero__intro,
.tw-picks-hero__intro p {
	text-align: center !important;
}

.tw-picks-hero__intro {
	width: 100%;
	max-width: 660px;
	margin: 22px auto 0 !important;
}

.tw-picks-hero__intro p {
	display: block;
	width: 100%;
	max-width: 660px;
	margin: 0 auto !important;
	padding: 0;
}

/* Version 1.6: newsletter placeholder cleanup + accessible back-to-top control */
.tw-back-to-top {
	position: fixed;
	right: 22px;
	bottom: 22px;
	z-index: 9999;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	margin: 0;
	padding: 0;
	border: 1px solid rgba(255,255,255,.72);
	border-radius: 999px;
	background: var(--tw-rose);
	box-shadow: 0 12px 28px rgba(68, 42, 35, .22);
	color: #fff;
	cursor: pointer;
	opacity: 0;
	pointer-events: none;
	transform: translateY(12px);
	transition: opacity .2s ease, transform .2s ease, background .2s ease, box-shadow .2s ease;
}

.tw-back-to-top.is-visible {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.tw-back-to-top:hover,
.tw-back-to-top:focus-visible {
	background: var(--tw-rose-deep);
	box-shadow: 0 15px 30px rgba(68, 42, 35, .28);
	color: #fff;
}

.tw-back-to-top:focus-visible {
	outline: 3px solid rgba(189, 118, 114, .32);
	outline-offset: 3px;
}

.tw-back-to-top__icon {
	display: block;
	width: 21px;
	height: 21px;
	margin: 0;
	padding: 0;
	transform: translateY(-.5px);
}

@media (max-width: 767px) {
	.tw-back-to-top {
		right: 16px;
		bottom: 16px;
		width: 44px;
		height: 44px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.tw-back-to-top {
		transition: none;
	}
}

/* Version 1.6.1: resilient Back to Top visibility.
   The control remains usable even if a cache/minifier delays theme.js. */
.tw-back-to-top {
	display: inline-flex !important;
	opacity: 1 !important;
	pointer-events: auto !important;
	transform: translateY(0) !important;
}

/* Keep it subtly tucked away only at the very top when JavaScript is available. */
html.tw-js .tw-back-to-top:not(.is-visible) {
	opacity: .72 !important;
}

html.tw-js .tw-back-to-top:not(.is-visible):hover,
html.tw-js .tw-back-to-top:not(.is-visible):focus-visible {
	opacity: 1 !important;
}


/* v1.6.2 card layout fix: anchors must be block elements so aspect-ratio crops portrait images and card titles remain visible. */
.tw-post-card__image,
.tw-feature-card__image,
.tw-pick-card__image {
	display: block;
	width: 100%;
}

.tw-post-card__image,
.tw-feature-card__image {
	aspect-ratio: .95 / 1;
	overflow: hidden;
}

.tw-post-card__body,
.tw-feature-card__body,
.tw-pick-card__body {
	display: block;
	position: relative;
	background: var(--tw-white);
}

.tw-post-card__body h3,
.tw-post-card__body h3 a {
	display: block;
	visibility: visible;
	opacity: 1;
}

/* Version 1.7.0: wedding website product system, template gallery, and consultation path */
.tw-websites-hero--showcase {
	position: relative;
	padding: clamp(78px, 10vw, 138px) 0;
	overflow: hidden;
	text-align: left;
	background: linear-gradient(125deg, #f2e3dd 0%, #fcfaf7 54%, #ead5cb 100%);
}
.tw-websites-hero--showcase::before {
	content: "";
	position: absolute;
	width: 520px;
	aspect-ratio: 1;
	right: -220px;
	top: -238px;
	border: 1px solid rgba(255,255,255,.72);
	border-radius: 50%;
}
.tw-websites-hero__grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(330px, .82fr); align-items: center; gap: clamp(45px, 8vw, 140px); }
.tw-websites-hero__content { max-width: 650px; }
.tw-websites-hero--showcase h1 { max-width: 690px; margin: 0; font-size: clamp(3.8rem, 6.7vw, 7rem); }
.tw-websites-hero--showcase .tw-websites-hero__text { margin-right: 0; margin-left: 0; }
.tw-websites-hero--showcase .tw-websites-hero__actions { justify-content: flex-start; }
.tw-websites-hero__microcopy { margin: 16px 0 0; color: var(--tw-muted); font-size: 12px; }
.tw-service-preview { position: relative; min-height: 410px; }
.tw-service-preview__browser { position: absolute; left: 50%; top: 50%; width: min(100%, 390px); overflow: hidden; border: 1px solid rgba(131,85,78,.22); background: #fffdfb; box-shadow: 0 28px 70px rgba(73,50,40,.16); transform: translate(-50%, -50%) rotate(3deg); }
.tw-service-preview__bar { display: flex; gap: 5px; padding: 12px; border-bottom: 1px solid var(--tw-line); background: rgba(250,246,241,.9); }
.tw-service-preview__bar span { display: block; width: 6px; height: 6px; border-radius: 50%; background: #c9aaa0; }
.tw-service-preview__canvas { position: relative; min-height: 360px; padding: 58px 34px 34px; overflow: hidden; background: linear-gradient(145deg, #f6e8e1, #dcc2b7); text-align: center; }
.tw-service-preview__canvas::before, .tw-service-preview__canvas::after { content: ""; position: absolute; border: 1px solid rgba(255,255,255,.66); border-radius: 50%; }
.tw-service-preview__canvas::before { width: 260px; height: 260px; left: -145px; bottom: -168px; }
.tw-service-preview__canvas::after { width: 190px; height: 190px; right: -118px; top: -115px; }
.tw-service-preview__eyebrow { margin: 0; color: var(--tw-rose-deep); font-size: 9px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; }
.tw-service-preview__canvas h2 { position: relative; z-index: 1; margin: 35px 0 0; font-family: var(--tw-serif); font-size: clamp(3.2rem, 6vw, 4.6rem); font-weight: 500; letter-spacing: -.055em; line-height: .74; }
.tw-service-preview__canvas h2 em { display: inline-block; margin: 3px 0; color: var(--tw-rose-deep); font-weight: 400; }
.tw-service-preview__date { margin: 30px 0 0; color: var(--tw-ink); font-size: 9px; font-weight: 800; letter-spacing: .17em; }
.tw-service-preview__rule { width: 52px; height: 1px; margin: 21px auto; background: var(--tw-rose); }
.tw-service-preview__small { margin: 0; color: var(--tw-muted); font-size: 12px; font-style: italic; }
.tw-service-preview__tag { position: absolute; right: 0; bottom: 5px; padding: 15px 18px; background: var(--tw-rose-deep); color: #fff; font-family: var(--tw-serif); font-size: 22px; font-style: italic; line-height: .9; box-shadow: 0 12px 24px rgba(79,45,41,.16); }
.tw-websites-paths { background: var(--tw-white); }
.tw-websites-paths__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; margin-top: clamp(38px, 5vw, 62px); }
.tw-websites-path { position: relative; min-height: 318px; padding: clamp(30px, 4vw, 48px); overflow: hidden; border: 1px solid var(--tw-line); }
.tw-websites-path::after { content: "✦"; position: absolute; right: 32px; top: 23px; color: var(--tw-rose-deep); font-size: 24px; }
.tw-websites-path h3 { max-width: 430px; margin: 0; font-family: var(--tw-serif); font-size: clamp(2.5rem, 3.7vw, 4rem); font-weight: 500; letter-spacing: -.048em; line-height: .9; }
.tw-websites-path > p:last-of-type { max-width: 470px; margin: 20px 0 0; font-size: 15px; line-height: 1.72; }
.tw-websites-path .tw-read-more { display: inline-block; margin-top: 28px; }
.tw-websites-path--template { background: linear-gradient(145deg, #f2e2dc, #e0c2b8); }
.tw-websites-path--consult { background: linear-gradient(145deg, #f5f1eb, #e7d9ce); }
.tw-template-spotlight { border-top: 1px solid var(--tw-line); }
.tw-template-cards { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 19px; }
.tw-template-card { display: block; overflow: hidden; border: 1px solid var(--tw-line); background: #fff; color: var(--tw-ink); text-decoration: none; transition: transform .22s ease, box-shadow .22s ease; }
.tw-template-card:hover { color: var(--tw-ink); box-shadow: var(--tw-shadow); transform: translateY(-4px); }
.tw-template-card__preview { position: relative; display: flex; flex-direction: column; justify-content: flex-end; min-height: 276px; padding: 28px; overflow: hidden; }
.tw-template-card__preview::after { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(255,255,255,.58); pointer-events: none; }
.tw-template-card__preview-label, .tw-template-card__preview-date { position: relative; z-index: 1; }
.tw-template-card__preview-label { font-family: var(--tw-serif); font-size: clamp(2rem, 3vw, 3rem); font-weight: 500; letter-spacing: -.04em; line-height: .9; }
.tw-template-card__preview-date { margin-top: 13px; font-size: 9px; font-weight: 800; letter-spacing: .17em; }
.tw-template-card--editorial .tw-template-card__preview { background: linear-gradient(145deg, #e9d4cb, #c9a297); }
.tw-template-card--garden .tw-template-card__preview { background: linear-gradient(145deg, #dce0ce, #aebba8); }
.tw-template-card--modern .tw-template-card__preview { background: linear-gradient(145deg, #d9d5e8, #b8a7c9); }
.tw-template-card--garden .tw-template-card__preview::before { content: "✿"; position: absolute; left: 25px; top: 23px; color: rgba(63,86,67,.72); font-size: 26px; }
.tw-template-card--modern .tw-template-card__preview::before { content: "+"; position: absolute; right: 25px; top: 15px; color: rgba(74,47,104,.6); font-family: var(--tw-serif); font-size: 62px; }
.tw-template-card__body { padding: 21px 20px 24px; }
.tw-template-card__body > p { margin: 0; color: var(--tw-rose-deep); font-size: 10px; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }
.tw-template-card__body h3 { margin: 12px 0 0; font-family: var(--tw-serif); font-size: 25px; font-weight: 600; letter-spacing: -.03em; line-height: 1.02; }
.tw-template-card__body .tw-read-more { display: inline-block; margin-top: 17px; }
.tw-websites-hosting { background: var(--tw-white); }
.tw-websites-hosting__grid { display: grid; grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr); gap: clamp(42px, 7vw, 100px); align-items: start; }
.tw-websites-hosting__intro .tw-websites-heading { font-size: clamp(3rem, 4.8vw, 4.8rem); }
.tw-websites-hosting__intro p:last-child { max-width: 520px; margin: 22px 0 0; color: var(--tw-muted); font-size: 16px; line-height: 1.72; }
.tw-hosting-options { display: grid; gap: 13px; }
.tw-hosting-option { position: relative; min-height: 142px; padding: 25px 25px 25px 78px; border: 1px solid var(--tw-line); background: #fffdfb; }
.tw-hosting-option__number { position: absolute; top: 27px; left: 24px; color: var(--tw-rose-deep); font-size: 10px; font-weight: 800; letter-spacing: .1em; }
.tw-hosting-option h3 { margin: 0; font-family: var(--tw-serif); font-size: 28px; font-weight: 600; line-height: 1; }
.tw-hosting-option p { margin: 10px 0 0; color: var(--tw-muted); font-size: 14px; line-height: 1.65; }
.tw-websites-process-wrap { border-top: 1px solid var(--tw-line); background: #fdfbf9; }

/* Template gallery */
.tw-template-gallery__hero { padding: clamp(80px, 11vw, 142px) 0 clamp(65px, 8vw, 96px); background: linear-gradient(135deg, #f2e3dc, #fcfaf7); text-align: center; }
.tw-template-gallery__hero h1 { max-width: 900px; margin: 0 auto; font-family: var(--tw-serif); font-size: clamp(3.8rem, 7vw, 7rem); font-weight: 500; letter-spacing: -.06em; line-height: .88; }
.tw-template-gallery__hero > .tw-shell > p:last-child { max-width: 640px; margin: 26px auto 0; color: var(--tw-muted); font-size: 16px; line-height: 1.72; }
.tw-template-gallery__collection { background: #fff; }
.tw-template-gallery__grid { display: grid; gap: clamp(48px, 8vw, 100px); }
.tw-template-gallery__item { display: grid; grid-template-columns: minmax(320px, .85fr) minmax(0, 1fr); gap: clamp(34px, 6vw, 90px); align-items: center; }
.tw-template-gallery__item:nth-child(even) .tw-template-gallery__art { order: 2; }
.tw-template-gallery__art { position: relative; min-height: 475px; display: flex; flex-direction: column; justify-content: flex-end; padding: 42px; overflow: hidden; border: 1px solid var(--tw-line); }
.tw-template-gallery__art::after { content: ""; position: absolute; inset: 24px; border: 1px solid rgba(255,255,255,.6); }
.tw-template-gallery__art span, .tw-template-gallery__art em { position: relative; z-index: 1; }
.tw-template-gallery__art span { max-width: 360px; font-family: var(--tw-serif); font-size: clamp(3rem, 5vw, 5.5rem); font-weight: 500; letter-spacing: -.055em; line-height: .82; }
.tw-template-gallery__art em { margin-top: 23px; font-size: 10px; font-style: normal; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.tw-template-gallery__item--editorial .tw-template-gallery__art { background: linear-gradient(145deg, #ead7ce, #c99e93); }
.tw-template-gallery__item--garden .tw-template-gallery__art { background: linear-gradient(145deg, #dde5d4, #a4b99d); }
.tw-template-gallery__item--modern .tw-template-gallery__art { background: linear-gradient(145deg, #dfd8ea, #ae9bc2); }
.tw-template-gallery__item--garden .tw-template-gallery__art::before { content: "✿"; position: absolute; right: 38px; top: 27px; color: rgba(57,82,60,.65); font-size: 40px; }
.tw-template-gallery__item--modern .tw-template-gallery__art::before { content: "+"; position: absolute; right: 34px; top: 8px; color: rgba(71,45,98,.62); font-family: var(--tw-serif); font-size: 110px; }
.tw-template-gallery__copy { max-width: 540px; }
.tw-template-gallery__copy h2 { margin: 0; font-family: var(--tw-serif); font-size: clamp(3rem, 4.7vw, 4.8rem); font-weight: 500; letter-spacing: -.05em; line-height: .9; }
.tw-template-gallery__copy > p:last-of-type { margin: 22px 0 0; color: var(--tw-muted); font-size: 16px; line-height: 1.72; }
.tw-template-gallery__actions { display: flex; flex-wrap: wrap; gap: 11px; margin-top: 27px; }
.tw-template-gallery__note { padding: clamp(65px, 9vw, 110px) 0; background: linear-gradient(135deg, #f3e6e0, #f9f4ef); text-align: center; }
.tw-template-gallery__note h2 { max-width: 780px; margin: 0 auto; font-family: var(--tw-serif); font-size: clamp(3rem, 5.6vw, 5.5rem); font-weight: 500; letter-spacing: -.055em; line-height: .9; }
.tw-template-gallery__note p:not(.tw-section-kicker) { max-width: 610px; margin: 20px auto 0; color: var(--tw-muted); font-size: 16px; line-height: 1.72; }
.tw-template-gallery__note .tw-button { margin-top: 28px; }

/* Demo template previews */


/* Get started page: public service path remains a theme responsibility. */
.tw-get-started__hero { padding: clamp(80px, 11vw, 142px) 0 clamp(66px, 8vw, 95px); background: linear-gradient(135deg, #f1e1da, #fcfaf7); text-align: center; }
.tw-get-started__hero h1 { max-width: 780px; margin: 0 auto; font-family: var(--tw-serif); font-size: clamp(3.7rem, 6.5vw, 6.8rem); font-weight: 500; letter-spacing: -.06em; line-height: .86; }
.tw-get-started__hero > .tw-shell > p:last-of-type { max-width: 620px; margin: 25px auto 0; color: var(--tw-muted); font-size: 16px; line-height: 1.72; }
.tw-get-started__selected { display: inline-flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 9px; margin-top: 28px; padding: 12px 16px; border: 1px solid var(--tw-line); background: rgba(255,255,255,.68); font-size: 12px; }
.tw-get-started__selected span { color: var(--tw-muted); }
.tw-get-started__selected a { color: var(--tw-rose-deep); font-weight: 700; }
.tw-start-choice-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 20px; }
.tw-start-choice { min-height: 375px; padding: clamp(30px, 4vw, 52px); border: 1px solid var(--tw-line); background: linear-gradient(145deg, #f5ebe6, #e3c9bf); }
.tw-start-choice--consult { background: linear-gradient(145deg, #f5f1eb, #ddd2c6); }
.tw-start-choice h2 { max-width: 480px; margin: 0; font-family: var(--tw-serif); font-size: clamp(3rem, 4.5vw, 4.7rem); font-weight: 500; letter-spacing: -.055em; line-height: .88; }
.tw-start-choice > p:last-of-type { max-width: 465px; margin: 20px 0 0; font-size: 15px; line-height: 1.72; }
.tw-start-choice .tw-button { margin-top: 28px; }
.tw-start-choice small { display: block; max-width: 350px; margin-top: 15px; color: var(--tw-muted); font-size: 11px; line-height: 1.55; }
.tw-start-choice__actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 27px; }
.tw-start-choice__actions .tw-button { margin-top: 0; }
.tw-text-link { display: block; width: 100%; margin-top: 2px; color: var(--tw-rose-deep); font-size: 12px; font-weight: 700; }
.tw-get-started__hosting { display: grid; grid-template-columns: minmax(0,.85fr) minmax(0,1.15fr); gap: clamp(38px, 7vw, 100px); align-items: start; }
.tw-get-started__hosting h2 { font-size: clamp(3rem, 4.8vw, 4.8rem); }
.tw-get-started__hosting-options { display: grid; gap: 12px; }
.tw-get-started__hosting-options article { padding: 22px 23px; border: 1px solid var(--tw-line); background: rgba(255,255,255,.64); }
.tw-get-started__hosting-options h3 { margin: 0; font-family: var(--tw-serif); font-size: 27px; font-weight: 600; line-height: 1; }
.tw-get-started__hosting-options p { margin: 10px 0 0; }
.tw-get-started__hosting-options code { color: var(--tw-rose-deep); font-family: var(--tw-sans); font-size: 12px; font-weight: 700; }
.tw-get-started__hosting-options span { display: block; margin-top: 7px; color: var(--tw-muted); font-size: 13px; line-height: 1.6; }
.tw-get-started__what { padding: clamp(66px, 9vw, 112px) 0; background: #fffdfb; text-align: center; }
.tw-get-started__what h2 { max-width: 760px; margin: 0 auto; font-family: var(--tw-serif); font-size: clamp(3rem, 5.4vw, 5.5rem); font-weight: 500; letter-spacing: -.06em; line-height: .9; }
.tw-get-started__what ul { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; max-width: 910px; margin: 40px auto 0; padding: 0; list-style: none; text-align: left; }
.tw-get-started__what li { padding: 19px 21px 19px 46px; border: 1px solid var(--tw-line); background: #fff; font-size: 14px; line-height: 1.6; }
.tw-get-started__what li::before { content: "✦"; position: absolute; margin-left: -24px; color: var(--tw-rose); }

a.tw-back-to-top { text-decoration: none; }

@media (max-width: 900px) {
    .tw-websites-hero__grid, .tw-websites-hosting__grid, .tw-template-gallery__item, .tw-get-started__hosting { grid-template-columns: 1fr; }
    .tw-websites-hero--showcase { text-align: center; }
    .tw-websites-hero--showcase .tw-websites-hero__text { margin-right: auto; margin-left: auto; }
    .tw-websites-hero--showcase .tw-websites-hero__actions { justify-content: center; }
    .tw-service-preview { min-height: 360px; max-width: 470px; width: 100%; margin: 0 auto; }
    .tw-template-gallery__item:nth-child(even) .tw-template-gallery__art { order: 0; }
    .tw-template-gallery__copy { max-width: none; }
}
@media (max-width: 767px) {
    .tw-websites-paths__grid, .tw-template-cards, .tw-start-choice-grid, .tw-get-started__what ul { grid-template-columns: 1fr; }
    .tw-template-card__preview { min-height: 230px; }
    .tw-template-gallery__art { min-height: 350px; padding: 30px; }
    .tw-websites-hosting__intro, .tw-get-started__hosting { text-align: center; }
    .tw-websites-hosting__intro p:last-child { margin-right: auto; margin-left: auto; }
    .tw-hosting-option { padding-left: 65px; text-align: left; }
}
