/*
 * Believe Subscription Customizer — estilos base.
 *
 * Todo es "opt-in" via CSS custom props para que:
 *   (a) los Global Styles de Elementor las puedan pisar,
 *   (b) los widgets de Elementor inyecten overrides por instancia,
 *   (c) el theme pueda redefinir --believe-* en :root.
 */

.believe-subs-selector,
.believe-subs-panel {
	--believe-primary: var(--e-global-color-primary, #2c7a4b);
	--believe-accent:  var(--e-global-color-accent,  #f4a71d);
	--believe-bg:      var(--e-global-color-secondary, #ffffff);
	--believe-card-bg: #ffffff;
	--believe-text:    var(--e-global-color-text, #1f2933);
	--believe-muted:   #667380;
	--believe-border:  #e5e7eb;
	--believe-radius:  12px;
	--believe-gap:     12px;
	--believe-font:    var(--e-global-typography-text-font-family, inherit);

	font-family: var(--believe-font);
	color: var(--believe-text);
}

/* ---------- Selector en product page ---------- */

.believe-subs-selector {
	display: grid;
	gap: var(--believe-gap);
	margin: 16px 0 20px;
}
.believe-subs-mode {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
	border: 0;
	padding: 0;
	margin: 0;
}
.believe-subs-option {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 14px;
	border: 1px solid var(--believe-border);
	border-radius: var(--believe-radius);
	background: var(--believe-bg);
	cursor: pointer;
	transition: border-color .15s, box-shadow .15s, background .15s;
}
.believe-subs-option input { accent-color: var(--believe-primary); }
.believe-subs-option:has(input:checked) {
	border-color: var(--believe-primary);
	box-shadow: 0 0 0 2px color-mix(in srgb, var(--believe-primary) 18%, transparent);
}
.believe-subs-option--featured { position: relative; }
.believe-subs-badge {
	display: inline-block;
	padding: 2px 8px;
	margin-left: 6px;
	background: var(--believe-accent);
	color: #fff;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 700;
}
.believe-subs-details {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--believe-gap);
	padding: 14px;
	border: 1px dashed var(--believe-border);
	border-radius: var(--believe-radius);
	background: color-mix(in srgb, var(--believe-bg) 92%, var(--believe-primary) 8%);
}
.believe-subs-details[hidden] { display: none; }
.believe-subs-field { margin: 0; display: grid; gap: 4px; }
.believe-subs-field label { font-size: 13px; color: var(--believe-muted); }
.believe-subs-field select {
	padding: 10px 12px;
	border: 1px solid var(--believe-border);
	border-radius: calc(var(--believe-radius) - 4px);
	background: #fff;
}
.believe-subs-note {
	grid-column: 1 / -1;
	font-size: 13px;
	color: var(--believe-muted);
	margin: 0;
}

/* ---------- Panel "Mis suscripciones" ---------- */

.believe-subs-panel { display: grid; gap: 16px; }
.believe-subs-empty {
	padding: 24px;
	text-align: center;
	color: var(--believe-muted);
	border: 1px dashed var(--believe-border);
	border-radius: var(--believe-radius);
}
.believe-subs-card {
	background: var(--believe-card-bg);
	border: 1px solid var(--believe-border);
	border-radius: var(--believe-radius);
	padding: 18px 20px;
	display: grid;
	gap: 14px;
	box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.believe-subs-card--on-hold  { border-left: 4px solid #f2b600; }
.believe-subs-card--active   { border-left: 4px solid var(--believe-primary); }
.believe-subs-card--cancelled,
.believe-subs-card--expired  { opacity: .65; }

.believe-subs-card__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}
.believe-subs-card__title { margin: 0; font-size: 18px; }
.believe-subs-chip {
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	background: color-mix(in srgb, var(--believe-primary) 14%, transparent);
	color: var(--believe-primary);
}
.believe-subs-chip--on-hold  { background: #fff4d4; color: #7a5d00; }
.believe-subs-chip--cancelled,
.believe-subs-chip--expired  { background: #eee; color: #555; }

.believe-subs-card__items { margin: 0; padding-left: 18px; color: var(--believe-muted); }

.believe-subs-card__meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: 10px 18px;
	margin: 0;
}
.believe-subs-card__meta > div { margin: 0; }
.believe-subs-card__meta dt { font-size: 12px; color: var(--believe-muted); }
.believe-subs-card__meta dd { margin: 0; font-weight: 600; }

.believe-subs-card__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	padding-top: 10px;
	border-top: 1px solid var(--believe-border);
}
.believe-subs-inline-form {
	display: inline-flex;
	gap: 6px;
	margin: 0;
	align-items: center;
}
.believe-subs-form-day label { font-size: 13px; color: var(--believe-muted); }
.believe-subs-form-day select {
	padding: 6px 10px;
	border: 1px solid var(--believe-border);
	border-radius: calc(var(--believe-radius) - 6px);
	background: #fff;
}

.believe-subs-btn {
	appearance: none;
	cursor: pointer;
	font: inherit;
	padding: 8px 14px;
	border-radius: 999px;
	border: 1px solid var(--believe-primary);
	background: var(--believe-primary);
	color: #fff;
	transition: filter .15s, transform .05s;
}
.believe-subs-btn:hover  { filter: brightness(1.05); }
.believe-subs-btn:active { transform: translateY(1px); }
.believe-subs-btn--ghost {
	background: transparent;
	color: var(--believe-primary);
}
.believe-subs-btn--primary { background: var(--believe-primary); color: #fff; }
.believe-subs-btn--danger {
	background: transparent;
	color: #b91c1c;
	border-color: #fecaca;
}
.believe-subs-btn--danger:hover {
	background: #fef2f2;
	border-color: #fca5a5;
}

/* Disclosure (details/summary) usado para Suspensión Temporal y Cancelar con motivo */
.believe-subs-disclosure {
	display: inline-block;
}
.believe-subs-disclosure[open] {
	display: block;
	width: 100%;
	margin-top: 8px;
	padding: 10px 12px;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	background: #fafafa;
}
.believe-subs-disclosure > summary {
	list-style: none;
	cursor: pointer;
	user-select: none;
}
.believe-subs-disclosure > summary::-webkit-details-marker {
	display: none;
}
.believe-subs-disclosure[open] > summary {
	margin-bottom: 8px;
}
.believe-subs-disclosure__form {
	display: block !important;
}
.believe-subs-link {
	color: var(--believe-primary);
	text-decoration: none;
	margin-left: auto;
	font-weight: 600;
}
.believe-subs-link:hover { text-decoration: underline; }

@media (max-width: 600px) {
	.believe-subs-mode { grid-template-columns: 1fr; }
	.believe-subs-details { grid-template-columns: 1fr; }
	.believe-subs-card__header { flex-wrap: wrap; }
	.believe-subs-link { margin-left: 0; }
}
