@import url("variables.css");

.flexi-subs-panel {
	position: relative;
	min-height: 100%;
	display: flex;
	flex-direction: column;
}

.flexi-subs-panel a:focus {
	outline: none;
	box-shadow: none;
}

/* HEADER & NAV */
.flexi-subs-header {
	background: var(--flexi-subs-surface);
	border-bottom: 1px solid var(--flexi-subs-border);
	height: var(--flexi-subs-header-h);
	display: flex;
	align-items: center;
	position: relative;
}

.flexi-subs-nav {
	width: 100%;
}

.flexi-upgrade-btn {
	display: inline-flex;
	align-items: center;
	padding: var(--flexi-subs-2) var(--flexi-subs-4);
	background: var(--flexi-subs-primary);
	color: #fff;
	text-decoration: none;
	font-weight: 600;
	border-radius: var(--flexi-subs-radius);
	box-shadow: var(--flexi-subs-shadow);
	transition: background 0.2s ease, transform 0.1s ease;
	margin-left: auto;
}

.flexi-upgrade-btn:hover {
	background: var(--flexi-subs-primary-600);
	transform: translateY(-2px);
	color: #fff;
}

.flexi-subs-nav__inner {
	margin: 0 auto;
	padding: 0 var(--flexi-subs-6);
	display: flex;
	align-items: center;
	gap: var(--flexi-subs-6);
}

.flexi-subs-brand {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-right: var(--flexi-subs-6);
	border-right: 1px solid var(--flexi-subs-border);
	flex: 0 0 auto;
}

.flexi-subs-nav__brand {
	display: inline-flex;
	align-items: center;
}

.flexi-subs-nav__brand img {
	height: 32px;
	width: auto;
	display: block;
}

.flexi-subs-plugin__title {
	font-size: 14px;
	color: var(--flexi-subs-text);
	font-weight: 600;
	white-space: nowrap;
}

.flexi-subs-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: stretch;
	height: var(--flexi-subs-header-h);
	gap: 2px;
	transition: transform 0.25s ease;
}

.flexi-subs-nav__item {
	position: relative;
	margin: 0;
}

.flexi-subs-nav__link {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0 var(--flexi-subs-4);
	height: 100%;
	font-weight: 600;
	color: #314155;
	text-decoration: none;
	border-top: 2px solid transparent;
	transition: color 0.12s ease, background-color 0.12s ease,
		border-color 0.12s ease;
}

.flexi-subs-nav__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: #94a3b8;
}

.flexi-subs-nav__icon svg {
	width: var(--flexi-subs-6);
	height: var(--flexi-subs-7);
}

.flexi-subs-nav__link:hover,
.flexi-subs-nav__link:focus {
	color: var(--flexi-subs-primary);
	border-top-color: var(--flexi-subs-primary);
}

.flexi-subs-nav__item--active>.flexi-subs-nav__link {
	color: var(--flexi-subs-primary);
	border-top-color: var(--flexi-subs-primary);
	background: var(--flexi-subs-primary-050);
}

.flexi-subs-nav__btn {
	display: none;
	background: none;
	border: 0;
	padding: 0 var(--flexi-subs-4);
	height: var(--flexi-subs-header-h);
	align-items: center;
	justify-content: center;
	cursor: pointer;
	color: var(--flexi-subs-text);
}

.flexi-subs-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.3);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease;
	z-index: 105;
}

.flexi-subs-overlay.active {
	opacity: 1;
	pointer-events: auto;
}

.flexi-subs-content {
	flex: 1 1 auto;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	padding-top: var(--flexi-subs-4);
}

.flexi-subs-section {
	background: var(--flexi-subs-surface);
	border: 1px solid var(--flexi-subs-border);
	box-shadow: var(--flexi-subs-shadow);
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: calc(100dvh - var(--flexi-subs-header-h));
}

.flexi-subs-section__header {
	padding: var(--flexi-subs-6) var(--flexi-subs-7) var(--flexi-subs-3);
	border-bottom: 1px solid var(--flexi-subs-border);
}

