/**
 * Premium Memberships extension for the phpBB Forum Software package.
 *
 * Frontend stylesheet for the Premium templates (region selector, plans,
 * UCP membership, checkout return).
 *
 * @copyright (c) 2024 Mundo Técnico
 * @license   GNU General Public License, version 2 (GPL-2.0)
 * @version   1.0.0
 *
 * Loaded automatically by templates that declare:
 *   <!-- INCLUDECSS mt_premium.css -->
 *
 * Templates consuming this file:
 *   - premium_body.html               Region selector
 *   - premium_argentina.html          MercadoPago plans grid
 *   - premium_international.html      PayPal plans grid
 *   - premium_return.html             Checkout result page
 *   - ucp_premium_memberships.html    UCP — user's membership panel
 *
 * Conventions:
 *   - All custom classes are prefixed `.mt-` to avoid collisions with phpBB native.
 *   - BEM-like naming: block / block__element / block--modifier.
 *   - Design tokens declared on :root (CSS custom properties).
 *   - phpBB native classes (.panel, .button1, .button2, .table1, .errorbox,
 *     .successbox, .notice, .details, .responsive-table, .rightside) are
 *     never overridden globally — only scoped composition.
 */

/* =============================================================================
   1. Animations
   ========================================================================== */
@keyframes fadeIn {
	0%   { opacity: 0; transform: translateY(10px); }
	to   { opacity: 1; transform: translateY(0); }
}

