/* ============================================================
   Community Draws — App UI System
   File: /wp-content/mu-plugins/assets/css/cd-ui-system.css
   Scope: .cd-app-screen and descendants (tokens on :root)
   ============================================================ */

:root {
	/* Colours */
	--cd-primary: #0A1628;
	--cd-secondary: #132238;
	--cd-success: #10B981;
	--cd-surface: #FFFFFF;
	--cd-app-bg: #F8FAFC;
	--cd-border: #E5E7EB;
	--cd-text-primary: #1F2937;
	--cd-text-secondary: #6B7280;
	--cd-text-muted: #94A3B8;

	/* Typography */
	--cd-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
	--cd-h1-size: 32px;
	--cd-h1-line: 1.15;
	--cd-h2-size: 24px;
	--cd-body-size: 16px;
	--cd-small-size: 14px;

	/* Spacing */
	--cd-space-4: 4px;
	--cd-space-8: 8px;
	--cd-space-12: 12px;
	--cd-space-16: 16px;
	--cd-space-24: 24px;
	--cd-space-32: 32px;
	--cd-space-48: 48px;

	/* Radius */
	--cd-radius-sm: 8px;
	--cd-radius-md: 12px;
	--cd-radius-lg: 16px;
	--cd-radius-xl: 24px;
}

/* --- Screen shell --------------------------------------------------- */

.cd-app-screen {
	box-sizing: border-box;
	font-family: var(--cd-font-family);
	font-size: var(--cd-body-size);
	line-height: 1.5;
	color: var(--cd-text-primary);
	background: var(--cd-app-bg);
	-webkit-font-smoothing: antialiased;
}

.cd-app-screen *,
.cd-app-screen *::before,
.cd-app-screen *::after {
	box-sizing: border-box;
}

.cd-app-shell {
	width: 100%;
	max-width: 640px;
	margin: 0 auto;
	padding: var(--cd-space-32) var(--cd-space-24) var(--cd-space-48);
}

/* --- Navigation / titles -------------------------------------------- */

.cd-app-screen .cd-back-link {
	display: inline-flex;
	align-items: center;
	gap: var(--cd-space-8);
	margin: 0 0 var(--cd-space-24);
	font-size: var(--cd-small-size);
	font-weight: 600;
	color: var(--cd-text-secondary);
	text-decoration: none;
}

.cd-app-screen .cd-back-link:hover {
	color: var(--cd-primary);
}

.cd-app-screen .cd-screen-title {
	margin: 0 0 var(--cd-space-12);
	font-size: var(--cd-h1-size);
	line-height: var(--cd-h1-line);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--cd-primary);
}

.cd-app-screen .cd-screen-subtitle {
	margin: 0 0 var(--cd-space-32);
	font-size: var(--cd-body-size);
	line-height: 1.55;
	color: var(--cd-text-secondary);
}

/* --- Cards ------------------------------------------------------------ */

.cd-app-screen .cd-card {
	display: block;
	width: 100%;
	padding: var(--cd-space-24);
	background: var(--cd-surface);
	border: 1px solid var(--cd-border);
	border-radius: var(--cd-radius-lg);
	box-shadow: 0 1px 2px rgba(10, 22, 40, 0.04);
}

.cd-app-screen .cd-card + .cd-card {
	margin-top: var(--cd-space-16);
}

.cd-app-screen .cd-card-row {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--cd-space-16);
}

.cd-app-screen .cd-card-selected {
	border-color: var(--cd-primary);
	box-shadow: 0 0 0 1px var(--cd-primary), 0 8px 24px rgba(10, 22, 40, 0.08);
}

.cd-app-screen .cd-card-title {
	margin: 0 0 var(--cd-space-8);
	font-size: var(--cd-h2-size);
	line-height: 1.25;
	font-weight: 700;
	color: var(--cd-text-primary);
}

.cd-app-screen .cd-card-text {
	margin: 0;
	font-size: var(--cd-body-size);
	line-height: 1.55;
	color: var(--cd-text-secondary);
}

