.mmap-igo360-card {
	box-sizing: border-box;
	position: relative;
	overflow: visible;
	max-width: 920px;
	margin: 0 0 24px;
	padding: 24px;
	background: #fff;
	border: 1px solid rgba(32, 40, 52, .12);
	border-radius: 8px;
	box-shadow: 0 10px 28px rgba(20, 24, 32, .08);
	color: #26313d;
}

.mmap-igo360-card h2 {
	margin: 0 0 18px;
	font-size: 24px;
	line-height: 1.25;
}

.mmap-igo360-clickable-card {
	cursor: pointer;
	transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.mmap-igo360-clickable-card:hover,
.mmap-igo360-clickable-card:focus {
	border-color: rgba(201, 47, 45, .34);
	box-shadow: 0 14px 34px rgba(20, 24, 32, .12);
	outline: none;
	transform: translateY(-1px);
}

.mmap-account-welcome {
	margin: 0 0 22px;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.25;
	color: #1f2933;
}

.mmap-profile-photo-row {
	display: flex;
	align-items: center;
	margin: 0 0 18px;
}

.mmap-igo360-card > .mmap-profile-photo-row {
	position: absolute;
	top: -22px;
	right: 22px;
	margin: 0;
	z-index: 2;
}

.mmap-profile-photo-upload-panel .mmap-profile-photo-row {
	position: static;
	margin: 0 0 18px;
}

.mmap-profile-photo-wrap {
	position: relative;
	width: 92px;
	height: 92px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: linear-gradient(135deg, #c92f2d, #26313d);
	border: 3px solid #fff;
	box-shadow: 0 8px 22px rgba(20, 24, 32, .14);
	color: #fff;
	font-size: 30px;
	font-weight: 700;
	letter-spacing: 0;
}

.mmap-profile-photo {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mmap-profile-photo-upload-panel {
	margin: 0 0 28px;
	padding: 18px;
	border: 1px solid rgba(32, 40, 52, .12);
	border-radius: 8px;
	background: rgba(255, 255, 255, .78);
}

.mmap-profile-photo-upload-panel h3 {
	margin: 0 0 14px;
	font-size: 20px;
	line-height: 1.25;
}

.mmap-profile-photo-upload-form {
	display: grid;
	gap: 10px;
	max-width: 520px;
}

.mmap-profile-photo-upload-form input[type="file"] {
	width: 100%;
	max-width: 100%;
}

.mmap-profile-photo-success {
	margin: 0 0 12px;
	color: #166534;
	font-weight: 700;
}

.mmap-profile-photo-error {
	margin: 0 0 12px;
	color: #b91c1c;
	font-weight: 700;
}

.woocommerce-MyAccount-navigation-link.is-active > a,
.woocommerce-MyAccount-navigation .is-active > a {
	font-weight: 700;
}

.mmap-login-email-notice {
	text-align: center;
	width: 100%;
}

@media (min-width: 769px) {
	.woocommerce-account .woocommerce-MyAccount-navigation {
		width: 165px;
		margin-right: 24px;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul {
		margin: 0;
		padding: 0;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation li a {
		display: block;
		padding: 8px 10px;
		line-height: 1.25;
	}

	.woocommerce-account .woocommerce-MyAccount-content {
		width: calc(100% - 190px);
	}
}

@media (max-width: 768px) {
	.mmap-igo360-card > .mmap-profile-photo-row {
		top: -18px;
		right: 16px;
	}

	.mmap-profile-photo-wrap {
		width: 74px;
		height: 74px;
		font-size: 24px;
	}
}

.mmap-igo360-profile-grid {
	display: grid;
	grid-template-columns: minmax(140px, 220px) minmax(0, 1fr);
	gap: 10px 18px;
	margin: 0 0 18px;
}

.mmap-igo360-profile-grid dt {
	font-weight: 700;
	color: #4d5966;
}

.mmap-igo360-profile-grid dd {
	margin: 0;
	color: #1f2933;
	word-break: break-word;
}

.mmap-payment-activity-note {
	margin: 0 0 18px;
	padding: 12px 14px;
	background: #f8fafc;
	border: 1px solid rgba(32, 40, 52, .1);
	border-radius: 7px;
	color: #4d5966;
	line-height: 1.5;
}

.mmap-payment-activity-list {
	display: grid;
	gap: 14px;
}

.mmap-payment-activity-entry {
	padding: 16px;
	border: 1px solid rgba(32, 40, 52, .12);
	border-radius: 7px;
	background: rgba(255, 255, 255, .82);
}

.mmap-payment-activity-entry h3 {
	margin: 0 0 12px;
	font-size: 16px;
	line-height: 1.25;
	color: #1f2933;
}

.mmap-payment-activity-entry .mmap-igo360-profile-grid {
	margin-bottom: 0;
}

.mmap-previous-updates-list {
	display: grid;
	gap: 10px;
}

.mmap-previous-update-item {
	border: 1px solid rgba(32, 40, 52, .12);
	border-radius: 7px;
	background: rgba(255, 255, 255, .82);
	overflow: hidden;
}

.mmap-previous-update-summary {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 12px 44px 12px 14px;
	cursor: pointer;
	list-style: none;
}

.mmap-previous-update-summary::-webkit-details-marker {
	display: none;
}

.mmap-previous-update-summary::after {
	position: absolute;
	top: 50%;
	right: 14px;
	width: 22px;
	height: 22px;
	border: 1px solid rgba(32, 40, 52, .18);
	border-radius: 50%;
	background: rgba(255, 255, 255, .74);
	color: #1f2933;
	content: "+";
	font-size: 18px;
	font-weight: 700;
	line-height: 19px;
	text-align: center;
	transform: translateY(-50%);
}

.mmap-previous-update-item[open] .mmap-previous-update-summary::after {
	content: "-";
	line-height: 17px;
}

.mmap-previous-update-title {
	font-weight: 700;
}

.mmap-previous-update-date {
	color: #5f6b78;
	font-size: 14px;
	text-align: right;
}

.mmap-previous-update-detail {
	margin: 0;
	padding: 0 14px 14px;
	border-top: 1px solid rgba(32, 40, 52, .1);
	background: rgba(248, 250, 252, .62);
}

.mmap-previous-update-detail p {
	margin-bottom: 0;
}

.mmap-previous-update-detail .mmap-igo360-profile-grid {
	margin-bottom: 0;
	padding-top: 14px;
}

.mmap-attendance-history {
	margin-top: 18px;
}

.mmap-attendance-note {
	margin: 0 0 18px;
	padding: 12px 14px;
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	border-radius: 7px;
	color: #1e3a8a;
	font-weight: 700;
}

.mmap-attendance-history p {
	margin: 0;
	color: #4d5966;
}

.mmap-attendance-history ol {
	display: grid;
	gap: 8px;
	margin: 12px 0 0;
	padding-left: 22px;
}

.mmap-attendance-history li {
	padding-left: 4px;
	color: #1f2933;
}

.mmap-attendance-month {
	margin: 0 0 12px;
	border: 1px solid rgba(32, 40, 52, .12);
	border-radius: 7px;
	background: #fff;
}

.mmap-attendance-month summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 16px;
	cursor: pointer;
	font-weight: 700;
	color: #1f2933;
}

.mmap-attendance-month summary span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 30px;
	min-height: 24px;
	padding: 0 8px;
	border-radius: 999px;
	background: #f3f4f6;
	color: #4d5966;
	font-size: 13px;
}

.mmap-attendance-month[open] {
	box-shadow: 0 6px 18px rgba(20, 24, 32, .06);
}

.mmap-attendance-month[open] ol {
	padding: 0 16px 16px 38px;
}

.mmap-igo360-payment-button,
.mmap-igo360-secondary-button,
.mmap-igo360-action-button {
	box-sizing: border-box;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 12px 22px;
	border-radius: 7px;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
}

.mmap-igo360-payment-button {
	width: min(100%, 360px);
	background: #ff0000 !important;
	color: #fff !important;
	border-color: #ff0000 !important;
	box-shadow: 0 8px 18px rgba(255, 0, 0, .3);
}

.mmap-igo360-secondary-button {
	width: min(100%, 420px);
	background: #fff;
	color: #111827;
	border: 1px solid rgba(32, 40, 52, .18);
	box-shadow: 0 5px 14px rgba(20, 24, 32, .07);
}

.mmap-igo360-payment-action {
	display: flex;
	justify-content: center;
	margin: 20px 0 0;
}

.mmap-igo360-payment-button:hover,
.mmap-igo360-payment-button:focus {
	background: #cc0000 !important;
	border-color: #cc0000 !important;
	color: #fff !important;
}

.mmap-igo360-secondary-button:hover,
.mmap-igo360-secondary-button:focus {
	background: #f7f8fa;
	color: #111827;
	border-color: rgba(32, 40, 52, .3);
}

.mmap-igo360-action-list {
	display: grid;
	gap: 14px;
	max-width: 520px;
}

.mmap-igo360-action-button {
	width: 100%;
	background: #fff;
	color: #111827;
	border: 1px solid rgba(32, 40, 52, .16);
	box-shadow: 0 4px 12px rgba(20, 24, 32, .06);
	font: inherit;
}

.mmap-igo360-action-button:hover,
.mmap-igo360-action-button:focus {
	background: #f7f8fa;
	color: #111827;
	border-color: rgba(32, 40, 52, .28);
}

.mmap-igo360-action-button.is-disabled {
	cursor: pointer;
	opacity: .56;
	box-shadow: none;
}

.mmap-igo360-balance-warning {
	margin: 0 0 18px;
	padding: 12px 14px;
	background: #fff7ed;
	border: 1px solid #fed7aa;
	border-radius: 7px;
	color: #9a3412;
	font-weight: 700;
}

.mmap-igo360-balance-due {
	margin: 0 0 16px;
	color: #b91c1c;
	font-size: 32px;
	font-weight: 800;
	line-height: 1.15;
}

.mmap-igo360-paid-status {
	margin: 0;
	padding: 12px 14px;
	background: #f0fdf4;
	border: 1px solid #bbf7d0;
	border-radius: 7px;
	color: #166534;
	font-weight: 700;
}

.mmap-member-selector-card p {
	margin: 0 0 14px;
	color: #4d5966;
}

.mmap-member-selector-form {
	display: grid;
	grid-template-columns: minmax(220px, 1fr) auto;
	gap: 12px;
	align-items: center;
	max-width: 720px;
}

.mmap-member-selector-form select {
	box-sizing: border-box;
	width: 100%;
	min-height: 44px;
	padding: 8px 10px;
	border: 1px solid rgba(32, 40, 52, .22);
	border-radius: 7px;
	background: #fff;
	color: #1f2933;
	box-shadow: 0 4px 12px rgba(20, 24, 32, .06);
}

.mmap-member-selector-form .mmap-igo360-action-button {
	width: auto;
	min-width: 160px;
}

.mmap-igo360-late-fee-notice {
	margin: 22px 0 0;
	padding: 16px 18px;
	background: #fff;
	border: 1px solid rgba(154, 52, 18, .24);
	border-radius: 7px;
	color: #26313d;
}

.mmap-igo360-late-fee-notice p {
	margin: 0 0 10px;
	font-weight: 700;
}

.mmap-igo360-late-fee-notice ul {
	margin: 0;
	padding-left: 20px;
}

.mmap-igo360-late-fee-notice li {
	margin: 4px 0;
}

.mmap-agreement-download {
	max-width: 260px;
	margin: 0 0 18px;
}

.mmap-agreement-list {
	display: grid;
	gap: 10px;
	margin: 0;
	padding-left: 20px;
}

.mmap-agreement-list li {
	line-height: 1.5;
	color: #26313d;
}

.mmap-igo360-collections-card {
	margin: 16px 0 0;
	padding: 16px 18px;
	background: #f8fafc;
	border: 1px solid rgba(32, 40, 52, .14);
	border-radius: 7px;
	color: #26313d;
}

.mmap-igo360-collections-card p {
	margin: 0 0 12px;
	font-weight: 700;
}

.mmap-igo360-collections-card h3 {
	margin: 0 0 8px;
	font-size: 18px;
	line-height: 1.25;
}

.mmap-igo360-collections-card ul {
	margin: 0;
	padding-left: 20px;
}

.mmap-igo360-collections-card li {
	margin: 4px 0;
}

.mmap-online-address {
	line-height: 1.55;
	color: #1f2933;
}

.mmap-online-orders-heading {
	margin: 0 0 20px;
	font-size: 28px;
	line-height: 1.25;
	color: #1f2933;
}

.mmap-online-orders-note {
	box-sizing: border-box;
	max-width: 920px;
	margin: 0 0 20px;
	padding: 12px 14px;
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	border-radius: 7px;
	color: #1e3a8a;
	font-weight: 700;
	line-height: 1.45;
}

.mmap-online-address-action {
	max-width: 160px;
	margin: 18px 0 0;
}

.mmap-support-chat {
	position: fixed;
	right: 22px;
	bottom: 22px;
	z-index: 99999;
	font-family: inherit;
	color: #1f2933;
}

.mmap-support-chat-toggle {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	min-height: 48px;
	padding: 11px 16px;
	border: 1px solid rgba(215, 25, 32, .52);
	border-radius: 999px;
	background: #d71920;
	color: #fff;
	font-size: 16px;
	font-weight: 800;
	line-height: 1;
	box-shadow: 0 12px 28px rgba(0, 0, 0, .28);
	cursor: pointer;
}

.mmap-support-chat-toggle:hover,
.mmap-support-chat-toggle:focus {
	background: #b9151b;
	color: #fff;
}

.mmap-support-chat-toggle-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: rgba(255, 255, 255, .18);
	font-weight: 900;
}

.mmap-support-chat-panel {
	position: absolute;
	right: 0;
	bottom: 62px;
	box-sizing: border-box;
	width: min(390px, calc(100vw - 28px));
	overflow: hidden;
	border: 1px solid rgba(32, 40, 52, .16);
	border-radius: 8px;
	background: rgba(255, 255, 255, .98);
	box-shadow: 0 22px 60px rgba(0, 0, 0, .34);
}

.mmap-support-chat-panel[hidden] {
	display: none !important;
}

.mmap-support-chat-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 14px;
	padding: 15px 16px;
	background: #111827;
	color: #fff;
}

.mmap-support-chat-header h2 {
	margin: 0 0 3px;
	color: #fff;
	font-size: 18px;
	line-height: 1.2;
}

.mmap-support-chat-header p {
	margin: 0;
	color: rgba(255, 255, 255, .78);
	font-size: 13px;
	line-height: 1.35;
}

.mmap-support-chat-close {
	flex: 0 0 auto;
	width: 30px;
	height: 30px;
	border: 1px solid rgba(255, 255, 255, .24);
	border-radius: 50%;
	background: rgba(255, 255, 255, .12);
	color: #fff;
	font-size: 16px;
	font-weight: 800;
	line-height: 1;
	cursor: pointer;
}

.mmap-support-chat-body {
	padding: 14px;
}

.mmap-support-chat-log {
	display: grid;
	gap: 10px;
	max-height: 300px;
	overflow: auto;
	padding: 2px 2px 10px;
}

.mmap-support-chat-message {
	box-sizing: border-box;
	max-width: 92%;
	padding: 10px 12px;
	border-radius: 8px;
	font-size: 14px;
	line-height: 1.45;
}

.mmap-support-chat-message p {
	margin: 4px 0 0;
}

.mmap-support-chat-message-user {
	justify-self: end;
	background: #d71920;
	color: #fff;
}

.mmap-support-chat-message-bot {
	justify-self: start;
	border: 1px solid rgba(32, 40, 52, .12);
	background: #f8fafc;
	color: #1f2933;
}

.mmap-support-chat-links {
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
	margin-top: 9px;
}

.mmap-support-chat-links a,
.mmap-support-chat-actions button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	padding: 7px 10px;
	border: 1px solid rgba(215, 25, 32, .22);
	border-radius: 7px;
	background: #fff;
	color: #b9151b;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.15;
	text-decoration: none;
	cursor: pointer;
}