@keyframes slideUp {
	0%   { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}

@keyframes pulse {
	0%, to { transform: scale(1); }
	50%    { transform: scale(1.05); }
}

/* =============================================================================
   2. Design Tokens (CSS Custom Properties)
   ========================================================================== */
:root {
	/* Brand colours */
	--premium-primary:         #448ebd;
	--premium-primary-hover:   #c14626;
	--premium-primary-light:   #5d88a4;

	/* Backgrounds */
	--premium-bg-main:         #f4f4f4;
	--premium-bg-secondary:    #e4e4e4;
	--premium-bg-white:        #ffffff;
	--premium-bg-soft:         #f8f9fa;

	/* Text */
	--premium-text:            #141414;
	--premium-text-secondary:  #5b5b5b;
	--premium-text-muted:      #a0a0a0;
	--premium-text-dim:        #7f8c8d;

	/* Borders */
	--premium-border:          #e7e7e7;
	--premium-border-light:    #f9f9f9;

	/* Status colours (Tanda 5 additions) */
	--premium-status-success:  #27ae60;
	--premium-status-error:    #e74c3c;
	--premium-status-warning:  #f39c12;
	--premium-status-muted:    #7f8c8d;
	--premium-status-icon-dim: #bdc3c7;

	/* Spacing scale */
	--premium-spacing-xs:      5px;
	--premium-spacing-sm:      10px;
	--premium-spacing-md:      20px;
	--premium-spacing-lg:      30px;

	/* Radii */
	--premium-radius:          5px;
	--premium-radius-sm:       3px;
	--premium-radius-md:       8px;
}

/* =============================================================================
   3. Root wrapper
   ========================================================================== */
.mt-premium {
	margin: 0 0 var(--premium-spacing-md);
	animation: fadeIn .5s ease-in;
	clear: both;
}

/* =============================================================================
   4. Hero
   ========================================================================== */
.mt-hero {
	background: var(--premium-primary);
	background-image: -webkit-linear-gradient(top, rgba(255,255,255,.2) 0, rgba(255,255,255,0) 100%);
	background-image: linear-gradient(to bottom, rgba(255,255,255,.2) 0, rgba(255,255,255,0) 100%);
	color: #fff;
	text-align: center;
	margin-bottom: var(--premium-spacing-md);
	border-radius: var(--premium-radius);
	overflow: hidden;
	box-shadow:
		0 0 1px 1px rgba(255,255,255,.5) inset,
		0 0 3px 1px rgba(128,128,128,.1) inset,
		1px 1px 3px rgba(0,0,0,.15);
}
.mt-hero .inner {
	padding: 25px 20px 20px;
}
.mt-hero__content {
	max-width: 700px;
	margin: 0 auto;
}
.mt-hero__icon {
	color: #fff;
	margin-bottom: 12px;
	animation: pulse 3s ease-in-out infinite;
	opacity: .9;
}
.mt-title {
	margin: 8px 0 12px !important;
	font-size: 3.8em !important;
	line-height: 1.2 !important;
	font-weight: 700 !important;
	font-family: "Trebuchet MS", Arial, Helvetica, sans-serif;
	color: #fff !important;
	text-shadow:
		0 2px 4px rgba(0,0,0,.5),
		0 4px 8px rgba(0,0,0,.3),
		0 0 20px rgba(255,255,255,.2) !important;
	letter-spacing: .5px !important;
}
.mt-sub {
	margin: 0;
	color: rgba(255,255,255,.95);
	font-size: 1.8em !important;
	line-height: 1.6;
	font-weight: 400;
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
}

/* =============================================================================
   5. Alerts
   ========================================================================== */
.mt-alert {
	margin-top: 16px;
	border-radius: var(--premium-radius-sm);
	overflow: hidden;
}
.mt-alert--warning {
	background: var(--premium-bg-white);
	border: 2px solid var(--premium-primary-hover);
}
.mt-alert .inner {
	padding: 12px 16px;
	display: flex;
	align-items: center;
	gap: 12px;
}
.mt-alert .icon {
	color: var(--premium-primary-hover);
	flex-shrink: 0;
	font-size: 1.3em;
}
.mt-alert__text {
	margin: 0;
	color: var(--premium-text);
	font-size: 13px;
	font-weight: 400;
	line-height: 1.4;
}

/* =============================================================================
   6. Plans Grid + Cards
   ========================================================================== */
.mt-grid {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	margin-top: var(--premium-spacing-md);
}
.mt-grid::after {
	content: "";
	display: table;
	clear: both;
}

.mt-card {
	background: var(--premium-bg-main);
	border: 1px solid var(--premium-border-light);
	border-radius: var(--premium-radius);
	padding: 4px 9px;
	background-image:
		-webkit-linear-gradient(left, rgba(255,255,255,0) 0, rgba(255,255,255,.3) 50%, rgba(255,255,255,0) 100%),
		-webkit-linear-gradient(top,  rgba(204,204,204,.2) 0, rgba(204,204,204,.25) 10px, rgba(204,204,204,0) 50px);
	background-image:
		linear-gradient(to right,  rgba(255,255,255,0) 0, rgba(255,255,255,.3) 50%, rgba(255,255,255,0) 100%),
		linear-gradient(to bottom, rgba(204,204,204,.2) 0, rgba(204,204,204,.25) 10px, rgba(204,204,204,0) 50px);
	box-shadow:
		0 0 1px 1px rgba(255,255,255,.5) inset,
		0 0 3px 1px rgba(128,128,128,.1) inset,
		1px 1px 3px rgba(0,0,0,.15),
		0 10px 10px -10px rgba(0,0,0,.2);
	margin-bottom: var(--premium-spacing-sm);
	float: left;
	width: 31%;
	margin-right: 3.5%;
	box-sizing: border-box;
	animation: slideUp .6s ease-out backwards;
	transition: all .3s ease;
	position: relative;
	display: flex;
	flex-direction: column;
}
.mt-card:nth-child(1) { animation-delay: .1s; }
.mt-card:nth-child(2) { animation-delay: .2s; }
.mt-card:nth-child(3) { animation-delay: .3s; margin-right: 0; }
.mt-card:hover {
	transform: translateY(-4px);
	box-shadow:
		0 0 1px 1px rgba(255,255,255,.5) inset,
		0 0 3px 1px rgba(128,128,128,.1) inset,
		1px 1px 5px rgba(0,0,0,.2),
		0 15px 15px -10px rgba(0,0,0,.3);
}
.mt-card .inner {
	padding: 20px 10px;
	min-height: 400px;
	display: flex;
	flex-direction: column;
	flex: 1;
}

/* Variants */
.mt-card--featured {
	border: 2px solid var(--premium-primary);
	background: var(--premium-bg-white);
}
.mt-card--featured::before {
	content: "";
	display: block;
	height: 3px;
	background: var(--premium-primary);
	margin: -20px -10px 20px;
	background-image: -webkit-linear-gradient(top, rgba(255,255,255,.2) 0, rgba(255,255,255,0) 100%);
	background-image: linear-gradient(to bottom, rgba(255,255,255,.2) 0, rgba(255,255,255,0) 100%);
}
.mt-card--recommended {
	border: 2px solid var(--premium-primary);
	background: var(--premium-bg-white);
	box-shadow:
		0 0 1px 1px rgba(255,255,255,.5) inset,
		0 0 3px 1px rgba(128,128,128,.1) inset,
		1px 1px 5px rgba(0,0,0,.2),
		0 8px 20px -6px rgba(68,142,189,.25);
	transform: translateY(-4px);
}
.mt-card--recommended:hover {
	transform: translateY(-8px);
	box-shadow:
		0 0 1px 1px rgba(255,255,255,.5) inset,
		0 0 3px 1px rgba(128,128,128,.1) inset,
		1px 1px 8px rgba(0,0,0,.2),
		0 16px 28px -8px rgba(68,142,189,.3);
}
.mt-card--recommended .inner { padding-top: 40px; }
.mt-card--basic .mt-card__title,
.mt-card--basic .mt-price__amount {
	color: var(--premium-text-secondary);
}
.mt-card--basic .mt-card__title { font-size: 28px; }
.mt-card--basic .mt-price__amount { font-size: 36px; }
.mt-card--basic .mt-button { background: var(--premium-primary-light); }
.mt-card--basic .mt-button:hover { background: var(--premium-primary-hover); }

/* Card pieces */
.mt-card__header {
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--premium-border);
	text-align: center;
}
.mt-card__title {
	margin: 0 0 8px;
	font-size: 32px;
	font-weight: 400;
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
	color: var(--premium-primary);
	line-height: 1.3;
	text-align: center;
	transition: color .3s ease, text-shadow .3s ease;
}
.mt-card:hover .mt-card__title {
	color: var(--premium-primary-hover);
	text-shadow: 0 1px 2px rgba(193,70,38,.2);
}
.mt-card__desc {
	margin: 0;
	color: var(--premium-text-secondary);
	line-height: 1.4;
	font-size: 18px;
	text-align: center;
}