.flexi-subs-section__title {
	margin: 0 0 2px 0;
	font-size: var(--flexi-subs-5);
	font-weight: 500;
	color: var(--flexi-subs-text);
	display: inline-flex;
}

.flexi-subs-section__button {
	display: inline-flex;
	margin-left: 10px;
}

.flexi-subs-section__desc {
	margin: 0;
	color: var(--flexi-subs-text-muted);
	font-size: 13px;
}

.flexi-subs-section__body {
	padding: var(--flexi-subs-3) var(--flexi-subs-7);
	flex: 1 1 auto;
}

.flexi-subs-footer {
	position: sticky;
	bottom: 0;
	background: var(--flexi-subs-surface);
	border-top: 1px solid var(--flexi-subs-border);
	padding: var(--flexi-subs-6) var(--flexi-subs-7);
	display: flex;
	justify-content: flex-end;
	gap: 10px;
	z-index: 10;
}

.flexi-subs__button {
	border: 1px solid transparent;
	background: #e5e7eb;
	color: var(--flexi-fx-text);
	border-radius: var(--flexi-subs-radius);
	padding: 7px 20px;
	font-weight: 600;
	cursor: pointer;
	transition: 0.15s ease;
}

.flexi-subs__button--primary {
	background: var(--flexi-subs-primary);
	color: #fff;
	border-color: var(--flexi-subs-primary);
}

.flexi-subs__button--primary:hover {
	background: var(--flexi-subs-primary-600);
}

.flexi-subs__button--secondary {
	background: #fff;
	color: #2b3746;
	border-color: var(--flexi-subs-border);
}

.flexi-subs__button--secondary:hover {
	background: #f9fafc;
}

.flexi-subs__button--danger {
	background: var(--flexi-subs-error);
	color: #fff;
	border-color: var(--flexi-subs-error);
}

.flexi-subs__button--danger:hover {
	background: var(--flexi-subs-error-600);
}

.flexi-subs__button--link {
	background: #fff;
	color: var(--flexi-subs-text);
	border-radius: 50px;
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	box-shadow: var(--flexi-subs-shadow);
}

.flexi-subs__button--link:hover {
	color: var(--flexi-subs-primary);
}

.flexi-subs__button--link-info {
	color: var(--flexi-subs-primary);
}

.flexi-subs__button--link-error {
	color: var(--flexi-subs-error);
}

/* LIST TABLE */
.flexi-subs__table .wp-list-table {
	border-collapse: separate;
	border-spacing: 0;
	width: 100%;
	border: 1px solid var(--flexi-subs-border);
	border-radius: var(--flexi-subs-radius);
	font-size: 14px;
	background-color: #fff;
	/* box-shadow: var(--flexi-subs-shadow); */
}

.flexi-subs__table .wp-list-table thead td,
.flexi-subs__table .wp-list-table thead th {
	/* background-color: var(--flexi-subs-primary);
	color: #fff !important; */
	font-weight: 600;
	padding: 12px 10px;
	border-bottom: 1px solid var(--flexi-subs-border);
}

.flexi-subs__table .wp-list-table tfoot td,
.flexi-subs__table .wp-list-table tfoot th {
	font-weight: 600;
	padding: 12px 10px;
	border-top: 1px solid var(--flexi-subs-border);
}

.flexi-subs__table .wp-list-table tbody td {
	padding: 10px 12px;
	border-bottom: 1px solid var(--flexi-subs-border);
	color: var(--flexi-subs-text);
	vertical-align: middle;
}

.flexi-subs__table .wp-list-table tbody th {
	border-bottom: 1px solid var(--flexi-subs-border);
	vertical-align: middle;
	padding-left: 11px;
}

.flexi-subs__table .wp-list-table tbody tr:nth-child(odd) {
	background-color: transparent;
}

.flexi-subs__table .wp-list-table tbody tr:hover {
	background-color: transparent;
}

