/* KafeKrem loyalty QR registration and sale entry */
.krem-loyalty {
	min-height: 70vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 70px 20px;
	background: #f8f1e7;
}
.krem-loyalty-card {
	width: min(100%, 520px);
	background: #fff;
	border: 1px solid rgba(54, 36, 24, 0.12);
	border-radius: 8px;
	box-shadow: 0 18px 50px rgba(54, 36, 24, 0.14);
	padding: 34px;
	text-align: center;
}
.krem-loyalty-logo {
	display: block;
	width: 150px;
	height: auto;
	margin: 0 auto 22px;
}
.krem-loyalty h1 {
	font-size: 34px;
	line-height: 1.15;
	font-weight: 700;
	color: #2d2018;
	margin: 0 0 18px;
}
.krem-loyalty-form {
	display: grid;
	gap: 16px;
	margin-top: 20px;
}
.krem-loyalty-field {
	text-align: left;
}
.krem-loyalty-register .krem-loyalty-form {
	gap: 10px;
	margin-top: 14px;
}
.krem-loyalty-register .krem-loyalty-field {
	margin: 0;
}
.krem-loyalty-register .krem-loyalty-field label {
	margin-bottom: 5px;
}
.krem-loyalty-register .krem-loyalty-field input {
	min-height: 46px;
	font-size: 18px;
}
.krem-loyalty-register .krem-loyalty-field-hint {
	margin-top: 4px;
}
.krem-loyalty-offer {
	margin-top: 24px;
	padding-top: 18px;
	border-top: 1px solid rgba(54, 36, 24, 0.12);
	text-align: left;
	color: #4f3a2e;
}
.krem-loyalty-offer h2 {
	margin: 0 0 10px;
	font-size: 20px;
	line-height: 1.25;
	color: #2d2018;
}
.krem-loyalty-offer p {
	margin: 0 0 10px;
	font-size: 15px;
	line-height: 1.5;
}
.krem-loyalty-offer p:last-child {
	margin-bottom: 0;
}
.krem-loyalty-qr-ready {
	text-align: left;
	color: #2d2018;
}
.krem-loyalty-qr-ready h2 {
	margin: 0 0 10px;
	font-size: 24px;
	line-height: 1.2;
	color: #2d2018;
	text-align: center;
}
.krem-loyalty-qr-ready h3 {
	margin: 0 0 8px;
	font-size: 19px;
	line-height: 1.25;
	color: #2d2018;
}
.krem-loyalty-qr-ready p {
	margin: 0 0 14px;
	font-size: 16px;
	line-height: 1.5;
}
.krem-loyalty-qr-frame {
	display: flex;
	justify-content: center;
	margin: 20px auto 14px;
	padding: 14px;
	background: #fff;
	border: 2px solid #b69073;
	border-radius: 10px;
}
.krem-loyalty-qr-frame img {
	display: block;
	width: min(280px, 100%);
	height: auto;
}
.krem-loyalty-qr-actions,
.krem-loyalty-share-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
	margin-top: 12px;
}
.krem-loyalty-qr-info,
.krem-loyalty-share-box {
	margin-top: 18px;
	padding: 16px;
	border: 1px solid #eadccc;
	border-radius: 8px;
	background: #fffaf4;
}
.krem-loyalty-share-url {
	word-break: break-word;
	font-size: 14px;
}
.krem-loyalty-share-url a {
	color: #2d2018;
}
.krem-loyalty-field label {
	display: block;
	font-size: 16px;
	font-weight: 700;
	color: #2d2018;
	margin: 0 0 7px;
}
.krem-loyalty-phone-input {
	display: flex;
	align-items: stretch;
	width: 100%;
}
.krem-loyalty-phone-prefix {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 62px;
	margin: 10px 0;
	padding: 0 14px;
	border: 1px solid rgba(54, 36, 24, 0.22);
	border-right: 0;
	border-radius: 8px 0 0 8px;
	background: #f3e6d7;
	color: #2d2018;
	font-size: 18px;
	font-weight: 800;
}
.krem-loyalty-field input {
	width: 100%;
	min-height: 50px;
	border: 1px solid rgba(54, 36, 24, 0.22);
	border-radius: 6px;
	padding: 10px 14px;
	font-size: 20px;
	line-height: 1.2;
	background: #fff;
	color: #2d2018;
}
.krem-loyalty-field .krem-loyalty-phone-input input {
	border-radius: 0 8px 8px 0;
}
.krem-loyalty-field-hint {
	display: block;
	margin-top: 6px;
	font-size: 14px;
	line-height: 1.35;
	color: #7b675a;
}
.krem-loyalty-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 52px;
	border: 0;
	border-radius: 6px;
	padding: 12px 22px;
	background: #2d2018;
	color: #fff;
	font-size: 18px;
	font-weight: 700;
	text-decoration: none;
	cursor: pointer;
}
.krem-loyalty-button:hover,
.krem-loyalty-button:focus {
	background: #5e3b28;
	color: #fff;
}
.krem-loyalty-message {
	padding: 13px 15px;
	border-radius: 6px;
	font-size: 16px;
	line-height: 1.45;
	margin: 0 0 14px;
	text-align: left;
}
.krem-loyalty-message-success {
	background: #edf8ef;
	color: #20652c;
}
.krem-loyalty-message-error {
	background: #fff0ed;
	color: #8a1f11;
}

