/* ============================================================
   QR vCard Pro — Frontend Portal Stylesheet
   Scoped under .qrvp-portal so theme styles don't bleed in.
   ============================================================ */

.qrvp-portal {
	--qrvp-ink:        #1c1917;
	--qrvp-ink-2:      #44403c;
	--qrvp-ink-3:      #78716c;
	--qrvp-ink-4:      #a8a29e;
	--qrvp-line:       #e7e5e0;
	--qrvp-line-2:     #d6d3d1;
	--qrvp-paper:      #fdfcf9;
	--qrvp-cream:      #f5f1ea;
	--qrvp-accent:     #c2410c;
	--qrvp-accent-h:   #9a3412;
	--qrvp-success:    #15803d;
	--qrvp-error:      #b91c1c;
	--qrvp-radius:     10px;
	--qrvp-radius-sm:  6px;
	--qrvp-shadow-sm:  0 1px 2px rgba(0,0,0,0.04);
	--qrvp-shadow:     0 2px 8px rgba(0,0,0,0.05), 0 1px 3px rgba(0,0,0,0.06);
	--qrvp-shadow-lg:  0 8px 28px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.06);

	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	color: var(--qrvp-ink);
	background: var(--qrvp-cream);
	background-image: radial-gradient(circle at 1px 1px, rgba(0,0,0,0.03) 1px, transparent 0);
	background-size: 22px 22px;
	min-height: 60vh;
	padding: 0 0 60px;
	max-width: 100%;
	box-sizing: border-box;
}

.qrvp-portal * { box-sizing: border-box; }

.qrvp-portal a {
	color: var(--qrvp-accent);
	text-decoration: none;
}
.qrvp-portal a:hover { color: var(--qrvp-accent-h); }

/* ============================================================
   FLASH MESSAGES
   ============================================================ */
.qrvp-flash {
	max-width: 1100px;
	margin: 16px auto;
	padding: 12px 18px;
	border-radius: var(--qrvp-radius-sm);
	font-size: 14px;
	font-weight: 500;
	border-left: 4px solid;
}
.qrvp-flash-success { background: #f0fdf4; border-color: var(--qrvp-success); color: #14532d; }
.qrvp-flash-error   { background: #fef2f2; border-color: var(--qrvp-error);   color: #7f1d1d; }
.qrvp-flash-info    { background: #f0f9ff; border-color: #0369a1;             color: #0c4a6e; }

.qrvp-error { color: var(--qrvp-error); padding: 20px; text-align: center; }

/* ============================================================
   TOP BAR (HEADER)
   ============================================================ */
.qrvp-bar {
	background: var(--qrvp-paper);
	border-bottom: 1px solid var(--qrvp-line);
	padding: 14px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.qrvp-bar-brand {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--qrvp-ink) !important;
	font-weight: 700;
}
.qrvp-bar-logo {
	width: 36px; height: 36px;
	background: var(--qrvp-ink);
	color: #fff;
	border-radius: 8px;
	display: flex; align-items: center; justify-content: center;
}
.qrvp-bar-title {
	font-size: 17px;
	letter-spacing: -0.01em;
}
.qrvp-bar-user {
	display: flex;
	align-items: center;
	gap: 14px;
	font-size: 14px;
}
.qrvp-bar-greeting { color: var(--qrvp-ink-2); }
.qrvp-bar-logout { margin: 0; }
.qrvp-btn-link {
	background: none;
	border: none;
	padding: 0;
	color: var(--qrvp-accent);
	cursor: pointer;
	font-size: 14px;
	font-weight: 500;
	font-family: inherit;
}
.qrvp-btn-link:hover { color: var(--qrvp-accent-h); text-decoration: underline; }

@media (max-width: 600px) {
	.qrvp-bar { flex-direction: column; align-items: stretch; gap: 10px; padding: 12px 16px; }
	.qrvp-bar-user { justify-content: space-between; }
}

/* ============================================================
   PAGE LAYOUT
   ============================================================ */
.qrvp-page {
	max-width: 1100px;
	margin: 24px auto;
	padding: 0 24px;
}

.qrvp-page-head {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 20px;
	flex-wrap: wrap;
}
.qrvp-page-title {
	font-size: 24px;
	font-weight: 800;
	letter-spacing: -0.02em;
	margin: 0;
	flex: 1;
}
.qrvp-back-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--qrvp-ink-3) !important;
	font-weight: 500;
}
.qrvp-back-link:hover { color: var(--qrvp-ink) !important; }

.qrvp-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-bottom: 18px;
	flex-wrap: wrap;
}