.flexi-subs__table .wp-list-table input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 20px;
	height: 20px;
	border: 2px solid var(--flexi-subs-primary);
	cursor: pointer;
	vertical-align: middle;
	position: relative;
	background-color: #fff;
	transition: background-color 0.2s, box-shadow 0.2s;
	margin: 0;
}

.flexi-subs__table .check-column input:hover+label,
.flexi-subs__table .check-column label:hover {
	background-color: transparent;
}

.flexi-subs__table th.sortable a,
.flexi-subs__table th.sorted a {
	padding: 0 8px;
	/* color:#fff; */
}

/* .flexi-subs__table .sorting-indicator.asc:before, .flexi-subs__table .sorting-indicator.desc:before{
	color: #fff;
} */

/* Hover glow */
.flexi-subs__table .wp-list-table input[type="checkbox"]:focus,
.flexi-subs__table .wp-list-table input[type="checkbox"]:hover {
	box-shadow: none;
	border-color: var(--flexi-subs-primary);
	outline: none;
}

.flexi-subs__table .wp-list-table input[type="checkbox"]:checked {
	background-color: var(--flexi-subs-primary);
	border-color: var(--flexi-subs-primary);
}

/* Custom check mark */
.flexi-subs__table .wp-list-table input[type="checkbox"]:checked::after {
	content: "✔";
	color: #fff;
	font-size: 14px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -55%);
}

/* Pagination styling */
.flexi-subs__table .tablenav {
	display: block !important;
}

.flexi-subs__table .tablenav.top {
	margin-bottom: 25px;
}

.flexi-subs__table .search-box input[type="search"] {
	border: 1px solid var(--flexi-subs-border);
	border-radius: var(--flexi-subs-radius);
	padding: 6px 10px;
}

.flexi-subs__table .search-box input[type="search"]:focus {
	box-shadow: none;
	outline: none;
	border: 1px solid var(--flexi-subs-primary);
}

.flexi-subs__table .tablenav .actions select {
	border: 1px solid var(--flexi-subs-border);
	border-radius: var(--flexi-subs-radius);
	padding: 5px 8px;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%2394a3b8' stroke-width='1.5' viewBox='0 0 24 24' aria-hidden='true'><path stroke-linecap='round' stroke-linejoin='round' d='M8.25 15L12 18.75 15.75 15m-7.5-6L12 5.25 15.75 9'/></svg>") no-repeat;
	background-position: right 0.75rem center;
	background-size: 1.5rem;
	min-width: 130px;
}

.flexi-subs__table .tablenav .actions select:hover,
.flexi-subs__table .tablenav .actions select:focus {
	color: var(--flexi-subs-primary-600);
	box-shadow: none;
	border: 1px solid var(--flexi-subs-primary);
}

.flexi-subs__table .search-box .button,
.flexi-subs__table .tablenav .actions .button {
	min-width: 90px;
	color: var(--flexi-fx-text);
	border-radius: var(--flexi-subs-radius);
	padding: 5px 20px;
	transition: 0.15s ease;
	background: #fff;
	color: var(--flexi-subs-primary);
	border-color: var(--flexi-subs-border);
	font-weight: 500;
}

.flexi-subs__table .search-box .button:hover,
.flexi-subs__table .tablenav .actions .button:hover {
	background-color: #f9fafc;
}

.flexi-subs__table .tablenav-pages .button,
.flexi-subs__table .tablenav-pages .button-secondary {
	background-color: var(--flexi-subs-primary);
	color: #fff;
	border: none;
	border-radius: var(--flexi-subs-radius);
	padding: 4px 8px;
	font-size: 13px;
	transition: background-color 0.3s ease;
}

.flexi-subs__table .tablenav-pages .button:hover {
	background-color: #f9fafc;
}

.flexi-subs__table .tablenav-pages .current-page {
	border: 1px solid var(--flexi-subs-primary);
	border-radius: var(--flexi-subs-radius);
	padding: 4px 6px;
	width: 40px;
	text-align: center;
}

