/**
 * Iron Compound — customer account portal styles.
 * Brand: #B3AE61 gold-tan on black, white-ish text. Scoped under .ic-account.
 */

.ic-account,
.ic-account * {
	box-sizing: border-box !important;
}

.ic-account {
	--ic-gold: #B3AE61 !important;
	--ic-gold-dim: rgba(179, 174, 97, 0.55) !important;
	--ic-gold-soft: rgba(179, 174, 97, 0.08) !important;
	--ic-bg-page: #000000 !important;
	--ic-bg-panel: #0a0a0a !important;
	--ic-bg-field: #141414 !important;
	--ic-border: #B3AE61 !important;
	--ic-border-soft: rgba(179, 174, 97, 0.3) !important;
	--ic-text: #f4f4f4 !important;
	--ic-text-dim: #a8a8a8 !important;
	--ic-error: #f87171 !important;
	--ic-success: #4ade80 !important;
	--ic-radius: 10px !important;
	--ic-radius-sm: 6px !important;

	max-width: 880px !important;
	margin: 32px auto !important;
	padding: 32px !important;
	background: var(--ic-bg-page) !important;
	color: var(--ic-text) !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
	line-height: 1.5 !important;
}

/* ---------- Login (logged-out) view ---------- */

.ic-account--login .ic-account__panel {
	padding: 40px 32px !important;
	background: var(--ic-bg-panel) !important;
	border: 1px solid var(--ic-border) !important;
	border-radius: var(--ic-radius) !important;
}

.ic-account--login .ic-account__title {
	margin: 0 0 12px !important;
	font-size: 26px !important;
	font-weight: 700 !important;
	color: var(--ic-text) !important;
}

.ic-account--login .ic-account__lede {
	margin: 0 0 24px !important;
	font-size: 15px !important;
	color: var(--ic-text-dim) !important;
}

.ic-account-login-form {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
}

.ic-account-field {
	display: flex !important;
	flex-direction: column !important;
	gap: 6px !important;
}

.ic-account-field__label {
	font-weight: 600 !important;
	font-size: 14px !important;
	color: var(--ic-text) !important;
}

.ic-account-field__input {
	display: block !important;
	width: 100% !important;
	padding: 10px 14px !important;
	font-size: 15px !important;
	color: var(--ic-text) !important;
	background: var(--ic-bg-field) !important;
	border: 1px solid var(--ic-border) !important;
	border-radius: var(--ic-radius-sm) !important;
	font-family: inherit !important;
}

.ic-account-field__input:focus {
	outline: none !important;
	border-color: var(--ic-gold) !important;
	box-shadow: 0 0 0 3px rgba(179, 174, 97, 0.25) !important;
}

.ic-account__msg {
	margin: 0 !important;
	padding: 12px 14px !important;
	border-radius: var(--ic-radius-sm) !important;
	font-size: 14px !important;
}

.ic-account__msg.is-success {
	background: rgba(74, 222, 128, 0.08) !important;
	border: 1px solid rgba(74, 222, 128, 0.4) !important;
	color: var(--ic-success) !important;
}

.ic-account__msg.is-error {
	background: rgba(248, 113, 113, 0.08) !important;
	border: 1px solid rgba(248, 113, 113, 0.4) !important;
	color: var(--ic-error) !important;
}

/* ---------- Dashboard (logged-in) view ---------- */

.ic-account__head {
	display: flex !important;
	justify-content: space-between !important;
	align-items: flex-start !important;
	gap: 24px !important;
	padding-bottom: 20px !important;
	margin-bottom: 24px !important;
	border-bottom: 1px solid var(--ic-border) !important;
}

.ic-account__head-left {
	display: flex !important;
	flex-direction: column !important;
	gap: 8px !important;
}

.ic-account__kicker {
	display: inline-block !important;
	padding: 4px 12px !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 1px !important;
	text-transform: uppercase !important;
	color: var(--ic-gold) !important;
	background: var(--ic-gold-soft) !important;
	border: 1px solid var(--ic-border) !important;
	border-radius: 999px !important;
	width: fit-content !important;
}