/* ============================================================
   STAT TILES
   ============================================================ */
.qrvp-stats-row {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
	margin-bottom: 24px;
}
.qrvp-stats-row-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 720px) {
	.qrvp-stats-row, .qrvp-stats-row-4 { grid-template-columns: 1fr 1fr; }
}

.qrvp-stat-tile {
	background: var(--qrvp-paper);
	border: 1px solid var(--qrvp-line);
	border-radius: var(--qrvp-radius);
	padding: 18px 20px;
	box-shadow: var(--qrvp-shadow-sm);
}
.qrvp-stat-tile-label {
	display: block;
	font-size: 11px;
	font-weight: 700;
	color: var(--qrvp-ink-3);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin-bottom: 8px;
}
.qrvp-stat-tile-value {
	display: block;
	font-size: 30px;
	font-weight: 800;
	letter-spacing: -0.03em;
	color: var(--qrvp-ink);
	line-height: 1;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.qrvp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 18px;
	border: 1px solid transparent;
	border-radius: var(--qrvp-radius-sm);
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.12s ease;
	text-decoration: none !important;
	font-family: inherit;
	line-height: 1.2;
}
.qrvp-btn-primary {
	background: var(--qrvp-accent);
	color: #fff !important;
	border-color: var(--qrvp-accent);
}
.qrvp-btn-primary:hover {
	background: var(--qrvp-accent-h);
	border-color: var(--qrvp-accent-h);
	transform: translateY(-1px);
	box-shadow: var(--qrvp-shadow);
}
.qrvp-btn-secondary {
	background: var(--qrvp-paper);
	color: var(--qrvp-ink) !important;
	border-color: var(--qrvp-line-2);
}
.qrvp-btn-secondary:hover {
	background: var(--qrvp-cream);
	border-color: var(--qrvp-ink-4);
}
.qrvp-btn-block { width: 100%; display: flex; }
.qrvp-btn-large { padding: 14px 22px; font-size: 15px; }
.qrvp-btn-sm    { padding: 7px 12px; font-size: 13px; }

.qrvp-btn-link-red {
	background: none; border: none; padding: 0;
	color: var(--qrvp-error); font-size: 12px; cursor: pointer;
	font-family: inherit;
}
.qrvp-btn-link-red:hover { text-decoration: underline; }

/* ============================================================
   FORMS
   ============================================================ */
.qrvp-form { margin: 0; }
.qrvp-field { margin-bottom: 14px; }
.qrvp-field label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	color: var(--qrvp-ink-2);
	margin-bottom: 6px;
}
.qrvp-portal input[type="text"],
.qrvp-portal input[type="password"],
.qrvp-portal input[type="email"],
.qrvp-portal input[type="url"],
.qrvp-portal input[type="tel"],
.qrvp-portal select,
.qrvp-portal textarea {
	width: 100%;
	padding: 10px 12px;
	background: var(--qrvp-paper);
	border: 1px solid var(--qrvp-line-2);
	border-radius: var(--qrvp-radius-sm);
	font-size: 14px;
	font-family: inherit;
	color: var(--qrvp-ink);
	transition: border-color 0.12s, box-shadow 0.12s;
}
.qrvp-portal input:focus,
.qrvp-portal select:focus,
.qrvp-portal textarea:focus {
	outline: none;
	border-color: var(--qrvp-accent);
	box-shadow: 0 0 0 3px rgba(194, 65, 12, 0.15);
}
.qrvp-portal textarea { resize: vertical; min-height: 80px; }