/* Items count */
.flexi-subs__table .tablenav .displaying-num {
	font-weight: 500;
	color: var(--flexi-subs-primary);
}

/* Loading States */
.flexi-subscription-loading {
	opacity: 0.6;
	pointer-events: none;
}

.flexi-subscription-loading::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 20px;
	height: 20px;
	margin: -10px 0 0 -10px;
	border: 2px solid var(--flexi-subs-border);
	border-top-color: var(--flexi-subs-primary);
	border-radius: 50%;
	animation: flexi-spin 1s linear infinite;
}

@keyframes flexi-spin {
	to {
		transform: rotate(360deg);
	}
}

/* Responsive Design */
@media (max-width: 1024px) {
	.flexi-subs-nav__inner {
		padding: 0 var(--flexi-subs-4);
	}

	.flexi-subs-nav__btn {
		display: flex;
	}

	.flexi-subs-nav__list {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--flexi-subs-surface);
		border-top: 1px solid var(--flexi-subs-border);
		flex-direction: column;
		height: auto;
		gap: 0;
		transform: translateY(-100%);
		opacity: 0;
		pointer-events: none;
		z-index: 110;
	}

	.flexi-subs-nav__list.active {
		transform: translateY(0);
		opacity: 1;
		pointer-events: auto;
	}

	.flexi-subs-nav__item {
		border-bottom: 1px solid var(--flexi-subs-border);
	}

	.flexi-subs-nav__link {
		height: 48px;
		border-top: none;
		border-left: 2px solid transparent;
	}

	.flexi-subs-nav__link:hover,
	.flexi-subs-nav__link:focus {
		border-left-color: var(--flexi-subs-primary);
		border-top-color: transparent;
	}

	.flexi-subs-nav__item--active>.flexi-subs-nav__link {
		border-left-color: var(--flexi-subs-primary);
		border-top-color: transparent;
	}
}

@media (max-width: 768px) {

	.flexi-subscription-list-table .wp-list-table .column-customer,
	.flexi-subscription-list-table .wp-list-table .column-product {
		display: none;
	}

	.flexi-subscription-filters {
		flex-direction: column;
		align-items: stretch;
	}

	.flexi-subscription-filters>* {
		width: 100%;
	}
}

@media (max-width: 600px) {
	.flexi-subs-section__body {
		padding: var(--flexi-subs-3) var(--flexi-subs-4);
	}

	.flexi-subscription-list-table .wp-list-table .column-recurring_amount,
	.flexi-subscription-list-table .wp-list-table .column-start_date,
	.flexi-subscription-list-table .wp-list-table .column-next_payment {
		display: none;
	}
}

/* --- UPGRADE TO PRO CTA --- */
.flexi-upgrade-cta {
	background: var(--flexi-subs-primary-050);
	border: 1px solid var(--flexi-subs-primary);
	border-radius: var(--flexi-subs-radius);
	padding: var(--flexi-subs-6);
	text-align: center;
	box-shadow: var(--flexi-subs-shadow);
	margin-top: var(--flexi-subs-7);
	position: relative;
	overflow: hidden;
}

.flexi-upgrade-cta::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--flexi-subs-primary);
	border-radius: var(--flexi-subs-radius) var(--flexi-subs-radius) 0 0;
}

.flexi-upgrade-cta__content {
	max-width: 600px;
	margin: 0 auto;
}

.flexi-upgrade-cta__title {
	font-size: 1.25rem;
	color: var(--flexi-subs-primary-600);
	margin: 0 0 var(--flexi-subs-3);
	font-weight: 700;
}

.flexi-upgrade-cta__message {
	color: var(--flexi-subs-text);
	font-size: 14px;
	line-height: 1.6;
	margin: 0 0 var(--flexi-subs-5);
}

.flexi-upgrade-cta .flexi-subs__button--primary {
	background: var(--flexi-subs-primary);
	color: #fff;
	border-color: var(--flexi-subs-primary);
	padding: 10px 28px;
	font-size: 14px;
	font-weight: 600;
	transition: background 0.2s ease;
	text-decoration: none;
}