/* Badges */
.mt-card__badge {
	position: absolute;
	top: 0;
	right: 0;
	background: var(--premium-primary-hover);
	color: #fff;
	padding: 6px 12px;
	border-bottom-left-radius: var(--premium-radius-sm);
	font-weight: 700;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: .5px;
	box-shadow: 1px 1px 3px rgba(0,0,0,.2);
	background-image: -webkit-linear-gradient(top, rgba(255,255,255,.2) 0, rgba(255,255,255,0) 100%);
	background-image: linear-gradient(to bottom, rgba(255,255,255,.2) 0, rgba(255,255,255,0) 100%);
}
.mt-card__badge .icon { margin-right: 4px; font-size: 12px; }
.mt-card__badge--professional {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	background: var(--premium-primary);
	color: #fff;
	padding: 8px 14px;
	border-radius: 0;
	font-weight: 700;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: .8px;
	text-align: center;
	box-shadow: 0 2px 4px rgba(68,142,189,.3);
	background-image: linear-gradient(to bottom, rgba(255,255,255,.15) 0, rgba(255,255,255,0) 100%);
}
.mt-card__badge--professional .icon { margin-right: 6px; font-size: 12px; }

/* CTA */
.mt-card__cta {
	margin-top: auto;
	text-align: center;
}
.mt-card__cta form { margin: 0; }

/* =============================================================================
   7. Features list
   ========================================================================== */
