/**
 * wwh/itinerary-builder — themed against THEME_STANDARDS.md (§1, §2, §4, §11, §15.5).
 */
.wwh-builder {
	font-family: var( --wp--preset--font-family--body );
	color: var( --wp--preset--color--ink-primary );
}

/* Sign-in card --------------------------------------------------- */
.wwh-builder__signin {
	max-width: 520px;
	margin: 2rem auto;
	padding: 2rem;
	text-align: center;
	background: #fff;
	border: 1px solid var( --wwh-hair-light );
}
.wwh-builder__signin-title {
	font-family: var( --wp--preset--font-family--display );
	font-style: italic;
	font-size: var( --wp--preset--font-size--display-h3 );
	margin: 0 0 0.5rem;
}
.wwh-builder__signin-actions { display: flex; gap: 0.75rem; justify-content: center; }

/* Buttons -------------------------------------------------------- */
.wwh-builder__btn {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 10px 18px;
	background: #fff;
	color: var( --wp--preset--color--ink-primary );
	border: 1px solid var( --wp--preset--color--ink-primary );
	border-radius: 9999px;
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	cursor: pointer;
	text-decoration: none;
	transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}
.wwh-builder__btn:hover {
	background: var( --wp--preset--color--ink-primary );
	color: var( --wp--preset--color--warm-cream );
}
.wwh-builder__btn--primary {
	background: var( --wp--preset--color--ink-primary );
	color: var( --wp--preset--color--warm-cream );
}
.wwh-builder__btn--primary:hover {
	background: var( --wp--preset--color--ink-caption );
	border-color: var( --wp--preset--color--ink-caption );
	color: var( --wp--preset--color--warm-cream );
}
.wwh-builder__btn--share { padding: 8px 14px; }
.wwh-builder__btn[disabled] { opacity: 0.4; cursor: not-allowed; }

/* Layout: list (sidebar) + editor -------------------------------- */
.wwh-builder__layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 24px;
	margin: 16px 0 24px;
}
@media ( max-width: 780px ) {
	.wwh-builder__layout { grid-template-columns: 1fr; }
}

.wwh-builder__list {
	background: #fff;
	border: 1px solid var( --wwh-hair-light );
	padding: 16px;
}
.wwh-builder__list-head {
	display: flex; justify-content: space-between; align-items: center;
	margin-bottom: 12px; gap: 12px;
}
.wwh-builder__list-head h3 {
	margin: 0;
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var( --wp--preset--color--ink-caption );
}
.wwh-builder__list-items { list-style: none; padding: 0; margin: 0; }
.wwh-builder__list-item { margin-bottom: 6px; }
.wwh-builder__list-item.is-active .wwh-builder__list-link {
	background: var( --wp--preset--color--ink-primary );
	color: var( --wp--preset--color--warm-cream );
	border-color: var( --wp--preset--color--ink-primary );
}
.wwh-builder__list-link {
	width: 100%;
	display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
	padding: 10px 12px;
	background: transparent;
	border: 1px solid var( --wwh-hair-light );
	font-family: inherit;
	font-size: var( --wp--preset--font-size--caption );
	color: inherit;
	cursor: pointer;
	text-align: left;
	transition: background-color .2s ease;
}
.wwh-builder__list-link:hover { background: var( --wp--preset--color--warm-cream-2 ); }
.wwh-builder__list-title { flex: 1 0 100%; font-weight: 500; }
.wwh-builder__list-meta {
	color: var( --wp--preset--color--ink-caption );
	font-size: var( --wp--preset--font-size--cap );
}
.wwh-builder__list-empty {
	color: var( --wp--preset--color--ink-caption );
	font-style: italic;
	font-size: var( --wp--preset--font-size--caption );
	padding: 8px;
}

.wwh-builder__badge {
	display: inline-block;
	padding: 2px 10px;
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.04em;
	background: var( --wp--preset--color--warm-cream-2 );
	border-radius: 9999px;
}
.wwh-builder__badge--pub {
	background: var( --wp--preset--color--status-positive );
	color: #fff;
}
.wwh-builder__badge--rev {
	background: var( --wp--preset--color--warm-cream-2 );
	color: var( --wp--preset--color--ink-primary );
}