.flexi-upgrade-cta .flexi-subs__button--primary:hover {
	background: var(--flexi-subs-primary-600);
	text-decoration: none;
	color: #fff;
}

.flexi-pro-notice {
	border-left: 4px solid var(--flexi-subs-primary);
	background: var(--flexi-subs-primary-050);
	padding: var(--flexi-subs-4);
	margin: 20px 0;
	border-radius: var(--flexi-subs-radius);
	box-shadow: var(--flexi-subs-shadow);
}

.flexi-pro-notice__inner h3 {
	margin: 0 0 var(--flexi-subs-2);
	color: var(--flexi-subs-text);
	font-size: 1.25rem;
}

.flexi-pro-notice__inner p {
	margin: 0 0 var(--flexi-subs-3);
	color: var(--flexi-subs-text-muted);
}

.flexi-pro-notice .flexi-subs__button--primary {
	background: var(--flexi-subs-primary);
	color: #fff;
	padding: var(--flexi-subs-2) var(--flexi-subs-4);
	border-radius: var(--flexi-subs-radius);
	text-decoration: none;
	display: inline-block;
}

.flexi-pro-notice .flexi-subs__button--primary:hover {
	background: var(--flexi-subs-primary-600);
}

.flexi-fw__notices {
	margin: 1em 0;
}

/* Base notice layout */
.flexi-subs__notice {
	padding: 0.8em 1em;
	border-radius: var(--flexi-subs-radius);
	margin-bottom: 1em;
	font-size: 14px;
	line-height: 1.4;
	display: flex;
	align-items: center;
	position: relative;
	transition: all 0.3s ease;
}

/* Icon circle */
.flexi-subs__notice-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	font-size: 14px;
	font-weight: bold;
	margin-right: 0.8em;
	flex-shrink: 0;
}