.qrvp-checkbox {
	display: flex; align-items: center; gap: 8px;
	margin-bottom: 18px;
	font-size: 13px;
}
.qrvp-checkbox input { width: auto; }
.qrvp-checkbox label { margin: 0; }

/* ============================================================
   LOGIN VIEW
   ============================================================ */
.qrvp-login-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 70vh;
	padding: 40px 20px;
}
.qrvp-login-card {
	background: var(--qrvp-paper);
	max-width: 380px;
	width: 100%;
	padding: 36px 32px;
	border-radius: var(--qrvp-radius);
	box-shadow: var(--qrvp-shadow-lg);
	border: 1px solid var(--qrvp-line);
}
.qrvp-login-head {
	text-align: center;
	margin-bottom: 28px;
}
.qrvp-login-icon {
	display: inline-flex;
	align-items: center; justify-content: center;
	width: 56px; height: 56px;
	background: var(--qrvp-ink);
	color: #fff;
	border-radius: 14px;
	margin-bottom: 16px;
}
.qrvp-login-head h1 {
	font-size: 22px;
	font-weight: 800;
	letter-spacing: -0.02em;
	margin: 0 0 6px;
	color: var(--qrvp-ink);
}
.qrvp-login-head p {
	color: var(--qrvp-ink-3);
	font-size: 13px;
	margin: 0;
	line-height: 1.5;
}
.qrvp-login-help {
	text-align: center;
	margin: 16px 0 0;
	font-size: 13px;
}

/* ============================================================
   LIST VIEW — CARD GRID
   ============================================================ */
.qrvp-cards-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 16px;
}