.mt-features {
	list-style: none;
	margin: 0 0 16px;
	padding: 0;
	flex-grow: 1;
}
.mt-features__item {
	color: var(--premium-text);
	font-size: 13px;
	line-height: 1.4;
	position: relative;
	padding: 6px 0 6px 20px;
	transition: color .2s ease;
}
.mt-features__item::before {
	content: "";
	font-family: FontAwesome;
	position: absolute;
	left: 0;
	color: var(--premium-status-success);
	font-size: 14px;
}
.mt-features__item:hover { color: var(--premium-primary); }
.mt-features__item .icon {
	margin-right: 8px;
	color: var(--premium-status-success);
	width: 16px;
	display: inline-block;
	text-align: center;
}

/* =============================================================================
   8. Price block
   ========================================================================== */
.mt-price {
	margin: auto 0 16px;
	padding: 16px 0;
	text-align: center;
	border-top: 2px solid var(--premium-border);
}
.mt-price__amount {
	display: block;
	font-size: 42px;
	font-weight: 700;
	color: var(--premium-primary);
	line-height: 1;
	margin-bottom: 6px;
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
}
.mt-price__duration {
	display: block;
	font-size: 14px;
	color: var(--premium-text-secondary);
	font-weight: 400;
}
.mt-price__installments {
	display: inline-block;
	margin-top: 10px;
	padding: 7px 14px;
	font-size: 13px;
	color: #fff;
	background: var(--premium-status-success);
	border-radius: var(--premium-radius-sm);
	letter-spacing: .3px;
	line-height: 1.4;
	font-weight: 700;
	box-shadow: 0 2px 4px rgba(39,174,96,.3);
	animation: fadeIn .8s ease-out .5s backwards;
	background-image: -webkit-linear-gradient(top, rgba(255,255,255,.15) 0, rgba(255,255,255,0) 100%);
	background-image: linear-gradient(to bottom, rgba(255,255,255,.15) 0, rgba(255,255,255,0) 100%);
}
.mt-price__installments .icon { margin-right: 5px; font-size: 12px; }

/* =============================================================================
   9. Buttons
   ========================================================================== */