/* Success */
.flexi-subs__notice--success {
	background-color: var(--flexi-subs-success-bg, #e6f7e6);
	border: 1px solid var(--flexi-subs-success-border, #b6e2b6);
	color: var(--flexi-subs-success, #2e7d32);
}

.flexi-subs__notice--success .flexi-subs__notice-icon {
	border: 2px solid var(--flexi-subs-success, #2e7d32);
	color: var(--flexi-subs-success, #2e7d32);
}

/* Error */
.flexi-subs__notice--error {
	background-color: var(--flexi-subs-error-bg, #fdecea);
	border: 1px solid var(--flexi-subs-error-border, #f5c6cb);
	color: var(--flexi-subs-error, #c62828);
}

.flexi-subs__notice--error .flexi-subs__notice-icon {
	border: 2px solid var(--flexi-subs-error, #c62828);
	color: var(--flexi-subs-error, #c62828);
}

/* Warning */
.flexi-subs__notice--warning {
	background-color: var(--flexi-subs-warning-bg, #fff3cd);
	border: 1px solid var(--flexi-subs-warning-border, #ffeeba);
	color: var(--flexi-subs-warning, #856404);
}

.flexi-subs__notice--warning .flexi-subs__notice-icon {
	border: 2px solid var(--flexi-subs-warning, #856404);
	color: var(--flexi-subs-warning, #856404);
}

/* Info */
.flexi-subs__notice--info {
	background-color: var(--flexi-subs-info-bg, #e7f3fe);
	border: 1px solid var(--flexi-subs-info-border, #b3d7f5);
	color: var(--flexi-subs-info, #31708f);
}

.flexi-subs__notice--info .flexi-subs__notice-icon {
	border: 2px solid var(--flexi-subs-info, #31708f);
	color: var(--flexi-subs-info, #31708f);
}

/* Message flexes */
.flexi-subs__notice-message {
	flex: 1;
}

/* Dismiss button */
.flexi-subs__notice-dismiss {
	background: transparent;
	border: none;
	font-size: 18px;
	line-height: 1;
	cursor: pointer;
	color: inherit;
	margin-left: 1em;
}

/* --- SUBSCRIPTION EDIT SCREEN DETAILS --- */
.flexi-subs-details {
	background: var(--flexi-subs-surface);
	border: 1px solid var(--flexi-subs-border);
	border-radius: var(--flexi-subs-radius);
	box-shadow: var(--flexi-subs-shadow);
	padding: var(--flexi-subs-6);
	margin: var(--flexi-subs-6) 0;
}

.flexi-subscription-summary {
	display: grid;
	grid-template-columns: 1.2fr 1fr 1fr;
	align-items: center;
	gap: var(--flexi-subs-6);
	border-bottom: 1px solid var(--flexi-subs-border);
	padding-bottom: var(--flexi-subs-5);
	margin-bottom: var(--flexi-subs-6);
}

.flexi-subscription-summary__left,
.flexi-subscription-summary__middle,
.flexi-subscription-summary__right {
	display: flex;
	align-items: center;
	gap: var(--flexi-subs-4);
}

.flexi-summary-avatar img {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	border: 2px solid var(--flexi-subs-border);
	box-shadow: var(--flexi-subs-shadow);
}

.flexi-summary-customer h3,
.flexi-subscription-summary__middle h3 {
	font-size: 13px;
	color: var(--flexi-subs-text-muted);
	margin: 0 0 4px;
}

.flexi-summary-value {
	font-size: 14px;
	font-weight: 600;
	color: var(--flexi-subs-text);
}

.flexi-summary-meta {
	font-size: 12px;
	color: var(--flexi-subs-text-muted);
	margin-top: 4px;
	word-break: break-word;
}

.flexi-summary-product {
	display: flex;
	align-items: center;
	gap: var(--flexi-subs-4);
}

.flexi-summary-product img {
	width: 56px;
	height: 56px;
	object-fit: cover;
	border-radius: var(--flexi-subs-radius);
	border: 1px solid var(--flexi-subs-border);
	box-shadow: var(--flexi-subs-shadow);
}

.flexi-summary-status {
	margin-bottom: var(--flexi-subs-3);
}

.flexi-summary-stats p {
	font-size: 13px;
	color: var(--flexi-subs-text);
	margin: 2px 0;
}

.flexi-subs-details__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--flexi-subs-7);
}

.flexi-details-section h3 {
	font-size: 14px;
	font-weight: 600;
	color: var(--flexi-subs-text);
	margin-bottom: var(--flexi-subs-3);
}

.flexi-details-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: var(--flexi-subs-5);
}

.flexi-details-table th {
	width: 45%;
	padding: 6px 10px 6px 0;
	color: var(--flexi-subs-text-muted);
	font-weight: 500;
	text-align: left;
	vertical-align: top;
}

.flexi-details-table td {
	padding: 6px 0;
	color: var(--flexi-subs-text);
	vertical-align: top;
}

.flexi-details-table tr+tr th,
.flexi-details-table tr+tr td {
	border-top: 1px solid var(--flexi-subs-border);
}

.flexi-action-metabox .button {
	width: 100%;
}

.flexi-subscription-activities {
	margin: 0;
	padding: 0;
	list-style: none;
}

.flexi-subscription-activity-item {
	padding: 10px 0;
	border-bottom: 1px solid var(--flexi-subs-border);
}

.flexi-subscription-activity-item:last-child {
	border-bottom: 0;
}

.flexi-activity-meta {
	font-size: 12px;
	color: var(--flexi-subs-text-muted);
	margin-bottom: 6px;
}

.flexi-activity-content {
	font-size: 13px;
	color: var(--flexi-subs-text);
	line-height: 1.5;
}

@media (max-width: 768px) {
	.flexi-subscription-summary {
		grid-template-columns: 1fr;
	}

	.flexi-subscription-summary__left,
	.flexi-subscription-summary__middle,
	.flexi-subscription-summary__right {
		flex-direction: column;
		align-items: flex-start;
	}
}
