/**
 * Register Place — 店家登錄 wizard 樣式。
 * 改版重點:寬鬆版面、克制色彩、更穩重的視覺層次。
 */

.register-place-page {
	background: var(--travel-bg);
	min-height: 70vh;
	padding-bottom: 120px;
}

/* ============================================================
 * Hero
 * ============================================================ */
.rp-hero {
	background: var(--travel-primary);
	color: #fff;
	padding: 80px 24px 96px;
	text-align: center;
	overflow: hidden;
	position: relative;
	margin-bottom: 40px;
}
.rp-hero-inner {
	max-width: 820px;
	margin: 0 auto;
	position: relative;
	z-index: 1;
}
.rp-eyebrow {
	display: inline-block;
	padding: 6px 18px;
	border-radius: var(--travel-radius-pill);
	background: rgba(41, 171, 226, 0.15);
	border: 1px solid rgba(41, 171, 226, 0.3);
	color: var(--travel-brand-blue);
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.18em;
	margin: 0 0 24px;
	text-transform: uppercase;
}
.rp-title {
	font-size: 60px;
	font-weight: 800;
	margin: 0 0 22px;
	line-height: 1.05;
	letter-spacing: -0.025em;
	color: #fff;
}
.rp-lead {
	color: #b8c2cc;
	font-size: 18px;
	line-height: 1.75;
	margin: 0 auto;
	max-width: 580px;
	font-weight: 400;
}
.rp-perks {
	list-style: none;
	padding: 0;
	margin: 0;
	display: inline-flex;
	flex-wrap: wrap;
	gap: 12px 28px;
	justify-content: center;
	font-size: 15px;
	color: #d6dce3;
	font-weight: 500;
}
.rp-perks li { display: inline-flex; align-items: center; gap: 10px; }
.rp-perks-icon {
	display: inline-flex;
	width: 22px; height: 22px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(41, 171, 226, 0.4);
	color: var(--travel-brand-blue);
	font-weight: 700;
	font-size: 11px;
	align-items: center;
	justify-content: center;
}
@media (max-width: 768px) {
	.rp-hero { padding: 56px 20px 64px; margin-bottom: 28px; }
	.rp-title { font-size: 38px; }
	.rp-lead { font-size: 16px; margin-bottom: 0; }
}

/* ============================================================
 * Notice banner (universal form hint)
 * ============================================================ */
.rp-notice {
	max-width: 1180px;
	margin: -56px auto 32px;
	padding: 0 24px;
	position: relative;
	z-index: 2;
}
.rp-notice-inner {
	display: flex;
	gap: 14px;
	align-items: flex-start;
	background: var(--travel-surface);
	border: 1px solid var(--travel-border);
	border-radius: var(--travel-radius-lg);
	padding: 18px 24px;
	box-shadow: var(--travel-shadow-md);
}
.rp-notice-icon {
	font-size: 20px;
	line-height: 1.3;
	flex-shrink: 0;
	color: var(--travel-accent);
	margin-top: 2px;
}
.rp-notice-inner p {
	margin: 0;
	color: var(--travel-text-muted);
	font-size: 14.5px;
	line-height: 1.7;
}
.rp-notice-inner b {
	color: var(--travel-primary);
	font-weight: 700;
}

/* ============================================================
 * Shell: 2-column layout (sidebar + wizard)
 * ============================================================ */
.rp-wizard-section {
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 24px;
	position: relative;
	z-index: 2;
}
.rp-shell {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 32px;
	align-items: start;
}
@media (max-width: 900px) {
	.rp-shell { grid-template-columns: 1fr; gap: 16px; }
}

.rp-wizard {
	background: var(--travel-surface);
	border-radius: var(--travel-radius-lg);
	box-shadow: var(--travel-shadow-card);
	overflow: hidden;
	border: 1px solid var(--travel-border);
}

/* ============================================================
 * Sidebar — vertical stepper + illustration
 * ============================================================ */