.mt-button {
	display: inline-block;
	padding: 6px 12px;
	font-size: 15px;
	font-weight: 700;
	text-decoration: none;
	border-radius: var(--premium-radius-sm);
	transition: all .3s ease;
	cursor: pointer;
	border: 0;
	width: 100%;
	box-sizing: border-box;
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
	background: var(--premium-primary);
	color: #fff;
	box-shadow: 0 2px 4px rgba(0,0,0,.2);
}
.mt-button:hover,
.mt-button--primary:hover,
.mt-button--secondary:hover {
	background: var(--premium-primary-hover);
	transform: translateY(-2px);
	box-shadow: 0 4px 8px rgba(193,70,38,.4);
}
.mt-button--primary   { background: var(--premium-primary); color: #fff; }
.mt-button--secondary { background: var(--premium-primary-light); color: #fff; }
.mt-button--featured  { background: var(--premium-primary-hover); }
.mt-button--featured:hover { background: var(--premium-primary); }
.mt-button--recommended {
	background: var(--premium-primary);
	font-size: 16px;
	padding: 8px 14px;
	box-shadow: 0 3px 8px rgba(68,142,189,.35);
}
.mt-button--recommended:hover {
	background: var(--premium-primary-hover);
	transform: translateY(-2px);
	box-shadow: 0 5px 12px rgba(193,70,38,.4);
}
.mt-button .icon { margin-right: 6px; }

.mt-card:hover .mt-button {
	background: var(--premium-primary-hover);
	box-shadow: 0 4px 8px rgba(193,70,38,.3);
}

/* =============================================================================
   10. Region selector
   ========================================================================== */
.mt-region-selector { margin: var(--premium-spacing-lg) 0; }
.mt-region-selector__header {
	text-align: center;
	margin-bottom: var(--premium-spacing-md);
}
.mt-region-selector__title {
	margin: 0 0 8px;
	font-size: 24px;
	font-weight: 400;
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
	color: var(--premium-primary);
}
.mt-region-selector__title .icon { margin-right: 8px; color: var(--premium-primary); }
.mt-region-selector__subtitle {
	margin: 0;
	color: var(--premium-text-secondary);
	font-size: 14px;
}

.mt-region-grid {
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
	justify-content: center;
}
.mt-region-card {
	flex: 1 1 calc(50% - 10px);
	max-width: 450px;
	text-decoration: none;
	display: block;
	transition: all .3s ease;
	position: relative;
}
.mt-region-card:hover { transform: translateY(-6px); }
.mt-region-card .inner {
	padding: 32px 24px;
	text-align: center;
}
.mt-region-card__flag { margin-bottom: 16px; }
.mt-region-card__flag .icon {
	color: var(--premium-primary);
	transition: all .3s ease;
}
.mt-region-card:hover .mt-region-card__flag .icon { transform: scale(1.1); }
.mt-region-card__country {
	margin: 0 0 12px;
	font-size: 21px;
	font-weight: 700;
	color: var(--premium-text);
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
}
.mt-region-card__payment {
	margin: 0 0 12px;
	font-size: 14px;
	color: var(--premium-text-secondary);
	font-weight: 700;
}
.mt-region-card__payment .icon { margin-right: 6px; color: var(--premium-primary); }
.mt-region-card__desc {
	margin: 0 0 20px;
	font-size: 13px;
	color: var(--premium-text-secondary);
	line-height: 1.5;
}
.mt-region-card--argentina     .mt-region-card__flag .icon { color: var(--premium-primary); }
.mt-region-card--international .mt-region-card__flag .icon { color: var(--premium-primary-light); }

/* =============================================================================
   11. Trust badges
   ========================================================================== */
.mt-trust { margin: var(--premium-spacing-lg) 0; }
.mt-trust .inner { padding: 24px 16px; }
.mt-trust__title {
	margin: 0 0 24px;
	font-size: 21px;
	font-weight: 400;
	text-align: center;
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
	color: var(--premium-primary);
}
.mt-trust__title .icon { margin-right: 8px; color: var(--premium-primary); }
.mt-trust__items { display: block; }
.mt-trust__items::after,
.mt-payment-methods__grid::after {
	content: "";
	display: table;
	clear: both;
}
.mt-trust__item {
	float: left;
	width: 24%;
	margin-right: 1.333%;
	text-align: center;
	padding: 16px 8px;
	transition: transform .3s ease;
	box-sizing: border-box;
}
.mt-trust__item:nth-child(4) { margin-right: 0; }
.mt-trust__item:hover { transform: translateY(-4px); }
.mt-trust__item .icon {
	display: block;
	margin-bottom: 12px;
	color: var(--premium-primary);
	opacity: .8;
	transition: all .3s ease;
}
.mt-trust__item:hover .icon,
.mt-payment-method:hover .icon {
	opacity: 1;
	transform: scale(1.1);
}
.mt-trust__text {
	margin: 0;
	font-size: 13px;
	font-weight: 700;
	color: var(--premium-text);
	line-height: 1.4;
}

/* =============================================================================
   12. FAQ
   ========================================================================== */
.mt-faq { margin: var(--premium-spacing-lg) 0; }
.mt-faq .inner { padding: 24px 16px; }
.mt-faq h3 {
	margin: 0 0 20px;
	font-size: 21px;
	font-weight: 400;
	text-align: center;
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
	color: var(--premium-primary);
}
.mt-faq__item {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--premium-border);
}
.mt-faq__item:last-child {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}
.mt-faq__question {
	margin: 0 0 8px;
	font-size: 15px;
	font-weight: 700;
	color: var(--premium-text);
	line-height: 1.4;
}
.mt-faq__question .icon { margin-right: 8px; color: var(--premium-primary); }
.mt-faq__answer {
	margin: 0;
	font-size: 13px;
	color: var(--premium-text-secondary);
	line-height: 1.6;
	padding-left: 24px;
}

/* =============================================================================
   13. Payment methods + Placeholder (legacy, kept for compatibility)
   ========================================================================== */
.mt-payment-methods {
	margin-bottom: 32px;
	padding: 24px;
	background: var(--premium-bg-white);
	border-radius: var(--premium-radius-sm);
	border: 1px solid var(--premium-border);
}
.mt-payment-methods__title {
	margin: 0 0 20px;
	font-size: 18px;
	font-weight: 700;
	color: var(--premium-primary);
	text-align: center;
}
.mt-payment-methods__grid {
	display: block;
	text-align: center;
}
.mt-payment-method {
	display: inline-block;
	width: 30%;
	padding: 16px 10px;
	text-align: center;
	color: var(--premium-text-secondary);
	transition: all .3s ease;
}
.mt-payment-method .icon {
	display: block;
	margin-bottom: 8px;
	font-size: 36px;
	color: var(--premium-primary);
	opacity: .7;
	transition: all .3s ease;
}
.mt-payment-method span { display: block; font-size: 13px; font-weight: 700; }

.mt-placeholder {
	margin: var(--premium-spacing-lg) 0;
	text-align: center;
}
.mt-placeholder .inner { padding: 48px 24px; }
.mt-placeholder__icon {
	color: var(--premium-primary);
	margin-bottom: 20px;
	opacity: .7;
}
.mt-placeholder__title {
	margin: 0 0 12px;
	font-size: 28px;
	font-weight: 400;
	font-family: "Droid Sans", "Open Sans", "Trebuchet MS", Helvetica, Arial, sans-serif;
	color: var(--premium-primary);
}
.mt-placeholder__subtitle,
.mt-placeholder__text {
	margin: 0 0 24px;
	font-size: 16px;
	color: var(--premium-text-secondary);
}
.mt-placeholder__text {
	margin: 0 0 32px;
	font-size: 15px;
	line-height: 1.6;
}

/* =============================================================================
   14. UCP — Membership panels (Tanda 5)
   --------------------------------------------------------------------------
   Used by: ucp_premium_memberships.html
   ========================================================================== */
.mt-ucp-membership { animation: fadeIn .5s ease-in; }
.mt-ucp-membership__details {
	margin: 0 0 var(--premium-spacing-sm);
}
.mt-ucp-membership__details dt {
	font-weight: 700;
	color: var(--premium-text-secondary);
}
.mt-ucp-membership__details dd { color: var(--premium-text); }

/* =============================================================================
   15. Status badges (Tanda 5)
   --------------------------------------------------------------------------
   Used by: ucp_premium_memberships.html (membership status + history rows)
   ========================================================================== */
.mt-status {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-weight: 700;
}
.mt-status .icon { margin-right: 2px; }
.mt-status--active   { color: var(--premium-status-success); }
.mt-status--expired  { color: var(--premium-status-error); }
.mt-status--pending  { color: var(--premium-status-warning); }
.mt-status--muted    { color: var(--premium-status-muted); font-weight: 400; }

/* =============================================================================
   16. Benefits list (Tanda 5)
   --------------------------------------------------------------------------
   Used by: ucp_premium_memberships.html (benefits panel)
   ========================================================================== */
.mt-benefits {
	list-style: none;
	padding: 0;
	margin: var(--premium-spacing-md) 0;
}
.mt-benefits__item {
	padding: 8px 0;
	border-bottom: 1px solid var(--premium-border);
}
.mt-benefits__item:last-child { border-bottom: none; }
.mt-benefits__item .icon { margin-right: 6px; }

/* =============================================================================
   17. Tables (Tanda 5)
   --------------------------------------------------------------------------
   Used by: ucp_premium_memberships.html (history table)
   Composes with phpBB native .table1 and .responsive-table.
   ========================================================================== */
.mt-table-wrap { overflow-x: auto; }
.mt-table-full { width: 100%; }

/* =============================================================================
   18. Return page (Tanda 5)
   --------------------------------------------------------------------------
   Used by: premium_return.html
   Composes with phpBB native .successbox / .notice / .errorbox.
   ========================================================================== */
.mt-return {
	max-width: 700px;
	margin: 40px auto;
}
.mt-return__inner { padding: 30px; }

.mt-return__header { text-align: center; margin-bottom: var(--premium-spacing-lg); }
.mt-return__icon   { margin-bottom: var(--premium-spacing-md); display: block; }
.mt-return__title  { margin-top: 0; }

.mt-return__header--success  .mt-return__title,
.mt-return__icon--success    { color: var(--premium-status-success); }
.mt-return__header--pending  .mt-return__title,
.mt-return__icon--pending    { color: var(--premium-status-warning); }
.mt-return__header--failure  .mt-return__title,
.mt-return__icon--failure    { color: var(--premium-status-error); }
.mt-return__header--unknown  .mt-return__title,
.mt-return__icon--unknown    { color: var(--premium-status-muted); }

.mt-return__box { margin: var(--premium-spacing-md) 0; }

.mt-return__details {
	margin: 25px 0;
	padding: 15px;
	background: var(--premium-bg-soft);
	border-radius: var(--premium-radius);
}
.mt-return__details-title {
	margin: 0 0 var(--premium-spacing-sm);
	color: var(--premium-primary);
	font-size: 16px;
}
.mt-return__details-title .icon { margin-right: 6px; }

.mt-return__details-list { font-size: 13px; }
.mt-return__details-list dt {
	display: inline-block;
	width: 40%;
	font-weight: 700;
	color: var(--premium-text-secondary);
}
.mt-return__details-list dd {
	display: inline-block;
	width: 58%;
	margin: 0;
	vertical-align: top;
}

.mt-return__actions {
	text-align: center;
	margin-top: var(--premium-spacing-lg);
	padding-top: var(--premium-spacing-md);
	border-top: 1px solid var(--premium-border);
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--premium-spacing-xs);
}
.mt-return__action { margin: 0; }