/* --- Pills ------------------------------------------------------------ */

.cd-app-screen .cd-pill {
	display: inline-flex;
	align-items: center;
	padding: var(--cd-space-4) var(--cd-space-12);
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--cd-text-secondary);
	background: var(--cd-app-bg);
	border: 1px solid var(--cd-border);
	border-radius: 999px;
	white-space: nowrap;
}

.cd-app-screen .cd-pill-success {
	color: #065f46;
	background: rgba(16, 185, 129, 0.12);
	border-color: rgba(16, 185, 129, 0.35);
}

/* --- Buttons ---------------------------------------------------------- */

.cd-app-screen .cd-button-primary,
.cd-app-screen .cd-button-secondary,
.cd-app-screen .cd-button-disabled {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: var(--cd-space-12) var(--cd-space-24);
	font-family: inherit;
	font-size: var(--cd-body-size);
	font-weight: 700;
	line-height: 1.2;
	text-decoration: none;
	border-radius: var(--cd-radius-md);
	border: 1px solid transparent;
	cursor: pointer;
	transition: background 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
}

.cd-app-screen .cd-button-primary {
	color: #fff;
	background: var(--cd-primary);
	border-color: var(--cd-primary);
}

.cd-app-screen .cd-button-primary:hover {
	background: var(--cd-secondary);
	border-color: var(--cd-secondary);
	color: #fff;
}

.cd-app-screen .cd-button-secondary {
	color: var(--cd-primary);
	background: var(--cd-surface);
	border-color: var(--cd-border);
}

.cd-app-screen .cd-button-secondary:hover {
	border-color: var(--cd-primary);
	color: var(--cd-primary);
}

.cd-app-screen .cd-button-disabled,
.cd-app-screen .cd-button-disabled:hover {
	color: var(--cd-text-muted);
	background: var(--cd-app-bg);
	border-color: var(--cd-border);
	cursor: not-allowed;
	opacity: 0.85;
}

/* --- Bottom action bar ------------------------------------------------ */

.cd-app-screen .cd-bottom-action {
	display: flex;
	flex-direction: column;
	gap: var(--cd-space-12);
	margin-top: var(--cd-space-32);
	padding-top: var(--cd-space-24);
}

.cd-app-screen .cd-bottom-action .cd-button-primary,
.cd-app-screen .cd-bottom-action .cd-button-secondary {
	width: 100%;
}

/* --- Forms ------------------------------------------------------------ */

.cd-app-screen .cd-form-group {
	margin: 0 0 var(--cd-space-24);
}

.cd-app-screen .cd-label {
	display: block;
	margin: 0 0 var(--cd-space-8);
	font-size: var(--cd-small-size);
	font-weight: 600;
	color: var(--cd-text-primary);
}

.cd-app-screen .cd-input {
	display: block;
	width: 100%;
	min-height: 48px;
	padding: var(--cd-space-12) var(--cd-space-16);
	font-family: inherit;
	font-size: var(--cd-body-size);
	color: var(--cd-text-primary);
	background: var(--cd-surface);
	border: 1px solid var(--cd-border);
	border-radius: var(--cd-radius-sm);
}

.cd-app-screen .cd-input:focus {
	outline: none;
	border-color: var(--cd-primary);
	box-shadow: 0 0 0 3px rgba(10, 22, 40, 0.12);
}

.cd-app-screen .cd-input-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cd-space-12);
}

.cd-app-screen .cd-input-row .cd-input {
	flex: 1 1 140px;
}

.cd-app-screen .cd-helper-text {
	margin: var(--cd-space-8) 0 0;
	font-size: var(--cd-small-size);
	line-height: 1.45;
	color: var(--cd-text-muted);
}

/* --- Success icon ----------------------------------------------------- */

.cd-app-screen .cd-success-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	margin: 0 0 var(--cd-space-16);
	font-size: 24px;
	line-height: 1;
	color: var(--cd-success);
	background: rgba(16, 185, 129, 0.12);
	border-radius: 50%;
}