.krem-loyalty-referrer {
	display: grid;
	gap: 6px;
	margin: 0 0 16px;
	padding: 14px 16px;
	border: 2px solid #b69073;
	border-radius: 8px;
	background: #fffaf4;
	text-align: left;
	color: #2d2018;
}
.krem-loyalty-referrer strong {
	font-size: 17px;
}
.krem-loyalty-referrer span {
	font-size: 14px;
	line-height: 1.45;
	color: #6b5a4d;
}
.krem-loyalty-hp {
	position: absolute;
	left: -9999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}
.krem-loyalty-customer-email {
	font-size: 16px;
	color: #6b5a4d;
	margin: -6px 0 18px;
}
@media (max-width: 560px) {
	.krem-loyalty {
		padding: 40px 14px;
	}
	.krem-loyalty-card {
		padding: 26px 18px;
	}
	.krem-loyalty h1 {
		font-size: 28px;
	}
}

.krem-loyalty-bonus{display:grid;gap:6px;margin:14px 0;padding:14px;border-radius:6px;background:#fff7df;color:#4f321d;text-align:left}
.krem-loyalty-bonus-toggle{display:flex;align-items:center;gap:10px;padding:14px;border:2px solid #8a5a2b;border-radius:6px;background:#fffaf0;color:#2d2018;font-weight:700;cursor:pointer}
.krem-loyalty-bonus-toggle input:checked + span{background:#2d2018;color:#fff}
.krem-loyalty-bonus-toggle span{display:block;width:100%;padding:8px;border-radius:4px}

.krem-loyalty-field textarea {
	width: 100%;
	min-height: 96px;
	border: 1px solid rgba(54, 36, 24, 0.22);
	border-radius: 6px;
	padding: 10px 14px;
	font-size: 18px;
	line-height: 1.35;
	background: #fff;
	color: #2d2018;
	resize: vertical;
}
.krem-loyalty-birthday {
	background: #f2f8ed;
	border: 1px solid rgba(32, 101, 44, 0.18);
	color: #204b26;
}

.krem-loyalty-recent-visits {
	margin-top: 22px;
	padding-top: 16px;
	border-top: 1px solid rgba(54, 36, 24, 0.12);
	text-align: left;
}
.krem-loyalty-recent-visits h3 {
	margin: 0 0 10px;
	font-size: 16px;
	line-height: 1.25;
	color: #2d2018;
}
.krem-loyalty-recent-visits ul {
	display: grid;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.krem-loyalty-recent-visits li {
	padding: 10px 12px;
	border: 1px solid rgba(54, 36, 24, 0.12);
	border-radius: 6px;
	background: #fffaf4;
}
.krem-loyalty-recent-visits strong,
.krem-loyalty-recent-visits span {
	display: block;
}
.krem-loyalty-recent-visits strong {
	font-size: 14px;
	color: #2d2018;
}
.krem-loyalty-recent-visits span {
	margin-top: 3px;
	font-size: 13px;
	line-height: 1.35;
	color: #6b5a4d;
}

.krem-loyalty-scanner-frame {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1;
	margin: 12px 0;
	overflow: hidden;
	border: 2px solid rgba(54, 36, 24, 0.18);
	border-radius: 8px;
	background: #211914;
}
.krem-loyalty-scanner-frame::after {
	content: '';
	position: absolute;
	inset: 12%;
	border: 3px solid rgba(255, 255, 255, 0.72);
	border-radius: 8px;
	pointer-events: none;
}
.krem-loyalty-scanner-frame video {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.krem-loyalty-scanner-actions {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin: 10px 0 12px;
}
.krem-loyalty-button-secondary {
	background: #7b675a;
}
@media (max-width: 420px) {
	.krem-loyalty-scanner-actions {
		grid-template-columns: 1fr;
	}
}

.krem-loyalty-processing[hidden] {
	display: none !important;
}
.krem-loyalty-processing {
	position: fixed;
	z-index: 99999;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background: rgba(45, 32, 24, 0.48);
	backdrop-filter: blur(2px);
}
.krem-loyalty-processing-box {
	display: grid;
	justify-items: center;
	gap: 12px;
	min-width: 190px;
	padding: 26px 28px;
	border-radius: 8px;
	background: #fffaf4;
	box-shadow: 0 22px 55px rgba(31, 22, 16, 0.28);
	color: #2d2018;
	text-align: center;
}
.krem-loyalty-processing-box strong {
	font-size: 20px;
	line-height: 1.2;
}
.krem-loyalty-coffee-loader {
	position: relative;
	display: block;
	width: 52px;
	height: 42px;
	border: 4px solid #6f4d35;
	border-top: 0;
	border-radius: 0 0 15px 15px;
	background: linear-gradient(180deg, #b88a62 0%, #6f4d35 100%);
}
.krem-loyalty-coffee-loader::before {
	content: '';
	position: absolute;
	right: -18px;
	top: 8px;
	width: 17px;
	height: 18px;
	border: 4px solid #6f4d35;
	border-left: 0;
	border-radius: 0 12px 12px 0;
}
.krem-loyalty-coffee-loader::after {
	content: '';
	position: absolute;
	left: 7px;
	top: -25px;
	width: 8px;
	height: 22px;
	border-radius: 999px;
	background: #8f796b;
	box-shadow: 15px 4px 0 #8f796b, 30px 0 0 #8f796b;
	animation: krem-loyalty-steam 1.15s ease-in-out infinite;
}
@keyframes krem-loyalty-steam {
	0% {
		opacity: 0.25;
		transform: translateY(8px) scaleY(0.72);
	}
	50% {
		opacity: 0.85;
		transform: translateY(0) scaleY(1);
	}
	100% {
		opacity: 0.2;
		transform: translateY(-8px) scaleY(0.78);
	}
}

.krem-loyalty-offline-bar,
.krem-loyalty-queue-summary {
	margin: 0;
	padding: 8px 10px;
	border-radius: 6px;
	background: #edf8ef;
	color: #20652c;
	font-size: 15px;
	line-height: 1.35;
	text-align: center;
}
.krem-loyalty-offline-bar.is-offline {
	background: #fff0ed;
	color: #8a1f11;
}
.krem-loyalty-offline-sale {
	margin-top: 22px;
	padding-top: 18px;
	border-top: 1px solid rgba(54, 36, 24, 0.12);
}
.krem-loyalty-offline-sale h2 {
	font-size: 26px;
	line-height: 1.2;
	margin: 0 0 10px;
	color: #2d2018;
}
.krem-loyalty-pending-list {
	margin-top: 18px;
	text-align: left;
}
.krem-loyalty-pending-list h3 {
	font-size: 18px;
	line-height: 1.25;
	margin: 0 0 10px;
	color: #2d2018;
}
.krem-loyalty-pending-item {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 0;
	border-top: 1px solid rgba(54, 36, 24, 0.1);
	font-size: 14px;
	color: #6b5a4d;
}
.krem-loyalty-pending-item strong {
	color: #2d2018;
}

.krem-loyalty-tier {
	display: inline-block;
	margin: 0 0 14px;
	padding: 7px 12px;
	border-radius: 999px;
	background: #f8f1e7;
	color: #2d2018;
	font-size: 15px;
	font-weight: 700;
}
.krem-loyalty-tier-zero {
	background: #ffe8e3;
	color: #8a1f11;
	border: 1px solid rgba(138, 31, 17, 0.25);
}
.krem-loyalty-tier-one {
	background: #fff7df;
	color: #6d430b;
	border: 1px solid rgba(109, 67, 11, 0.24);
}
.krem-loyalty-tier-two {
	background: #edf8ef;
	color: #20652c;
	border: 1px solid rgba(32, 101, 44, 0.22);
}
.krem-loyalty-tier-regular {
	background: #f8f1e7;
	color: #2d2018;
}
.krem-loyalty-meta-text {
	display: inline-block;
	margin-left: 8px;
}
.krem-loyalty-customer-email .krem-loyalty-tier,
.krem-loyalty-search-result .krem-loyalty-tier {
	margin: 0 8px 0 0;
	padding: 5px 10px;
	font-size: 13px;
	line-height: 1.2;
}

.krem-loyalty-link-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 8px auto 0;
	border: 0;
	background: transparent;
	color: #5e3b28;
	font-size: 15px;
	font-weight: 700;
	text-decoration: underline;
	cursor: pointer;
}
.krem-loyalty-search-panel {
	margin-top: 12px;
	padding: 14px;
	border: 1px solid rgba(54, 36, 24, 0.12);
	border-radius: 8px;
	background: #fffaf4;
}
.krem-loyalty-search-results {
	display: grid;
	gap: 8px;
	margin-top: 10px;
}
.krem-loyalty-search-result {
	display: grid;
	gap: 4px;
	width: 100%;
	padding: 12px;
	border: 1px solid rgba(54, 36, 24, 0.16);
	border-radius: 6px;
	background: #fff;
	color: #2d2018;
	text-align: left;
	cursor: pointer;
}
.krem-loyalty-search-result strong {
	font-size: 16px;
}
.krem-loyalty-search-result span,
.krem-loyalty-search-empty {
	font-size: 14px;
	line-height: 1.35;
	color: #6b5a4d;
}

.krem-loyalty-status-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;
	margin: 6px 0 8px;
}
.krem-loyalty-sync-panel {
	display: grid;
	gap: 10px;
	margin-top: 12px;
}
.krem-loyalty-sync-note {
	margin: 0;
	padding: 10px 12px;
	border: 1px solid rgba(54, 36, 24, 0.12);
	border-radius: 8px;
	background: #fffaf4;
	color: #5f4b3d;
	font-size: 14px;
	line-height: 1.4;
}
.krem-loyalty-sync-panel .krem-loyalty-button {
	width: 100%;
}
.krem-loyalty-offline-bar,
.krem-loyalty-queue-summary {
	font-weight: 700;
}
.krem-loyalty-offline-bar.is-online::before,
.krem-loyalty-offline-bar.is-offline::before {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	margin-right: 7px;
	border-radius: 50%;
	vertical-align: 1px;
	background: currentColor;
}
.krem-loyalty-queue-summary.has-pending {
	padding: 10px 12px;
	border-radius: 8px;
	background: #fff7df;
	color: #6d430b;
}
.krem-loyalty-queue-summary.is-offline-pending {
	background: #fff1ed;
	color: #8a1f11;
}
.krem-loyalty-pending-item.is-syncing {
	background: #f8f1e7;
}
.krem-loyalty-pending-item.is-error {
	color: #8a1f11;
}
.krem-loyalty-offline-sale.is-active {
	padding: 18px;
	border: 2px solid rgba(45, 32, 24, 0.16);
	border-radius: 8px;
	background: #fffdf9;
}
.krem-loyalty-bonus.has-bonus {
	align-items: center;
	justify-items: center;
	text-align: center;
	background: #2d2018;
	color: #fff;
}
.krem-loyalty-bonus.has-bonus strong {
	font-size: 44px;
	line-height: 1;
}
.krem-loyalty-bonus.has-birthday-bonus {
	background: #8a1f11;
}
.krem-loyalty-bonus-label {
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0;
	text-transform: uppercase;
	opacity: 0.82;
}
.krem-loyalty-button:disabled {
	opacity: 0.62;
	cursor: wait;
}
@media (max-width: 420px) {
	.krem-loyalty-status-grid {
		grid-template-columns: 1fr;
	}
}


.krem-loyalty-pending-item details,
.krem-loyalty-error-log {
	margin-top: 8px;
	text-align: left;
}
.krem-loyalty-pending-item summary,
.krem-loyalty-error-log summary {
	cursor: pointer;
	font-size: 13px;
	font-weight: 700;
	color: #6d430b;
}
.krem-loyalty-error-log {
	padding: 12px;
	border: 1px solid rgba(138, 31, 17, 0.18);
	border-radius: 6px;
	background: #fffaf4;
}
.krem-loyalty-error-log-item {
	margin-top: 8px;
	padding-top: 8px;
	border-top: 1px solid rgba(54, 36, 24, 0.1);
}
.krem-loyalty-error-log-item strong,
.krem-loyalty-error-log-item span {
	display: block;
}
.krem-loyalty-error-log-item strong {
	font-size: 13px;
	color: #8a1f11;
}
.krem-loyalty-error-log-item span {
	margin-top: 3px;
	font-size: 12px;
	line-height: 1.35;
	color: #6b5a4d;
}

.krem-loyalty-promo-fields {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}
@media (max-width: 560px) {
	.krem-loyalty-promo-fields {
		grid-template-columns: 1fr;
	}
}

.krem-loyalty-referral-prompt {
	display: block;
	margin-top: 8px;
	padding: 10px 12px;
	border-radius: 6px;
	background: #fff4e6;
	color: #5f3218;
	font-weight: 700;
}

.krem-loyalty-account {
	align-items: flex-start;
}
.krem-loyalty-account-card {
	width: min(100%, 900px);
	text-align: left;
}
.krem-loyalty-account-card > .krem-loyalty-logo,
.krem-loyalty-account-card > h1 {
	text-align: center;
}
.krem-loyalty.krem-loyalty-account .krem-loyalty-account-card h1,
.krem-loyalty.krem-loyalty-account .krem-loyalty-account-card h2,
.krem-loyalty.krem-loyalty-account .krem-loyalty-account-card h3 {
	font-family: inherit;
	letter-spacing: 0;
	text-transform: none;
	color: #2d2018;
	text-shadow: none;
}
.krem-loyalty.krem-loyalty-account .krem-loyalty-account-card h1 {
	font-size: 34px;
	line-height: 1.15;
	font-weight: 700;
	margin: 0 0 18px;
}
.krem-loyalty.krem-loyalty-account .krem-loyalty-account-card h2,
.krem-loyalty.krem-loyalty-account .krem-loyalty-share-box h2 {
	font-size: 22px;
	line-height: 1.2;
	font-weight: 700;
	margin: 0 0 10px;
}
.krem-loyalty.krem-loyalty-account .krem-loyalty-account-card h3 {
	font-size: 18px;
	line-height: 1.25;
	font-weight: 700;
	margin: 0 0 8px;
}
.krem-loyalty-employee-level {
	width: fit-content;
	max-width: 100%;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	justify-content: center;
	margin: -6px auto 20px;
	padding: 10px 14px;
	border: 1px solid rgba(54, 36, 24, 0.14);
	border-radius: 999px;
	background: #fff3dd;
	color: #2d2018;
	box-shadow: 0 8px 18px rgba(54, 36, 24, 0.08);
}
.krem-loyalty-employee-level span {
	font-size: 14px;
	font-weight: 700;
	color: #6b5a4d;
}
.krem-loyalty-employee-level strong {
	font-size: 15px;
	line-height: 1.15;
	color: #2d2018;
}
.krem-loyalty-employee-level.krem-loyalty-employee-champion {
	background: #f2f8ed;
	border-color: rgba(32, 101, 44, 0.2);
}
.krem-loyalty-employee-level.krem-loyalty-employee-double-shot,
.krem-loyalty-employee-level.krem-loyalty-employee-pro {
	background: #fff7d8;
}
.krem-loyalty-employee-scanner-link {
	margin: -8px 0 22px;
	text-align: center;
}
.krem-loyalty-employee-scanner-link .krem-loyalty-button {
	min-width: 220px;
	font-size: 20px;
	letter-spacing: 0;
}
.krem-loyalty-account-hero {
	display: grid;
	grid-template-columns: minmax(220px, 300px) 1fr;
	gap: 24px;
	align-items: start;
	margin-top: 18px;
}
.krem-loyalty-account-intro {
	display: flex;
	gap: 16px;
	align-items: center;
	justify-content: space-between;
	padding: 16px;
	border: 1px solid rgba(54, 36, 24, 0.12);
	border-radius: 8px;
	background: #fffaf4;
	color: #2d2018;
}
.krem-loyalty-account-intro strong {
	display: block;
	font-size: 22px;
	line-height: 1.2;
}
.krem-loyalty-account-intro p {
	margin: 6px 0 0;
	font-size: 15px;
	line-height: 1.45;
	color: #5f4b3d;
}
.krem-loyalty-account-kicker {
	display: block;
	margin-bottom: 3px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: uppercase;
	color: #8a623e;
}
.krem-loyalty-account-qr {
	text-align: center;
}
.krem-loyalty-account-qr img {
	display: block;
	width: min(260px, 100%);
	height: auto;
	margin: 0 auto 14px;
	padding: 12px;
	border: 2px solid #b69073;
	border-radius: 10px;
	background: #fff;
}
.krem-loyalty-account-stats {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}
.krem-loyalty-account-stat {
	min-height: 112px;
	display: grid;
	align-content: center;
	gap: 5px;
	padding: 16px;
	border: 1px solid rgba(54, 36, 24, 0.12);
	border-radius: 8px;
	background: #fffaf4;
	color: #2d2018;
}
.krem-loyalty-account-stat.is-saved {
	background: #f2f8ed;
	border-color: rgba(32, 101, 44, 0.2);
}
.krem-loyalty-account-stat span {
	font-size: 13px;
	font-weight: 700;
	color: #6b5a4d;
}
.krem-loyalty-account-stat strong {
	font-size: 30px;
	line-height: 1.05;
	color: #2d2018;
}
.krem-loyalty-account-stat small {
	font-size: 13px;
	color: #6b5a4d;
}
.krem-loyalty-referral-benefit,
.krem-loyalty-birthday-policy {
	display: grid;
	gap: 4px;
	margin: 12px 0;
	padding: 12px 14px;
	border: 1px solid rgba(32, 101, 44, 0.18);
	border-radius: 8px;
	background: #f2f8ed;
	color: #2d2018;
}
.krem-loyalty-referral-benefit strong,
.krem-loyalty-birthday-policy strong {
	font-size: 17px;
	line-height: 1.25;
}
.krem-loyalty-referral-benefit span,
.krem-loyalty-birthday-policy p {
	margin: 0;
	font-size: 14px;
	line-height: 1.45;
	color: #4f3a2e;
}
.krem-loyalty-referral-summary {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 12px;
}
.krem-loyalty-referral-summary span {
	padding: 7px 10px;
	border-radius: 999px;
	background: #fffaf4;
	border: 1px solid rgba(54, 36, 24, 0.1);
	font-size: 13px;
	font-weight: 700;
	color: #4f3a2e;
}
.krem-loyalty-account-shortcut,
.krem-loyalty-account-section {
	margin-top: 22px;
	padding-top: 18px;
	border-top: 1px solid rgba(54, 36, 24, 0.12);
	color: #4f3a2e;
}
.krem-loyalty-account-shortcut strong {
	display: block;
	margin: 0 0 10px;
	font-size: 22px;
	line-height: 1.2;
	color: #2d2018;
}
.krem-loyalty-account-shortcut p,
.krem-loyalty-account-section p {
	margin: 0 0 10px;
	font-size: 15px;
	line-height: 1.5;
}
.krem-loyalty-account-form {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}
.krem-loyalty-account-form .krem-loyalty-button {
	grid-column: 1 / -1;
	justify-self: start;
}
.krem-loyalty-account-history {
	display: grid;
	gap: 8px;
}
.krem-loyalty-referral-list {
	display: grid;
	gap: 8px;
}
.krem-loyalty-referral-row {
	display: grid;
	grid-template-columns: 1fr auto auto;
	gap: 8px;
	align-items: center;
	padding: 12px;
	border: 1px solid rgba(54, 36, 24, 0.1);
	border-radius: 6px;
	background: #fffaf4;
	font-size: 14px;
	color: #4f3a2e;
}
.krem-loyalty-referral-row.is-active {
	background: #f2f8ed;
	border-color: rgba(32, 101, 44, 0.2);
}
.krem-loyalty-referral-row strong {
	color: #2d2018;
}
.krem-loyalty-referral-row span {
	font-weight: 700;
}
.krem-loyalty-referral-row small {
	color: #6b5a4d;
}
.krem-loyalty-history-row {
	display: grid;
	grid-template-columns: 1.2fr repeat(3, minmax(110px, 1fr));
	gap: 8px;
	align-items: center;
	padding: 12px;
	border: 1px solid rgba(54, 36, 24, 0.1);
	border-radius: 6px;
	background: #fffaf4;
	font-size: 14px;
	color: #4f3a2e;
}
.krem-loyalty-history-row strong {
	color: #2d2018;
}
.krem-loyalty-account-logout {
	margin: 24px 0 0;
	text-align: center;
}
.krem-loyalty-account-logout a {
	color: #6d430b;
	font-weight: 700;
}
.krem-loyalty-coupon-panel,
.krem-loyalty-coupon-applied {
	margin: 14px 0;
	padding: 14px;
	border: 1px solid rgba(109, 67, 11, 0.22);
	border-radius: 6px;
	background: #fff8e8;
	color: #2d2018;
}
.krem-loyalty-coupon-panel h2 {
	margin: 0 0 8px;
	font-size: 22px;
	line-height: 1.2;
	color: #2d2018;
}
.krem-loyalty-coupon-image {
	display: block;
	max-width: 100%;
	height: auto;
	margin: 0 0 10px;
	border-radius: 6px;
}
.krem-loyalty-coupon-applied {
	background: #edf8ef;
	border-color: rgba(32, 101, 44, 0.22);
	font-weight: 700;
}
@media (max-width: 760px) {
	.krem-loyalty-account-hero,
	.krem-loyalty-account-form,
	.krem-loyalty-referral-row,
	.krem-loyalty-history-row {
		grid-template-columns: 1fr;
	}
	.krem-loyalty-account-intro {
		align-items: stretch;
		flex-direction: column;
	}
	.krem-loyalty-account-stats {
		grid-template-columns: 1fr;
	}
	.krem-loyalty-account-form .krem-loyalty-button {
		justify-self: stretch;
	}
}