.mt-return__footer {
	margin-top: 25px;
	text-align: center;
	font-size: 12px;
	color: var(--premium-text-dim);
}

/* =============================================================================
   19. Empty states
   --------------------------------------------------------------------------
   .mt-empty       — used in plans grid (BEGINELSE in argentina/international)
   .mt-empty-state — used in UCP when user has no current membership (Tanda 5)
   ========================================================================== */
.mt-empty {
	text-align: center;
	padding: 40px 20px;
	color: var(--premium-text-muted);
}
.mt-empty__icon {
	opacity: .3;
	display: block;
	margin-bottom: var(--premium-spacing-sm);
}

.mt-empty-state {
	text-align: center;
	padding: var(--premium-spacing-lg) var(--premium-spacing-md);
}
.mt-empty-state__icon {
	color: var(--premium-status-icon-dim);
	margin-bottom: var(--premium-spacing-md);
	display: block;
}
.mt-empty-state__text {
	font-size: 15px;
	color: var(--premium-text-dim);
	margin-bottom: var(--premium-spacing-md);
}

/* =============================================================================
   20. Utility classes (Tanda 5)
   --------------------------------------------------------------------------
   Small, composable helpers to avoid inline styles.
   ========================================================================== */

/* Text colour / weight */
.mt-text-link      { color: var(--premium-primary); }
.mt-text-muted     { color: var(--premium-text-dim); }
.mt-text-secondary { color: var(--premium-text-secondary); }
.mt-text-small     { font-size: 13px; }