.ic-account--dashboard .ic-account__title {
	margin: 0 !important;
	font-size: 28px !important;
	font-weight: 700 !important;
	color: var(--ic-text) !important;
}

.ic-account__logout {
	flex-shrink: 0 !important;
	padding: 8px 16px !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	color: var(--ic-gold) !important;
	background: transparent !important;
	border: 1px solid var(--ic-border) !important;
	border-radius: var(--ic-radius-sm) !important;
	text-decoration: none !important;
	transition: background 0.15s ease !important;
}

.ic-account__logout:hover {
	background: var(--ic-gold-soft) !important;
	color: var(--ic-gold) !important;
}

/* Tab navigation */

.ic-account__tabs {
	display: flex !important;
	gap: 4px !important;
	margin-bottom: 24px !important;
	border-bottom: 1px solid var(--ic-border-soft) !important;
	flex-wrap: wrap !important;
}

.ic-account__tab {
	padding: 10px 18px !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	color: var(--ic-text-dim) !important;
	background: transparent !important;
	border: none !important;
	border-bottom: 2px solid transparent !important;
	cursor: pointer !important;
	font-family: inherit !important;
	transition: color 0.15s ease, border-color 0.15s ease !important;
	margin-bottom: -1px !important;
}

.ic-account__tab:hover {
	color: var(--ic-text) !important;
}

.ic-account__tab.is-active {
	color: var(--ic-gold) !important;
	border-bottom-color: var(--ic-gold) !important;
}

/* Panes */

.ic-account-pane {
	padding: 24px !important;
	background: var(--ic-bg-panel) !important;
	border: 1px solid var(--ic-border) !important;
	border-radius: var(--ic-radius) !important;
}

.ic-account-pane[hidden] {
	display: none !important;
}

.ic-account-pane__title {
	margin: 0 0 8px !important;
	font-size: 20px !important;
	font-weight: 700 !important;
	color: var(--ic-gold) !important;
}

.ic-account-pane__lede {
	margin: 0 0 20px !important;
	color: var(--ic-text-dim) !important;
	font-size: 14px !important;
}

/* Profile summary list */

.ic-account-summary {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 16px 24px !important;
	margin: 0 !important;
}

.ic-account-summary > div {
	min-width: 0 !important;
}

.ic-account-summary__full {
	grid-column: 1 / -1 !important;
}

.ic-account-summary dt {
	margin: 0 0 4px !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	letter-spacing: 0.5px !important;
	text-transform: uppercase !important;
	color: var(--ic-text-dim) !important;
}

.ic-account-summary dd {
	margin: 0 !important;
	font-size: 15px !important;
	color: var(--ic-text) !important;
	word-break: break-word !important;
}

/* Buttons */

.ic-btn {
	display: inline-block !important;
	padding: 12px 24px !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	border-radius: var(--ic-radius-sm) !important;
	border: 1px solid transparent !important;
	cursor: pointer !important;
	text-decoration: none !important;
	font-family: inherit !important;
	transition: opacity 0.15s ease !important;
}

.ic-btn--primary {
	background: var(--ic-gold) !important;
	color: #000 !important;
	border-color: var(--ic-gold) !important;
}

.ic-btn--primary:hover {
	opacity: 0.9 !important;
	color: #000 !important;
}

.ic-btn--primary:disabled {
	opacity: 0.5 !important;
	cursor: not-allowed !important;
}

.ic-btn--ghost {
	background: transparent !important;
	color: var(--ic-gold) !important;
	border-color: var(--ic-border) !important;
}

.ic-btn--ghost:hover {
	background: var(--ic-gold-soft) !important;
}

/* ---------- Profile form ---------- */

.ic-account-form {
	display: flex !important;
	flex-direction: column !important;
	gap: 20px !important;
}

.ic-account-grid {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 16px 20px !important;
}

.ic-account-field--full {
	grid-column: 1 / -1 !important;
}

.ic-account-pane__subtitle {
	margin: 8px 0 0 !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	letter-spacing: 0.5px !important;
	text-transform: uppercase !important;
	color: var(--ic-gold) !important;
}

.ic-account-field__input:disabled {
	opacity: 0.55 !important;
	cursor: not-allowed !important;
}