.qrvp-card-tile {
	--qrvp-tile-accent: #c2410c;
	background: var(--qrvp-paper);
	border: 1px solid var(--qrvp-line);
	border-radius: var(--qrvp-radius);
	padding: 18px;
	box-shadow: var(--qrvp-shadow-sm);
	display: flex;
	flex-direction: column;
	gap: 14px;
	transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.qrvp-card-tile:hover {
	box-shadow: var(--qrvp-shadow);
	transform: translateY(-2px);
}
.qrvp-card-tile-head {
	display: flex; gap: 12px;
}
.qrvp-card-avatar {
	width: 56px; height: 56px;
	border-radius: 50%;
	background: var(--qrvp-cream);
	display: flex; align-items: center; justify-content: center;
	overflow: hidden;
	flex-shrink: 0;
	font-weight: 700;
	font-size: 18px;
	color: var(--qrvp-ink-2);
	letter-spacing: -0.02em;
}
.qrvp-card-avatar img {
	width: 100%; height: 100%; object-fit: cover;
}
.qrvp-card-info { flex: 1; min-width: 0; }
.qrvp-card-info h3 {
	margin: 0 0 2px;
	font-size: 15px;
	font-weight: 700;
	color: var(--qrvp-ink);
	letter-spacing: -0.01em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.qrvp-card-info p {
	margin: 0;
	font-size: 12px;
	color: var(--qrvp-ink-3);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.qrvp-card-slug {
	display: inline-block;
	font-family: ui-monospace, "SF Mono", Menlo, monospace;
	font-size: 11px;
	color: var(--qrvp-ink-3) !important;
	margin-top: 4px;
}
.qrvp-card-slug:hover { color: var(--qrvp-accent) !important; }

.qrvp-card-metrics {
	display: flex;
	gap: 14px;
	padding: 10px 0;
	border-top: 1px dashed var(--qrvp-line);
	border-bottom: 1px dashed var(--qrvp-line);
}
.qrvp-card-metric { flex: 1; text-align: center; }
.qrvp-card-metric-value {
	display: block;
	font-size: 22px;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--qrvp-ink);
	line-height: 1;
}
.qrvp-card-metric-label {
	display: block;
	font-size: 10px;
	color: var(--qrvp-ink-3);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-top: 4px;
}

.qrvp-card-actions {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.qrvp-card-btn {
	flex: 1;
	min-width: 0;
	padding: 8px 10px;
	background: var(--qrvp-cream);
	color: var(--qrvp-ink-2) !important;
	font-size: 12px;
	font-weight: 600;
	text-align: center;
	border-radius: var(--qrvp-radius-sm);
	border: 1px solid transparent;
	cursor: pointer;
	font-family: inherit;
	transition: background 0.12s, color 0.12s;
}
.qrvp-card-btn:hover {
	background: var(--qrvp-ink);
	color: #fff !important;
}
.qrvp-card-btn-accent {
	background: var(--qrvp-accent);
	color: #fff !important;
}
.qrvp-card-btn-accent:hover {
	background: var(--qrvp-accent-h);
}
.qrvp-card-btn-danger {
	flex: 0 0 auto;
	padding: 8px 10px;
	color: var(--qrvp-error) !important;
}
.qrvp-card-btn-danger:hover {
	background: var(--qrvp-error);
	color: #fff !important;
}
.qrvp-card-delete-form { margin: 0; flex: 0 0 auto; }

/* Empty state */
.qrvp-empty {
	text-align: center;
	padding: 60px 30px;
	background: var(--qrvp-paper);
	border: 1px dashed var(--qrvp-line-2);
	border-radius: var(--qrvp-radius);
}
.qrvp-empty-icon {
	display: inline-flex;
	align-items: center; justify-content: center;
	width: 80px; height: 80px;
	background: var(--qrvp-cream);
	color: var(--qrvp-ink-4);
	border-radius: 50%;
	margin-bottom: 16px;
}
.qrvp-empty h3 {
	margin: 0 0 8px;
	font-size: 18px;
	font-weight: 700;
	color: var(--qrvp-ink);
}
.qrvp-empty p {
	margin: 0 auto 20px;
	max-width: 460px;
	font-size: 14px;
	color: var(--qrvp-ink-3);
	line-height: 1.6;
}

/* ============================================================
   EDIT VIEW
   ============================================================ */
.qrvp-edit-layout {
	display: grid;
	grid-template-columns: 1fr 280px;
	gap: 24px;
	align-items: start;
}
@media (max-width: 900px) {
	.qrvp-edit-layout { grid-template-columns: 1fr; }
}

.qrvp-edit-main { display: flex; flex-direction: column; gap: 18px; }

.qrvp-section {
	background: var(--qrvp-paper);
	border: 1px solid var(--qrvp-line);
	border-radius: var(--qrvp-radius);
	padding: 22px;
	box-shadow: var(--qrvp-shadow-sm);
}
.qrvp-section-h {
	margin: 0 0 16px;
	font-size: 12px;
	font-weight: 700;
	color: var(--qrvp-ink-3);
	text-transform: uppercase;
	letter-spacing: 0.14em;
}
.qrvp-mini-h {
	margin: 14px 0 10px;
	font-size: 13px;
	font-weight: 700;
	color: var(--qrvp-ink-2);
}
.qrvp-divider {
	height: 1px;
	background: var(--qrvp-line);
	margin: 20px 0 14px;
}

.qrvp-grid-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px 16px;
}
.qrvp-span-2 { grid-column: 1 / -1; }
@media (max-width: 600px) {
	.qrvp-grid-2 { grid-template-columns: 1fr; }
	.qrvp-span-2 { grid-column: 1; }
}

/* Media uploader */
.qrvp-media { display: flex; flex-direction: column; gap: 8px; }
.qrvp-media-preview {
	width: 100px; height: 100px;
	border: 2px dashed var(--qrvp-line-2);
	border-radius: var(--qrvp-radius-sm);
	background: var(--qrvp-cream);
	display: flex; align-items: center; justify-content: center;
	overflow: hidden;
}
.qrvp-media-preview img { width: 100%; height: 100%; object-fit: cover; }
.qrvp-media-empty { font-size: 11px; color: var(--qrvp-ink-4); }
.qrvp-media-btns { display: flex; gap: 8px; align-items: center; }
.qrvp-media-hint {
	margin: 6px 0 0;
	font-size: 11px;
	color: var(--qrvp-ink-3);
	line-height: 1.45;
}

/* Repeater */
.qrvp-rep { display: flex; flex-direction: column; gap: 6px; margin-bottom: 8px; }
.qrvp-rep-row {
	display: grid;
	grid-template-columns: 130px 1fr 32px;
	gap: 6px;
}
.qrvp-rep-x {
	background: var(--qrvp-cream);
	border: 1px solid var(--qrvp-line-2);
	border-radius: var(--qrvp-radius-sm);
	color: var(--qrvp-error);
	font-size: 18px;
	line-height: 1;
	cursor: pointer;
}
.qrvp-rep-x:hover { background: var(--qrvp-error); color: #fff; }

/* Colors */
.qrvp-color-grid { display: grid; gap: 14px; }
.qrvp-color-row {
	display: grid; grid-template-columns: 1fr auto;
	gap: 12px; align-items: center;
}
.qrvp-color-row label { margin: 0; }
.qrvp-color-input {
	display: flex; gap: 8px; align-items: center;
	background: var(--qrvp-cream);
	padding: 4px 12px 4px 4px;
	border-radius: var(--qrvp-radius-sm);
}
.qrvp-color-input input[type="color"] {
	width: 32px; height: 32px;
	border: none; cursor: pointer;
	border-radius: 4px;
	padding: 0;
	background: none;
}
.qrvp-color-input span {
	font-family: ui-monospace, Menlo, monospace;
	font-size: 12px;
	color: var(--qrvp-ink-2);
}

/* Sidebar */
.qrvp-edit-side {
	display: flex; flex-direction: column; gap: 14px;
	position: sticky; top: 20px;
}
.qrvp-side-box {
	background: var(--qrvp-paper);
	border: 1px solid var(--qrvp-line);
	border-radius: var(--qrvp-radius);
	padding: 16px;
	display: flex; flex-direction: column; gap: 10px;
}
.qrvp-side-box h4 {
	margin: 0;
	font-size: 11px;
	font-weight: 700;
	color: var(--qrvp-ink-3);
	text-transform: uppercase;
	letter-spacing: 0.14em;
}
.qrvp-side-box canvas {
	width: 100%; max-width: 200px;
	margin: 0 auto;
	display: block;
	background: #fff;
	border-radius: var(--qrvp-radius-sm);
}
.qrvp-url-readonly {
	font-family: ui-monospace, Menlo, monospace !important;
	font-size: 11px !important;
	text-align: center;
	background: var(--qrvp-cream) !important;
	color: var(--qrvp-ink-2) !important;
}
.qrvp-side-hint p {
	font-size: 12px;
	color: var(--qrvp-ink-3);
	line-height: 1.5;
	margin: 0;
}

@media (max-width: 900px) {
	.qrvp-edit-side { position: static; }
}

/* ============================================================
   STATS VIEW — BAR TABLES + HEATMAP + RECENT
   ============================================================ */
.qrvp-grid-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.qrvp-grid-3col { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
@media (max-width: 900px) {
	.qrvp-grid-2col, .qrvp-grid-3col { grid-template-columns: 1fr; }
}
.qrvp-grid-2col + .qrvp-grid-2col,
.qrvp-grid-2col + .qrvp-grid-3col,
.qrvp-grid-3col + .qrvp-grid-2col,
.qrvp-grid-3col + .qrvp-grid-3col,
.qrvp-section + .qrvp-grid-2col,
.qrvp-section + .qrvp-grid-3col { margin-top: 16px; }

.qrvp-bar-table { width: 100%; border-collapse: collapse; }
.qrvp-bar-table td { padding: 7px 0; font-size: 13px; vertical-align: middle; }
.qrvp-bar-l { width: 32%; color: var(--qrvp-ink); font-weight: 500; padding-right: 10px; }
.qrvp-bar-c { width: 52%; }
.qrvp-bar-fill {
	height: 16px;
	background: linear-gradient(90deg, var(--qrvp-accent), #ea580c);
	border-radius: 3px;
	min-width: 2px;
}
.qrvp-bar-n { width: 16%; text-align: right; font-weight: 600; }

.qrvp-heat {
	display: flex; flex-direction: column; gap: 3px;
	overflow-x: auto;
}
.qrvp-heat-row {
	display: grid;
	grid-template-columns: 30px repeat(24, 1fr);
	gap: 3px; align-items: center;
	min-width: 580px;
}
.qrvp-heat-axis span {
	font-size: 9px;
	color: var(--qrvp-ink-4);
	text-align: center;
	font-weight: 600;
}
.qrvp-heat-day {
	font-size: 11px; color: var(--qrvp-ink-3);
	font-weight: 600; text-align: right; padding-right: 4px;
}
.qrvp-heat-cell {
	aspect-ratio: 1;
	border-radius: 2px;
	background: var(--qrvp-line);
}
.qrvp-heat-cell:hover { transform: scale(1.4); z-index: 2; position: relative; }
.qrvp-heat-0 { background: var(--qrvp-line); }
.qrvp-heat-1 { background: #fed7aa; }
.qrvp-heat-2 { background: #fb923c; }
.qrvp-heat-3 { background: var(--qrvp-accent); }
.qrvp-heat-4 { background: var(--qrvp-accent-h); }

.qrvp-recent {
	display: flex; flex-direction: column;
	max-height: 480px; overflow-y: auto;
}
.qrvp-recent-row {
	display: grid;
	grid-template-columns: 180px 1fr 1fr;
	gap: 12px;
	padding: 10px 0;
	font-size: 13px;
	border-bottom: 1px solid var(--qrvp-line);
}
.qrvp-recent-row:last-child { border-bottom: none; }
.qrvp-recent-time { color: var(--qrvp-ink-2); font-weight: 500; }
.qrvp-recent-loc  { color: var(--qrvp-ink); }
.qrvp-recent-dev  { color: var(--qrvp-ink-3); font-size: 12px; }
@media (max-width: 720px) {
	.qrvp-recent-row { grid-template-columns: 1fr; gap: 2px; }
}

/* ============================================================
   QR VIEW (big preview & download)
   ============================================================ */
.qrvp-qr-box-large {
	display: grid;
	grid-template-columns: minmax(280px, 460px) 1fr;
	gap: 30px;
	align-items: start;
	background: var(--qrvp-paper);
	border: 1px solid var(--qrvp-line);
	border-radius: var(--qrvp-radius);
	padding: 28px;
	box-shadow: var(--qrvp-shadow);
}
@media (max-width: 800px) {
	.qrvp-qr-box-large { grid-template-columns: 1fr; }
}
.qrvp-qr-canvas-wrap {
	background: #fff;
	border-radius: var(--qrvp-radius);
	padding: 20px;
	border: 1px solid var(--qrvp-line);
}
.qrvp-qr-canvas-wrap canvas { width: 100% !important; height: auto !important; max-width: 100%; display: block; }

.qrvp-qr-side { display: flex; flex-direction: column; gap: 18px; }
.qrvp-qr-url-row { display: flex; gap: 6px; }
.qrvp-qr-url-row input { font-family: ui-monospace, Menlo, monospace; font-size: 12px; flex: 1; }
.qrvp-qr-action label { font-size: 12px; }
.qrvp-qr-actions { display: flex; flex-direction: column; gap: 10px; }

.qrvp-qr-tips {
	background: var(--qrvp-cream);
	padding: 14px 16px;
	border-radius: var(--qrvp-radius-sm);
}
.qrvp-qr-tips h4 {
	margin: 0 0 8px;
	font-size: 13px;
	font-weight: 700;
	color: var(--qrvp-ink);
}
.qrvp-qr-tips ul {
	margin: 0;
	padding-left: 18px;
	font-size: 12px;
	color: var(--qrvp-ink-2);
	line-height: 1.6;
}
.qrvp-qr-tips li { margin-bottom: 4px; }

/* ============================================================
   PAGE TITLE wrappers when used inside templates
   ============================================================ */
.qrvp-portal h2.qrvp-page-title { color: var(--qrvp-ink); }