/* Icon colour */
.mt-icon-success { color: var(--premium-status-success); }

/* Spacing */
.mt-spacing-top-xs  { margin-top: var(--premium-spacing-xs); }
.mt-spacing-top-sm  { margin-top: var(--premium-spacing-sm); }
.mt-spacing-top-md  { margin-top: 15px; }
.mt-spacing-left-xs { margin-left: var(--premium-spacing-xs); }

/* =============================================================================
   21. Responsive breakpoints
   ========================================================================== */
@media (max-width: 900px) {
	.mt-grid { display: flex; flex-wrap: wrap; }
	.mt-card { width: 48%; margin-right: 4%; }
	.mt-card:nth-child(2) { margin-right: 0; }
	.mt-card:nth-child(3) {
		width: 100%;
		margin-right: 0;
		margin-top: var(--premium-spacing-sm);
	}
	.mt-region-grid { gap: 15px; }
	.mt-region-card { flex: 1 1 100%; max-width: 100%; }
	.mt-trust__item {
		width: 48%;
		margin-right: 4%;
		margin-bottom: var(--premium-spacing-sm);
	}
	.mt-trust__item:nth-child(2n),
	.mt-trust__item:nth-child(4) { margin-right: 0; }
}

@media (max-width: 700px) {
	.mt-title { font-size: 2em !important; }
	.mt-sub   { font-size: 1em !important; }
	.mt-grid  { flex-direction: column; }
	.mt-card  {
		float: none;
		width: 100%;
		margin-right: 0;
		margin-bottom: var(--premium-spacing-sm);
	}
	.mt-card .inner { min-height: auto; }
	.mt-card--recommended         { transform: none; }
	.mt-card--recommended:hover   { transform: translateY(-4px); }
	.mt-price__installments       { font-size: 12px; padding: 6px 10px; }
	.mt-region-card .inner        { padding: 24px 16px; }
	.mt-region-selector__title    { font-size: 20px; }
	.mt-trust__item {
		float: none;
		width: 100%;
		margin-right: 0;
		margin-bottom: var(--premium-spacing-sm);
	}
	.mt-price__amount             { font-size: 36px; }
	.mt-payment-method            { width: 100%; margin-bottom: 12px; }
	.mt-placeholder .inner        { padding: 32px 16px; }
	.mt-placeholder__title        { font-size: 22px; }

	/* Return page (Tanda 5) */
	.mt-return                    { margin: var(--premium-spacing-md) auto; }
	.mt-return__inner             { padding: var(--premium-spacing-md); }
	.mt-return__details-list dt,
	.mt-return__details-list dd   { display: block; width: 100%; }
	.mt-return__details-list dd   { margin-bottom: var(--premium-spacing-sm); }
}