.mmap-support-chat-links a:hover,
.mmap-support-chat-links a:focus,
.mmap-support-chat-actions button:hover,
.mmap-support-chat-actions button:focus {
	border-color: rgba(215, 25, 32, .42);
	background: #fff4f4;
	color: #991118;
}

.mmap-support-chat-actions {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	margin: 8px 0 12px;
}

.mmap-support-chat-form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 8px;
}

.mmap-support-chat-form input {
	box-sizing: border-box;
	width: 100%;
	min-height: 42px;
	padding: 9px 11px;
	border: 1px solid rgba(32, 40, 52, .22);
	border-radius: 7px;
	background: #fff;
	color: #1f2933;
	font-size: 15px;
}

.mmap-support-chat-form button {
	min-height: 42px;
	padding: 9px 14px;
	border: 1px solid #d71920;
	border-radius: 7px;
	background: #d71920;
	color: #fff;
	font-weight: 800;
	cursor: pointer;
}

.mmap-support-chat-contact {
	width: 100%;
	max-width: 100%;
}

.mmap-support-chat-contact-form {
	display: grid;
	gap: 8px;
	margin-top: 10px;
}

.mmap-support-chat-contact-form input {
	box-sizing: border-box;
	width: 100%;
	min-height: 38px;
	padding: 8px 10px;
	border: 1px solid rgba(32, 40, 52, .22);
	border-radius: 7px;
	background: #fff;
	color: #1f2933;
	font-size: 14px;
}