/* Editor form ---------------------------------------------------- */
.wwh-builder__editor {
	background: #fff;
	border: 1px solid var( --wwh-hair-light );
	padding: 32px;
}
.wwh-builder__form-row { margin-bottom: 20px; }
.wwh-builder__form-row label {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.wwh-builder__label-text {
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var( --wp--preset--color--ink-caption );
}
.wwh-builder__form-row input,
.wwh-builder__form-row select {
	width: 100%; max-width: 520px;
	padding: 10px 14px;
	font-family: var( --wp--preset--font-family--body );
	font-size: var( --wp--preset--font-size--caption );
	border: 1px solid var( --wwh-hair-light );
	border-radius: 9999px;
	background: #fff;
	color: var( --wp--preset--color--ink-primary );
}
.wwh-builder__form-row input:focus,
.wwh-builder__form-row select:focus,
.wwh-builder__form-row input:focus-visible,
.wwh-builder__form-row select:focus-visible {
	outline: none;
	border-color: var( --wp--preset--color--ink-primary );
}
.wwh-builder__form-row input::placeholder {
	color: var( --wp--preset--color--ink-caption );
}
.wwh-builder__form-row--inline { display: flex; gap: 24px; align-items: flex-end; flex-wrap: wrap; }
.wwh-builder__form-row--inline label { flex: 0 0 auto; }
.wwh-builder__form-row--inline label:not( .wwh-builder__field--emoji ) { flex: 1; min-width: 200px; }

/* Emoji field + picker ------------------------------------------- */
.wwh-builder__emoji-wrap {
	display: flex;
	gap: 8px;
	align-items: center;
	position: relative;
}
.wwh-builder__emoji-input {
	width: 5rem !important;
	text-align: center;
	font-size: var( --wp--preset--font-size--prose ) !important;
}
.wwh-builder__emoji-picker { position: relative; }
.wwh-builder__emoji-picker summary {
	display: inline-flex;
	align-items: center;
	padding: 8px 14px;
	background: #fff;
	border: 1px solid var( --wp--preset--color--ink-primary );
	border-radius: 9999px;
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var( --wp--preset--color--ink-primary );
	cursor: pointer;
	list-style: none;
	transition: background-color .2s ease, color .2s ease;
}
.wwh-builder__emoji-picker summary::-webkit-details-marker { display: none; }
.wwh-builder__emoji-picker summary:hover {
	background: var( --wp--preset--color--ink-primary );
	color: var( --wp--preset--color--warm-cream );
}
.wwh-builder__emoji-grid {
	position: absolute;
	top: calc( 100% + 8px );
	right: 0;
	background: #fff;
	border: 1px solid var( --wwh-hair-light );
	padding: 12px;
	display: grid;
	grid-template-columns: repeat( 6, 32px );
	gap: 6px;
	z-index: 5;
}
.wwh-builder__emoji-grid button {
	width: 32px; height: 32px;
	padding: 0;
	background: transparent;
	border: 1px solid transparent;
	border-radius: 0;
	font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", "Twemoji Mozilla", "EmojiOne Color", sans-serif;
	font-size: var( --wp--preset--font-size--body );
	line-height: 1;
	cursor: pointer;
	transition: background-color .2s ease, border-color .2s ease;
}
.wwh-builder__emoji-input {
	font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", "Twemoji Mozilla", "EmojiOne Color", var( --wp--preset--font-family--body ) !important;
}
.wwh-builder__emoji-grid button:hover {
	background: var( --wp--preset--color--warm-cream-2 );
	border-color: var( --wwh-hair-light );
}

/* Stops ---------------------------------------------------------- */
.wwh-builder__stops-heading {
	margin: 24px 0 12px;
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var( --wp--preset--color--ink-caption );
}
.wwh-builder__stops { list-style: none; padding: 0; margin: 0 0 12px; }
.wwh-builder__stops-empty {
	font-style: italic;
	color: var( --wp--preset--color--ink-caption );
	padding: 8px 0;
	font-size: var( --wp--preset--font-size--caption );
}
.wwh-builder__stop {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 12px;
	margin-bottom: 8px;
	background: var( --wp--preset--color--warm-cream );
	border: 1px solid var( --wwh-hair-light );
}
.wwh-builder__stop-card,
.wwh-builder__stop-card--nodetail {
	background: transparent;
}
.wwh-builder__stop-card > summary,
.wwh-builder__stop-card--nodetail {
	display: grid;
	grid-template-columns: 56px auto 1fr auto;
	align-items: center;
	gap: 12px;
	list-style: none;
	cursor: pointer;
}
.wwh-builder__stop-card > summary::-webkit-details-marker { display: none; }
.wwh-builder__stop-photo {
	display: block;
	width: 56px;
	height: 56px;
	object-fit: cover;
	border-radius: 4px;
	background: var( --wp--preset--color--warm-cream-2 );
}
.wwh-builder__stop-photo--placeholder {
	border: 1px dashed var( --wwh-hair-light );
}
.wwh-builder__stop-num {
	font-family: var( --wp--preset--font-family--display );
	font-style: italic;
	font-size: var( --wp--preset--font-size--prose );
	line-height: 1;
	min-width: 1.6rem;
	color: var( --wp--preset--color--ink-caption );
}
.wwh-builder__stop-title {
	font-weight: 500;
	color: var( --wp--preset--color--ink-primary );
	text-decoration: none;
}
.wwh-builder__stop-title:hover { text-decoration: underline; }
.wwh-builder__stop-chevron {
	color: var( --wp--preset--color--ink-caption );
	font-size: var( --wp--preset--font-size--caption );
	transition: transform .2s ease;
}
.wwh-builder__stop-card[ open ] .wwh-builder__stop-chevron { transform: rotate( 180deg ); }
.wwh-builder__stop-detail {
	margin-top: 8px;
	padding: 10px 12px 4px 68px;
	border-top: 1px solid var( --wwh-hair-light );
}
.wwh-builder__stop-detail p {
	margin: 0 0 6px;
	font-size: var( --wp--preset--font-size--caption );
	color: var( --wp--preset--color--ink-primary );
}
.wwh-builder__stop-addr  { color: var( --wp--preset--color--ink-caption ); }
.wwh-builder__stop-hours { color: var( --wp--preset--color--ink-caption ); }
.wwh-builder__stop-blurb { font-style: italic; color: var( --wp--preset--color--ink-caption ); }
.wwh-builder__stop-controls {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	padding-left: 68px;
}
.wwh-builder__stop-note {
	width: 100%;
	padding: 8px 12px;
	font-size: var( --wp--preset--font-size--caption );
	border: 1px solid var( --wwh-hair-light );
	border-radius: 9999px;
	background: #fff;
	font-family: inherit;
}
.wwh-builder__stop-note:focus,
.wwh-builder__stop-note:focus-visible {
	outline: none;
	border-color: var( --wp--preset--color--ink-primary );
}
.wwh-builder__stop-day { font-size: var( --wp--preset--font-size--caption ); white-space: nowrap; }
.wwh-builder__stop-day input { width: 4rem; padding: 4px 10px; margin-left: 8px; }
.wwh-builder__stop-controls .wwh-builder__stop-note { flex: 1 1 220px; min-width: 160px; }
.wwh-builder__stop-actions { display: flex; flex-direction: row; gap: 4px; }
.wwh-builder__stop-actions button {
	width: 28px; height: 26px;
	padding: 0;
	background: #fff;
	border: 1px solid var( --wwh-hair-light );
	border-radius: 9999px;
	cursor: pointer;
	font-size: var( --wp--preset--font-size--caption );
	color: var( --wp--preset--color--ink-primary );
	font-family: inherit;
	transition: background-color .2s ease;
}
.wwh-builder__stop-actions button:hover {
	background: var( --wp--preset--color--warm-cream-2 );
}

/* Picker --------------------------------------------------------- */
.wwh-builder__picker {
	margin: 16px 0;
	padding: 16px;
	background: var( --wp--preset--color--warm-cream );
	border: 1px solid var( --wwh-hair-light );
}
.wwh-builder__picker summary {
	cursor: pointer;
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var( --wp--preset--color--ink-primary );
}
.wwh-builder__picker[ open ] summary { margin-bottom: 12px; }
.wwh-builder__picker input[ type="search" ] {
	width: 100%;
	padding: 10px 14px;
	margin: 8px 0;
	border: 1px solid var( --wwh-hair-light );
	border-radius: 9999px;
	font-family: inherit;
	font-size: var( --wp--preset--font-size--caption );
	background: #fff;
}
.wwh-builder__picker input[ type="search" ]:focus,
.wwh-builder__picker input[ type="search" ]:focus-visible {
	outline: none;
	border-color: var( --wp--preset--color--ink-primary );
}
.wwh-builder__picker-cats { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.wwh-builder__picker-cat {
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 6px 12px;
	background: #fff;
	border: 1px solid var( --wwh-hair-light );
	border-radius: 9999px;
	cursor: pointer;
	color: var( --wp--preset--color--ink-caption );
	transition: background-color .2s ease, color .2s ease;
}
.wwh-builder__picker-cat.is-active {
	background: var( --wp--preset--color--ink-primary );
	color: var( --wp--preset--color--warm-cream );
	border-color: var( --wp--preset--color--ink-primary );
}
.wwh-builder__picker-results {
	list-style: none; margin: 0; padding: 0;
	max-height: 240px; overflow-y: auto;
	border: 1px solid var( --wwh-hair-light );
	background: #fff;
}
.wwh-builder__picker-results li button {
	width: 100%; text-align: left;
	padding: 10px 14px;
	background: transparent;
	border: 0;
	border-bottom: 1px solid var( --wwh-hair-light );
	cursor: pointer;
	font-size: var( --wp--preset--font-size--caption );
	color: inherit;
	font-family: inherit;
	transition: background-color .2s ease;
}
.wwh-builder__picker-results li button:hover { background: var( --wp--preset--color--warm-cream-2 ); }
.wwh-builder__picker-dot {
	display: inline-block;
	width: 8px; height: 8px;
	border-radius: 50%;
	margin-right: 8px;
	vertical-align: middle;
}
.wwh-builder__picker-meta {
	color: var( --wp--preset--color--ink-caption );
	font-size: var( --wp--preset--font-size--caption );
	margin-left: 6px;
}
.wwh-builder__picker-empty {
	padding: 10px 14px;
	font-style: italic;
	color: var( --wp--preset--color--ink-caption );
	font-size: var( --wp--preset--font-size--caption );
}

/* Actions -------------------------------------------------------- */
.wwh-builder__actions {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-top: 24px;
}

/* Share row ------------------------------------------------------ */
.wwh-builder__share {
	margin-top: 24px;
	padding-top: 16px;
	border-top: 1px solid var( --wwh-hair-light );
}
.wwh-builder__share-heading {
	margin: 0 0 8px;
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var( --wp--preset--color--ink-caption );
}
.wwh-builder__share-buttons { display: flex; flex-wrap: wrap; gap: 6px; }
.wwh-builder__share-url {
	margin-top: 8px;
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	font-size: var( --wp--preset--font-size--caption );
	color: var( --wp--preset--color--ink-caption );
	word-break: break-all;
}

/* Status pill ---------------------------------------------------- */
.wwh-builder__status {
	display: inline-block;
	margin-top: 12px;
	padding: 8px 16px;
	font-family: var( --wp--preset--font-family--ui );
	font-size: var( --wp--preset--font-size--cap );
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #fff;
	background: var( --wp--preset--color--status-positive );
	border-radius: 9999px;
	min-height: 1.2em;
	opacity: 0;
	transform: translateY( 4px );
	transition: opacity .2s ease, transform .2s ease;
	pointer-events: none;
}
.wwh-builder__status.is-visible {
	opacity: 1;
	transform: translateY( 0 );
}
.wwh-builder__status.is-error {
	background: var( --wp--preset--color--ink-primary );
}
.wwh-builder__status:empty {
	padding: 0;
	min-height: 0;
}

/* Map ------------------------------------------------------------ */
.wwh-builder__map { margin-top: 24px; }

/* Admin mode (loaded from /manage-itineraries/?post_id=N) ----------- */
/* Single-column layout: plan-list sidebar is hidden, editor stretches full width
   (capped to a readable measure and centred). */
.wwh-builder--admin-mode .wwh-builder__layout {
	grid-template-columns: 1fr;
}
.wwh-builder--admin-mode .wwh-builder__editor {
	max-width: 880px;
	margin: 0 auto;
	width: 100%;
}

.wwh-builder__admin-banner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	padding: 10px 14px;
	margin: 0 0 16px;
	border-radius: 4px;
	background: #f5e6c8;
	color: #1a1613;
	font-family: 'Montserrat', Arial, sans-serif;
	font-size: 14px;
}
.wwh-builder__admin-banner-label { color: #5a544d; }
.wwh-builder__admin-banner-back { margin-left: auto; font-weight: 600; }

.wwh-builder__admin-controls {
	margin: 12px 0 0;
	padding: 10px 12px;
	border: 1px dashed #c8b89c;
	border-radius: 4px;
	background: #fbf6ec;
}
.wwh-builder__admin-featured {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: 'Montserrat', Arial, sans-serif;
	font-size: 14px;
	cursor: pointer;
}