@media (max-width: 480px) {
	.mt-hero .inner               { padding: 30px 16px 24px; }
	.mt-title                     { font-size: 1.6em !important; }
	.mt-hero__icon                { font-size: 2em !important; }
	.mt-price__amount             { font-size: 30px; }
	.mt-button                    { font-size: 14px; padding: 5px 10px; }
	.mt-button--recommended       { font-size: 15px; padding: 7px 12px; }
	.mt-card--basic .mt-card__title    { font-size: 24px; }
	.mt-card--basic .mt-price__amount  { font-size: 28px; }
	.mt-price__installments       { font-size: 11px; padding: 5px 8px; }
	.mt-region-card__flag .icon   { font-size: 36px; }
	.mt-region-card__country      { font-size: 18px; }
	.mt-placeholder__icon         { font-size: 3em !important; }
}

/* =============================================================================
   22. Accessibility — focus, motion, print
   ========================================================================== */
.mt-button:focus,
.mt-card:focus-within,
.mt-region-card:focus {
	outline: 2px solid var(--premium-primary);
	outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
	}
	.mt-region-card,
	.mt-region-card__flag .icon,
	.mt-payment-method .icon {
		transition: none;
	}
	.mt-card--recommended,
	.mt-region-card:hover {
		transform: none;
	}
}

@media print {
	.mt-hero {
		background: 0 0 !important;
		color: #000 !important;
	}
	.mt-card,
	.mt-region-card { page-break-inside: avoid; }
	.mt-button       { display: none; }
	.mt-card__badge--professional {
		background: #333 !important;
		color: #fff !important;
	}
	.mt-price__installments {
		border: 1px solid #ccc;
		background: #f5f5f5;
	}
	.mt-return__actions { display: none; }
}