.mmap-support-chat-contact-form button {
	min-height: 40px;
	padding: 8px 12px;
	border: 1px solid #d71920;
	border-radius: 7px;
	background: #d71920;
	color: #fff;
	font-weight: 800;
	cursor: pointer;
}

.mmap-support-chat-contact-form button:disabled {
	opacity: .7;
	cursor: wait;
}

.mmap-lost-password-back {
	box-sizing: border-box;
	width: min(920px, calc(100% - 32px));
	margin: 22px auto 34px;
	text-align: center;
}

.mmap-lost-password-back-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 10px 26px;
	border: 2px solid #fff;
	border-radius: 4px;
	background: rgba(0, 0, 0, .45);
	color: #fff;
	font-size: 20px;
	font-weight: 800;
	line-height: 1.1;
	text-decoration: none;
	box-shadow: 0 10px 24px rgba(0, 0, 0, .28);
	cursor: pointer;
}

.mmap-lost-password-back-button:hover,
.mmap-lost-password-back-button:focus {
	background: #d71920;
	color: #fff;
}

@media (max-width: 640px) {
	.woocommerce-account #main-content .container,
	.woocommerce-account .et_pb_row,
	.woocommerce-account .entry-content,
	.woocommerce-account .woocommerce {
		box-sizing: border-box;
		width: 100% !important;
		max-width: none !important;
		padding-left: 8px !important;
		padding-right: 8px !important;
	}

	.woocommerce-account .woocommerce,
	.woocommerce-account .woocommerce-MyAccount-content,
	.woocommerce-account .woocommerce-MyAccount-navigation {
		box-sizing: border-box;
		float: none !important;
		width: 100% !important;
		max-width: none !important;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation {
		margin: 0 0 18px !important;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 8px;
		margin: 0;
		padding: 0;
		list-style: none !important;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation li {
		margin: 0;
		padding: 0 !important;
		list-style: none !important;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation li::before,
	.woocommerce-account .woocommerce-MyAccount-navigation li::after,
	.woocommerce-account .woocommerce-MyAccount-navigation li a::before,
	.woocommerce-account .woocommerce-MyAccount-navigation li a::after {
		content: none !important;
		display: none !important;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation li a {
		display: flex;
		align-items: center;
		justify-content: center;
		min-height: 42px;
		padding: 9px 10px;
		border: 1px solid rgba(32, 40, 52, .14);
		border-radius: 7px;
		background: rgba(255, 255, 255, .72);
		color: #1677b9;
		text-align: center;
		line-height: 1.2;
		text-decoration: none;
		box-shadow: 0 5px 14px rgba(20, 24, 32, .05);
	}

	.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
	.woocommerce-account .woocommerce-MyAccount-navigation li a:hover,
	.woocommerce-account .woocommerce-MyAccount-navigation li a:focus {
		background: rgba(255, 255, 255, .92);
		border-color: rgba(22, 119, 185, .28);
		color: #0f5687;
		box-shadow: 0 6px 16px rgba(20, 24, 32, .08);
	}

	.mmap-account-welcome,
	.mmap-online-orders-heading,
	.mmap-online-orders-note {
		max-width: none;
		width: 100%;
	}

	.mmap-igo360-card {
		width: 100%;
		max-width: none;
		margin: 0 0 18px;
		padding: 18px;
		background: rgba(255, 255, 255, .72);
		border-color: rgba(255, 255, 255, .58);
		box-shadow: 0 14px 34px rgba(20, 24, 32, .14);
		backdrop-filter: blur(5px);
	}

	.mmap-igo360-card h2 {
		font-size: 22px;
	}

	.mmap-igo360-balance-due {
		font-size: 26px;
	}

	.mmap-igo360-profile-grid {
		grid-template-columns: 1fr;
		gap: 4px 0;
	}

	.mmap-igo360-profile-grid dd {
		margin-bottom: 10px;
	}

	.mmap-igo360-payment-button,
	.mmap-igo360-action-button {
		width: 100%;
	}

	.mmap-member-selector-form {
		grid-template-columns: 1fr;
	}

	.mmap-member-selector-form .mmap-igo360-action-button {
		width: 100%;
	}

	.mmap-previous-update-summary {
		align-items: flex-start;
		flex-direction: column;
		gap: 4px;
	}

	.mmap-previous-update-date {
		text-align: left;
	}

	.mmap-support-chat {
		right: 12px;
		bottom: 12px;
		left: auto;
	}

	.mmap-support-chat-toggle {
		margin-left: auto;
		padding: 10px 14px;
	}

	.mmap-support-chat-panel {
		right: 0;
		bottom: 58px;
		width: min(360px, calc(100vw - 24px));
		max-height: min(560px, calc(100vh - 112px));
	}

	.mmap-support-chat-log {
		max-height: min(220px, calc(100vh - 360px));
	}

	.mmap-support-chat-actions {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.mmap-support-chat-form {
		grid-template-columns: 1fr;
	}

	.mmap-support-chat-form button {
		width: 100%;
	}

}