.ic-account-form__actions {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
	margin-top: 8px !important;
}

/* ---------- Subscription card + status badges ---------- */

.ic-account-card {
	padding: 20px !important;
	background: var(--ic-bg-field) !important;
	border: 1px solid var(--ic-border) !important;
	border-radius: var(--ic-radius) !important;
	margin-bottom: 20px !important;
}

.ic-account-card__head {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 12px !important;
	margin-bottom: 16px !important;
	padding-bottom: 14px !important;
	border-bottom: 1px solid var(--ic-border-soft) !important;
	flex-wrap: wrap !important;
}

.ic-account-card__kicker {
	display: inline-block !important;
	padding: 4px 12px !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	letter-spacing: 1px !important;
	text-transform: uppercase !important;
	color: var(--ic-gold) !important;
	background: var(--ic-gold-soft) !important;
	border: 1px solid var(--ic-border) !important;
	border-radius: 999px !important;
}

.ic-account-status {
	display: inline-block !important;
	padding: 4px 10px !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.5px !important;
	text-transform: uppercase !important;
	border-radius: 999px !important;
	border: 1px solid transparent !important;
}

.ic-account-status.is-active-badge,
.ic-account-status.is-created {
	background: rgba(74, 222, 128, 0.1) !important;
	border-color: rgba(74, 222, 128, 0.4) !important;
	color: var(--ic-success) !important;
}

.ic-account-status.is-warn,
.ic-account-status.is-pending {
	background: rgba(245, 158, 11, 0.1) !important;
	border-color: rgba(245, 158, 11, 0.4) !important;
	color: #fbbf24 !important;
}

.ic-account-status.is-cancelled,
.ic-account-status.is-failed {
	background: rgba(248, 113, 113, 0.08) !important;
	border-color: rgba(248, 113, 113, 0.4) !important;
	color: var(--ic-error) !important;
}

.ic-account-status.is-n\/a {
	background: rgba(168, 168, 168, 0.08) !important;
	border-color: rgba(168, 168, 168, 0.3) !important;
	color: var(--ic-text-dim) !important;
}

.ic-btn--danger {
	color: var(--ic-error) !important;
	border-color: rgba(248, 113, 113, 0.5) !important;
}

.ic-btn--danger:hover {
	background: rgba(248, 113, 113, 0.08) !important;
}

/* ---------- Lists (Appointments + Past Bookings) ---------- */

.ic-account-list {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
}

.ic-account-list__item {
	padding: 16px 18px !important;
	background: var(--ic-bg-field) !important;
	border: 1px solid var(--ic-border-soft) !important;
	border-left: 3px solid var(--ic-gold) !important;
	border-radius: var(--ic-radius-sm) !important;
}

.ic-account-list__head {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 12px !important;
	margin-bottom: 8px !important;
	flex-wrap: wrap !important;
}

.ic-account-list__head strong {
	font-size: 15px !important;
	color: var(--ic-text) !important;
}

.ic-account-pane__lede--small {
	font-size: 13px !important;
	margin: 0 !important;
}

.ic-account-pane__lede code,
.ic-account-summary code {
	display: inline-block !important;
	padding: 2px 6px !important;
	background: rgba(255, 255, 255, 0.05) !important;
	border: 1px solid var(--ic-border-soft) !important;
	border-radius: 4px !important;
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace !important;
	font-size: 12px !important;
	color: var(--ic-text-dim) !important;
}

.ic-account-summary--compact {
	grid-template-columns: 1fr 1fr !important;
	gap: 8px 16px !important;
}

.ic-account-summary--compact dt {
	font-size: 11px !important;
}

.ic-account-summary--compact dd {
	font-size: 13px !important;
}

/* Mobile */

@media (max-width: 640px) {
	.ic-account {
		margin: 16px !important;
		padding: 16px !important;
	}
	.ic-account__head {
		flex-direction: column !important;
		gap: 12px !important;
	}
	.ic-account-pane {
		padding: 16px !important;
	}
	.ic-account-summary,
	.ic-account-grid {
		grid-template-columns: 1fr !important;
	}
	.ic-account__tab {
		padding: 8px 12px !important;
		font-size: 13px !important;
	}
}