.rp-sidebar {
	position: sticky;
	top: 24px;
}
.rp-sidebar-inner {
	background: var(--travel-surface);
	border-radius: var(--travel-radius-lg);
	box-shadow: var(--travel-shadow-md);
	border: 1px solid var(--travel-border);
	padding: 28px 24px;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

/* Vertical stepper */
.rp-vstep {
	list-style: none;
	padding: 0;
	margin: 0;
	position: relative;
}
.rp-vstep::before {
	content: '';
	position: absolute;
	left: 14px;
	top: 14px;
	bottom: 14px;
	width: 2px;
	background: var(--travel-bg-soft);
	border-radius: 2px;
}
.rp-vstep-item {
	display: flex;
	gap: 14px;
	padding: 8px 0;
	position: relative;
	min-height: 44px;
}
.rp-vstep-item.is-loading { opacity: 0.5; }
.rp-vstep-dot {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: var(--travel-bg-soft);
	color: var(--travel-text-secondary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	font-weight: 700;
	flex-shrink: 0;
	border: 2px solid #fff;
	position: relative;
	z-index: 1;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.rp-vstep-item.is-current .rp-vstep-dot {
	background: var(--travel-accent);
	color: #fff;
	box-shadow:
		0 0 0 4px rgba(41, 171, 226, 0.18),
		0 4px 12px rgba(41, 171, 226, 0.35);
	transform: scale(1.05);
}
.rp-vstep-item.is-done .rp-vstep-dot {
	background: var(--travel-status-operating);
	color: #fff;
}
.rp-vstep-body {
	flex: 1;
	padding-top: 4px;
}
.rp-vstep-title {
	font-size: 14.5px;
	font-weight: 600;
	color: var(--travel-text-secondary);
	letter-spacing: 0.01em;
	transition: color 0.2s;
}
.rp-vstep-item.is-current .rp-vstep-title { color: var(--travel-primary); font-weight: 700; }
.rp-vstep-item.is-done    .rp-vstep-title { color: var(--travel-primary); }
.rp-vstep-desc {
	font-size: 12.5px;
	color: var(--travel-text-secondary);
	margin-top: 4px;
	line-height: 1.55;
	animation: rp-fade-in 0.3s ease;
}

/* Illustration */
.rp-sidebar-illust {
	color: var(--travel-accent);
	padding: 0 12px;
}
.rp-sidebar-illust svg {
	width: 100%;
	height: auto;
	display: block;
}

/* Sidebar footer note */
.rp-sidebar-foot {
	margin: 0;
	padding: 14px 16px;
	background: var(--travel-bg-soft);
	border-radius: var(--travel-radius-md);
	font-size: 12.5px;
	color: var(--travel-text-muted);
	line-height: 1.6;
	display: flex;
	gap: 8px;
	align-items: flex-start;
}
.rp-sidebar-foot i {
	color: var(--travel-status-operating);
	font-size: 13px;
	margin-top: 2px;
	flex-shrink: 0;
}

/* Mobile — sidebar collapses to horizontal scroll chips on top */
@media (max-width: 900px) {
	.rp-sidebar { position: static; }
	.rp-sidebar-inner { padding: 16px; gap: 12px; }
	.rp-sidebar-illust { display: none; }
	.rp-sidebar-foot { display: none; }
	.rp-vstep {
		display: flex;
		gap: 6px;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 4px;
		margin: -4px;
	}
	.rp-vstep::before { display: none; }
	.rp-vstep-item {
		flex-shrink: 0;
		padding: 4px;
		min-height: auto;
		flex-direction: row;
		align-items: center;
		gap: 8px;
	}
	.rp-vstep-dot { width: 24px; height: 24px; font-size: 11px; }
	.rp-vstep-body { padding: 0; }
	.rp-vstep-title { font-size: 13px; white-space: nowrap; }
	.rp-vstep-desc { display: none; }
}

/* Entry B 補件模式橫幅 */
.rp-contrib-banner {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 24px;
	background: var(--travel-accent-soft);
	border-bottom: 1px solid var(--travel-border);
	color: var(--travel-blue-800);
	font-size: 14.5px;
	font-weight: 600;
}
.rp-contrib-banner i { color: var(--travel-accent); }

/* ============================================================
 * Entry B — 側欄觸發按鈕 + 彈窗(平色)
 * ============================================================ */
.travel-contrib-trigger {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	margin-top: 16px;
	padding: 14px 18px;
	border: none;
	border-radius: var(--travel-radius-btn);
	background: var(--travel-accent);
	color: #fff;
	font: inherit;
	font-size: 15px;
	font-weight: 700;
	cursor: pointer;
	box-shadow: 0 4px 14px rgba(41, 171, 226, 0.28);
	transition: background 0.18s, transform 0.18s;
}
.travel-contrib-trigger:hover { background: var(--travel-accent-hover); transform: translateY(-1px); }
.travel-contrib-trigger svg { flex-shrink: 0; }

.rp-modal {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding: 24px 16px;
	overflow-y: auto;
}
.rp-modal[hidden] { display: none; }
.rp-modal-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(15, 23, 42, 0.55);
}
.rp-modal-dialog {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 680px;
	margin: auto;
}
.rp-modal-close {
	position: absolute;
	top: -14px;
	right: -8px;
	z-index: 2;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: none;
	background: var(--travel-surface);
	color: var(--travel-text-main);
	font-size: 26px;
	line-height: 1;
	cursor: pointer;
	box-shadow: var(--travel-shadow-md);
}
.rp-modal-close:hover { background: var(--travel-bg-soft); }
@media (max-width: 720px) {
	.rp-modal { padding: 12px; }
	.rp-modal-close { top: 6px; right: 6px; }
}

/* Thin progress bar at top of wizard card */
.rp-progress-thin {
	height: 4px;
	background: var(--travel-bg-soft);
	overflow: hidden;
}
.rp-progress-thin .rp-progress-fill {
	height: 100%;
	background: var(--travel-accent);
	transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Step meta label (步驟 N / M) */
.rp-step-meta {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	color: var(--travel-accent);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-bottom: 10px;
}

/* Loading */
.rp-loading-state {
	padding: 120px 20px;
	text-align: center;
	color: var(--travel-text-muted);
}
.rp-spinner {
	width: 42px; height: 42px;
	border: 3px solid var(--travel-border);
	border-top-color: var(--travel-accent);
	border-radius: 50%;
	animation: rp-spin 0.9s linear infinite;
	margin: 0 auto 18px;
}
@keyframes rp-spin { to { transform: rotate(360deg); } }

/* ============================================================
 * Progress (top stepper)
 * ============================================================ */
.rp-progress {
	padding: 36px 48px 0;
}
.rp-progress-track {
	height: 6px;
	background: var(--travel-bg-soft);
	border-radius: 999px;
	overflow: hidden;
	margin-bottom: 22px;
}
.rp-progress-fill {
	height: 100%;
	background: var(--travel-accent);
	transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
	border-radius: 999px;
	box-shadow: 0 1px 3px rgba(41, 171, 226, 0.4);
}
.rp-steps {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 13px;
	color: var(--travel-text-secondary);
	gap: 6px;
	flex-wrap: wrap;
}
.rp-step-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 5px 12px 5px 6px;
	border-radius: var(--travel-radius-pill);
	white-space: nowrap;
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.rp-step-pill.is-current {
	background: var(--travel-tint-hover);
	color: var(--travel-primary);
	font-weight: 600;
}
.rp-step-pill.is-done { color: var(--travel-status-operating); }
.rp-step-pill .rp-step-num {
	width: 24px; height: 24px;
	border-radius: 50%;
	background: var(--travel-bg-soft);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 700;
	color: var(--travel-text-secondary);
	flex-shrink: 0;
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.rp-step-pill.is-current .rp-step-num {
	background: var(--travel-accent);
	color: #fff;
	box-shadow: 0 2px 8px rgba(41, 171, 226, 0.4);
}
.rp-step-pill.is-done .rp-step-num {
	background: var(--travel-status-operating);
	color: #fff;
}

/* ============================================================
 * Step body
 * ============================================================ */
.rp-step-body {
	padding: 40px 48px 32px;
	animation: rp-fade-in 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes rp-fade-in {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: none; }
}
.rp-step-head { margin-bottom: 32px; }
.rp-step-head h2 {
	font-size: 30px;
	font-weight: 700;
	margin: 0 0 8px;
	color: var(--travel-primary);
	letter-spacing: -0.02em;
	line-height: 1.2;
}
.rp-step-head p {
	margin: 0;
	color: var(--travel-text-muted);
	font-size: 15.5px;
	line-height: 1.7;
}

/* Fields */
.rp-field { margin-bottom: 26px; }
.rp-field-label {
	display: block;
	font-weight: 600;
	font-size: 14px;
	color: var(--travel-primary);
	margin-bottom: 8px;
	letter-spacing: 0.01em;
}
.rp-field-label .rp-req {
	color: var(--travel-color-danger);
	margin-left: 3px;
	font-weight: 700;
}
.rp-field-help {
	margin: 8px 0 0;
	font-size: 13px;
	color: var(--travel-text-secondary);
	line-height: 1.6;
}
.rp-field-error {
	margin: 8px 0 0;
	font-size: 13px;
	color: var(--travel-color-danger);
	line-height: 1.6;
	font-weight: 500;
}
.rp-field.is-invalid .rp-input,
.rp-field.is-invalid .rp-textarea,
.rp-field.is-invalid .rp-select {
	border-color: var(--travel-color-danger);
	background: #fef7f7;
}

/* Inputs */
.rp-input,
.rp-textarea,
.rp-select {
	width: 100%;
	font: inherit;
	font-size: 15.5px;
	color: var(--travel-text);
	background: var(--travel-surface);
	border: 1px solid var(--travel-border);
	border-radius: var(--travel-radius-btn);
	padding: 13px 16px;
	box-sizing: border-box;
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.rp-input:hover,
.rp-textarea:hover,
.rp-select:hover {
	border-color: var(--travel-border-strong);
}
.rp-input:focus,
.rp-textarea:focus,
.rp-select:focus {
	outline: none;
	border-color: var(--travel-accent);
	box-shadow: var(--travel-shadow-focus);
	background: var(--travel-surface);
}
.rp-textarea { min-height: 130px; resize: vertical; line-height: 1.7; }
.rp-input-counter {
	display: block;
	text-align: right;
	font-size: 12.5px;
	color: var(--travel-text-secondary);
	margin-top: 6px;
	font-variant-numeric: tabular-nums;
}

/* CPT picker — bigger cards */
.rp-cpt-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 18px;
}
.rp-cpt-card {
	cursor: pointer;
	background: var(--travel-surface);
	border: 1.5px solid var(--travel-border);
	border-radius: var(--travel-radius-md);
	padding: 36px 22px;
	text-align: center;
	transition: all 0.22s cubic-bezier(0.4, 0, 0.2, 1);
	user-select: none;
	position: relative;
}
.rp-cpt-card:hover {
	border-color: rgba(41, 171, 226, 0.4);
	transform: translateY(-3px);
	box-shadow: var(--travel-shadow-md);
}
.rp-cpt-card.is-selected {
	border-color: var(--travel-accent);
	background: var(--travel-accent-soft);
	box-shadow: 0 12px 32px rgba(41, 171, 226, 0.2);
}
.rp-cpt-card-icon {
	font-size: 42px;
	line-height: 1;
	margin-bottom: 18px;
	color: var(--travel-neutral-400);
	transition: all 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}
.rp-cpt-card:hover .rp-cpt-card-icon,
.rp-cpt-card.is-selected .rp-cpt-card-icon {
	color: var(--travel-accent);
	transform: scale(1.1);
}
.rp-cpt-card-name {
	font-weight: 700;
	font-size: 19px;
	color: var(--travel-primary);
	margin: 0 0 6px;
	letter-spacing: -0.005em;
}
.rp-cpt-card-sub {
	font-size: 13px;
	color: var(--travel-text-secondary);
	margin: 0;
}

/* Region grid */
.rp-region-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}
@media (max-width: 540px) { .rp-region-grid { grid-template-columns: 1fr; } }

/* gmaps status */
.rp-gmaps-status {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 8px;
	font-size: 13.5px;
	font-weight: 500;
}
.rp-gmaps-status.is-ok    { color: var(--travel-status-operating); }
.rp-gmaps-status.is-error { color: var(--travel-color-danger); }

/* Checkbox + agree */
.rp-checkbox-row {
	display: flex;
	align-items: center;
	gap: 12px;
	cursor: pointer;
	user-select: none;
}
.rp-checkbox-row input[type="checkbox"] {
	width: 20px; height: 20px;
	accent-color: var(--travel-accent);
	cursor: pointer;
	flex-shrink: 0;
}
.rp-agree-box {
	background: var(--travel-bg-soft);
	border: 1px solid var(--travel-border);
	border-radius: var(--travel-radius-md);
	padding: 16px 20px;
	font-size: 15px;
	color: var(--travel-text);
}

/* Choices — chips */
.rp-choices {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.rp-chip {
	display: inline-block;
	padding: 9px 16px;
	border: 1.5px solid var(--travel-border);
	background: var(--travel-surface);
	border-radius: 10px;
	font-size: 13.5px;
	cursor: pointer;
	transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1);
	user-select: none;
	color: var(--travel-text);
	font-weight: 500;
}
.rp-chip:hover {
	border-color: var(--travel-accent);
	color: var(--travel-accent);
	transform: translateY(-1px);
}
.rp-chip.is-on {
	background: var(--travel-accent);
	color: #fff;
	border-color: var(--travel-accent);
	box-shadow: 0 4px 12px rgba(41, 171, 226, 0.25);
}
.rp-chip input { display: none; }

/* Tristate as segmented */
.rp-segment {
	display: inline-flex;
	border: 1.5px solid var(--travel-border);
	border-radius: var(--travel-radius-btn);
	overflow: hidden;
	background: var(--travel-surface);
	padding: 3px;
	gap: 3px;
}
.rp-segment label {
	padding: 8px 16px;
	font-size: 13.5px;
	cursor: pointer;
	color: var(--travel-text-muted);
	user-select: none;
	transition: all 0.15s;
	border-radius: 6px;
	font-weight: 500;
}
.rp-segment label:hover { color: var(--travel-primary); }
.rp-segment label.is-on {
	background: var(--travel-primary);
	color: #fff;
	box-shadow: 0 2px 6px rgba(8, 73, 107, 0.2);
}
.rp-segment input { display: none; }

/* Two-column row */
.rp-row-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
@media (max-width: 540px) { .rp-row-2 { grid-template-columns: 1fr; } }

/* ============================================================
 * Image uploader — 大氣的拖曳區
 * ============================================================ */
.rp-uploader-host { margin-bottom: 8px; }
.rp-uploader-host + .rp-uploader-host { margin-top: 36px; padding-top: 36px; border-top: 1px dashed var(--travel-border); }

.rp-uploader {
	border: 2.5px dashed var(--travel-border-strong);
	border-radius: var(--travel-radius-lg);
	background: var(--travel-bg);
	padding: 52px 28px;
	text-align: center;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	cursor: pointer;
	position: relative;
}
.rp-uploader:hover,
.rp-uploader.is-drag-over {
	border-color: var(--travel-accent);
	background: var(--travel-accent-soft);
	transform: translateY(-2px);
	box-shadow: 0 16px 40px rgba(41, 171, 226, 0.12);
}
.rp-uploader.is-drag-over { transform: scale(1.01); }
.rp-uploader-icon {
	font-size: 64px;
	margin-bottom: 18px;
	color: var(--travel-accent);
	line-height: 1;
	opacity: 0.9;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.rp-uploader:hover .rp-uploader-icon,
.rp-uploader.is-drag-over .rp-uploader-icon {
	transform: translateY(-4px) scale(1.08);
	opacity: 1;
}
.rp-uploader-title {
	font-weight: 700;
	font-size: 20px;
	color: var(--travel-primary);
	margin: 0 0 8px;
	letter-spacing: -0.005em;
}
.rp-uploader-sub {
	font-size: 14px;
	color: var(--travel-text-muted);
	margin: 0;
	line-height: 1.6;
}
.rp-uploader-sub b { color: var(--travel-primary); font-weight: 600; }

/* Encourage tip */
.rp-encourage {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-top: 18px;
	padding: 14px 18px;
	border-radius: var(--travel-radius-md);
	background: var(--travel-tint-hover);
	border: 1px solid rgba(41, 171, 226, 0.15);
	color: var(--travel-blue-800);
	font-size: 14px;
	line-height: 1.6;
}
.rp-encourage > i {
	font-size: 18px;
	color: var(--travel-accent);
	flex-shrink: 0;
	margin-top: 1px;
}
.rp-encourage b { color: var(--travel-blue-900); font-weight: 700; }

/* Photo grid */
.rp-photos {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: 14px;
	margin-top: 22px;
}
.rp-photo {
	position: relative;
	aspect-ratio: 4 / 3;
	background: var(--travel-bg-soft);
	border-radius: var(--travel-radius-md);
	overflow: hidden;
	box-shadow: var(--travel-shadow-sm);
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	border: 1px solid var(--travel-border);
}
.rp-photo.is-dragging { opacity: 0.4; transform: scale(0.97); }
.rp-photo:hover { box-shadow: var(--travel-shadow-md); transform: translateY(-2px); }
.rp-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

.rp-photo-cover-badge {
	position: absolute;
	top: 10px; left: 10px;
	padding: 4px 11px;
	border-radius: var(--travel-radius-pill);
	background: var(--travel-accent);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	box-shadow: 0 3px 10px rgba(41, 171, 226, 0.4);
	display: inline-flex;
	align-items: center;
	gap: 5px;
}
.rp-photo-cover-badge i { font-size: 10px; }

.rp-photo-remove {
	position: absolute;
	top: 8px; right: 8px;
	width: 28px; height: 28px;
	box-sizing: border-box;
	padding: 0;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.65);
	color: #fff;
	border: none;
	cursor: pointer;
	font-size: 13px;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.18s;
	backdrop-filter: blur(4px);
}
.rp-photo-remove i {
	font-style: normal;
	line-height: 1;
	display: block;
}
.rp-photo-remove:hover {
	background: var(--travel-color-danger);
	transform: scale(1.1);
}
.rp-photo-drag {
	position: absolute;
	bottom: 8px; left: 8px;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	width: 26px; height: 26px;
	border-radius: 6px;
	font-size: 12px;
	cursor: grab;
	user-select: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur(4px);
}
.rp-photo-drag:active { cursor: grabbing; }
.rp-photo-progress {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	height: 4px;
	background: rgba(255, 255, 255, 0.5);
}
.rp-photo-progress-bar {
	height: 100%;
	background: var(--travel-accent);
	transition: width 0.2s;
}
.rp-photo.is-uploading img { opacity: 0.5; }
.rp-photo.is-error { border: 2px solid var(--travel-color-danger); }
.rp-photo-error-msg {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	background: var(--travel-color-danger);
	color: #fff;
	font-size: 11px;
	padding: 5px 6px;
	text-align: center;
}

.rp-photos-counter {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 16px;
	font-size: 14px;
	color: var(--travel-text-muted);
}
.rp-photos-counter b {
	color: var(--travel-accent);
	font-size: 18px;
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

/* ============================================================
 * Footer nav
 * ============================================================ */
.rp-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 24px 48px;
	background: var(--travel-surface-2);
	border-top: 1px solid var(--travel-border);
	gap: 14px;
}
.rp-btn {
	font: inherit;
	font-size: 15px;
	font-weight: 600;
	padding: 13px 26px;
	border-radius: var(--travel-radius-btn);
	cursor: pointer;
	border: 1.5px solid transparent;
	transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1);
	display: inline-flex;
	align-items: center;
	gap: 8px;
	letter-spacing: 0.005em;
}
.rp-btn:active { transform: scale(0.98); }
.rp-btn-primary {
	background: var(--travel-accent);
	color: #fff;
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.15) inset,
		0 4px 14px rgba(41, 171, 226, 0.35);
}
.rp-btn-primary:hover {
	background: var(--travel-accent-hover);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.15) inset,
		0 6px 20px rgba(41, 171, 226, 0.45);
	transform: translateY(-1px);
}
.rp-btn-primary:disabled {
	background: var(--travel-text-secondary);
	box-shadow: none;
	cursor: not-allowed;
	transform: none;
}
.rp-btn-ghost {
	background: var(--travel-surface);
	color: var(--travel-text-muted);
	border-color: var(--travel-border);
}
.rp-btn-ghost:hover {
	color: var(--travel-primary);
	border-color: var(--travel-primary);
	transform: translateY(-1px);
}
.rp-btn-ghost:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }

@media (max-width: 640px) {
	.rp-progress { padding: 28px 24px 0; }
	.rp-step-body { padding: 28px 24px 24px; }
	.rp-footer { padding: 18px 24px; }
	.rp-step-head h2 { font-size: 24px; }
	.rp-uploader { padding: 40px 20px; }
	.rp-uploader-icon { font-size: 52px; }
	.rp-uploader-title { font-size: 17px; }
}

/* ============================================================
 * Success / verify result
 * ============================================================ */
.rp-success {
	padding: 80px 40px;
	text-align: center;
	animation: rp-fade-in 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.rp-success-icon {
	width: 96px; height: 96px;
	border-radius: 50%;
	background: var(--travel-accent);
	color: #fff;
	font-size: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 26px;
	box-shadow: 0 14px 36px rgba(41, 171, 226, 0.35);
	animation: rp-pop 0.55s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes rp-pop {
	0% { transform: scale(0); opacity: 0; }
	100% { transform: scale(1); opacity: 1; }
}
.rp-success h2 {
	font-size: 32px;
	color: var(--travel-primary);
	margin: 0 0 14px;
	font-weight: 700;
	letter-spacing: -0.015em;
}
.rp-success p {
	color: var(--travel-text-muted);
	line-height: 1.8;
	max-width: 500px;
	margin: 0 auto 28px;
	font-size: 15.5px;
}
.rp-success-id {
	display: inline-block;
	padding: 7px 16px;
	background: var(--travel-bg-soft);
	border-radius: var(--travel-radius-pill);
	font-family: 'SF Mono', Menlo, Consolas, monospace;
	font-size: 13px;
	color: var(--travel-text-muted);
	margin-bottom: 22px;
	font-weight: 600;
}
