@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Poppins:wght@500;600;700&display=swap");

.alc-shortcode,
.annual-leave-page {
	--alp-bg: #eef4ff;
	--alp-bg-soft: #f8fbff;
	--alp-surface: rgba(255, 255, 255, 0.94);
	--alp-surface-strong: #ffffff;
	--alp-surface-muted: #f3f8ff;
	--alp-border: #d7e3f4;
	--alp-border-strong: #c5d6ef;
	--alp-heading: #0f172a;
	--alp-text: #334155;
	--alp-muted: #526277;
	--alp-primary: #2563eb;
	--alp-primary-dark: #1d4ed8;
	--alp-primary-deep: #10254f;
	--alp-primary-soft: #dbeafe;
	--alp-accent: #f97316;
	--alp-accent-soft: #fff2e8;
	--alp-warning: #b45309;
	--alp-shadow: 0 28px 70px rgba(15, 23, 42, 0.14);
	--alp-shadow-soft: 0 18px 42px rgba(37, 99, 235, 0.08);
	--alp-page-pad: 28px;
	--alp-section-pad-x: 30px;
	--alp-section-pad-y: 30px;
	--alp-card-pad: 24px;
	--alp-card-pad-tight: 22px;
	--alp-block-gap: 26px;
	--alp-grid-gap: 22px;
	color: var(--alp-text);
	font-family: "Inter", Arial, sans-serif;
}

.alc-shortcode {
	margin: 0 0 36px;
}

.alc-shortcode *,
.alc-shortcode *::before,
.alc-shortcode *::after,
.annual-leave-page *,
.annual-leave-page *::before,
.annual-leave-page *::after {
	box-sizing: border-box;
}

.alc-shortcode [hidden] {
	display: none !important;
}

.alc-shell,
.annual-leave-page {
	position: relative;
	overflow: hidden;
	background:
		radial-gradient(circle at top left, rgba(37, 99, 235, 0.12), transparent 30%),
		radial-gradient(circle at top right, rgba(249, 115, 22, 0.08), transparent 24%),
		linear-gradient(180deg, #fbfdff 0%, var(--alp-bg) 100%);
	border: 1px solid var(--alp-border);
	border-radius: 30px;
	box-shadow: var(--alp-shadow);
}

.alc-shell {
	padding: 0;
}

.annual-leave-page {
	margin: 0 auto;
	max-width: 1180px;
	padding: var(--alp-page-pad);
}

.alc-shell::before,
.annual-leave-page::before {
	content: "";
	position: absolute;
	top: -120px;
	right: -120px;
	width: 320px;
	height: 320px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(37, 99, 235, 0.12), transparent 70%);
	pointer-events: none;
}

.alc-shell::after,
.annual-leave-page::after {
	content: "";
	position: absolute;
	bottom: -140px;
	left: -80px;
	width: 280px;
	height: 280px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(249, 115, 22, 0.09), transparent 70%);
	pointer-events: none;
}

.alc-grid,
.annual-leave-page__grid,
.annual-leave-page__faq-list {
	display: grid;
	gap: var(--alp-grid-gap);
}

.alc-hero {
	display: block;
	margin-bottom: var(--alp-block-gap);
}

.alc-summary__card,
.alc-copy,
.alc-form,
.annual-leave-page__section,
.annual-leave-page__card {
	position: relative;
	z-index: 1;
	background: var(--alp-surface);
	border: 1px solid rgba(215, 227, 244, 0.92);
	border-radius: 24px;
	box-shadow: var(--alp-shadow-soft);
	backdrop-filter: blur(8px);
}

.alc-summary__card {
	width: 100%;
	padding: var(--alp-section-pad-y) var(--alp-section-pad-x);
	background:
		linear-gradient(135deg, rgba(17, 37, 79, 0.97) 0%, rgba(29, 78, 216, 0.95) 100%);
	border-color: rgba(148, 180, 242, 0.45);
	color: #e5efff;
	box-shadow: 0 26px 60px rgba(16, 37, 79, 0.28);
}

.alc-summary__card::after {
	content: "";
	position: absolute;
	inset: auto -20px -20px auto;
	width: 160px;
	height: 160px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.18), transparent 68%);
	pointer-events: none;
}

.alc-kicker {
	margin: 0;
	color: rgba(219, 234, 254, 0.82);
	font-family: "Poppins", "Segoe UI", Arial, sans-serif;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.alc-summary__top {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 26px;
	align-items: center;
}

.alc-summary__lead {
	display: grid;
	gap: 12px;
	max-width: 38rem;
}

.alc-summary__value {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	text-align: right;
}

.alc-total {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: flex-end;
	gap: 12px;
	margin: 0;
	color: #ffffff;
	font-family: "Poppins", "Segoe UI", Arial, sans-serif;
	font-size: clamp(3.2rem, 6vw, 4.8rem);
	font-weight: 800;
	letter-spacing: -0.04em;
	line-height: 0.94;
}

.alc-total__unit {
	padding-bottom: 10px;
	color: rgba(255, 255, 255, 0.72);
	font-family: "Poppins", "Segoe UI", Arial, sans-serif;
	font-size: clamp(1rem, 1.8vw, 1.2rem);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.alc-summary__text,
.alc-summary__note,
.alc-copy__item,
.annual-leave-page p,
.annual-leave-page li {
	margin: 0;
	font-size: 1rem;
	line-height: 1.75;
}

.alc-summary__text {
	max-width: none;
	color: rgba(255, 255, 255, 0.84);
	font-size: 1.05rem;
}

.alc-summary__text strong {
	color: #ffffff;
}

.alc-summary__note {
	margin-top: 20px;
	padding-top: 18px;
	border-top: 1px solid rgba(219, 234, 254, 0.26);
	color: rgba(219, 234, 254, 0.8);
}

.alc-copy {
	display: grid;
	gap: 18px;
	padding: var(--alp-card-pad);
}

.alc-copy__item {
	padding: 20px 20px 20px 24px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(243, 248, 255, 0.94) 100%);
	border: 1px solid rgba(215, 227, 244, 0.95);
	border-left: 5px solid var(--alp-accent);
	border-radius: 18px;
	color: var(--alp-text);
	box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.alc-form {
	padding: var(--alp-card-pad);
}

.alc-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.alc-column {
	display: grid;
	gap: 20px;
}

.alc-field {
	padding: var(--alp-card-pad-tight);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(243, 248, 255, 0.92) 100%);
	border: 1px solid var(--alp-border);
	border-radius: 20px;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.alc-field label {
	display: block;
	margin-bottom: 12px;
	color: var(--alp-heading);
	font-size: 0.98rem;
	font-weight: 700;
	line-height: 1.5;
}

.alc-field input[type="date"],
.alc-field input[type="number"],
.alc-field select {
	width: 100%;
	min-height: 56px;
	padding: 0 16px;
	border: 1px solid var(--alp-border-strong);
	border-radius: 16px;
	background-color: var(--alp-surface-strong);
	color: var(--alp-heading);
	font-size: 1rem;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.alc-field select {
	padding-right: 46px;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18' fill='none'%3E%3Cpath d='M4.5 6.75L9 11.25L13.5 6.75' stroke='%23526277' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-position: right 16px center;
	background-repeat: no-repeat;
}

.alc-field input:focus,
.alc-field select:focus,
.alc-stepper:focus {
	outline: none;
	border-color: var(--alp-primary);
	box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.13);
}

.alc-number {
	display: grid;
	grid-template-columns: 52px minmax(0, 1fr) auto 52px;
	align-items: stretch;
	gap: 10px;
	width: 100%;
	max-width: 100%;
	background: transparent;
	border: 0;
	box-shadow: none;
	overflow: visible;
}

.alc-number:focus-within {
	box-shadow: none;
}

.alc-number input {
	min-height: 58px;
	padding: 0 18px;
	border: 1px solid var(--alp-border-strong);
	border-right: 0;
	border-radius: 18px 0 0 18px;
	background: var(--alp-surface-strong);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
	font-size: 1.08rem;
	font-weight: 700;
	text-align: center;
}

.alc-stepper {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	min-width: 52px;
	height: 52px;
	margin-top: 3px;
	padding: 0;
	border: 1px solid rgba(191, 212, 244, 0.95);
	border-radius: 999px;
	background: linear-gradient(180deg, #edf3ff 0%, #dbeafe 100%);
	color: var(--alp-primary-dark);
	cursor: pointer;
	box-shadow: 0 10px 20px rgba(37, 99, 235, 0.08);
	font-size: 1.35rem;
	font-weight: 700;
	line-height: 1;
	transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.alc-stepper:hover {
	background: linear-gradient(180deg, #dbeafe 0%, #c7ddff 100%);
	transform: translateY(-1px);
}

.alc-number__suffix {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 18px;
	min-height: 58px;
	border: 1px solid var(--alp-border-strong);
	border-left: 0;
	border-radius: 0 18px 18px 0;
	background: var(--alp-surface-strong);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
	color: var(--alp-muted);
	font-size: 0.88rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	white-space: nowrap;
}

.alc-field--check {
	padding: 20px 22px;
}

.alc-check {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin: 0;
	cursor: pointer;
}

.alc-check input[type="checkbox"] {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	margin-top: 3px;
	accent-color: var(--alp-primary);
}

.alc-check span {
	color: var(--alp-heading);
	font-weight: 600;
	line-height: 1.6;
}

.alc-warning {
	margin: 12px 0 0;
	color: var(--alp-warning);
	font-size: 0.92rem;
	font-weight: 600;
	line-height: 1.5;
}

.annual-leave-page > * + * {
	margin-top: var(--alp-block-gap);
}

.annual-leave-page > .alc-shortcode {
	margin: 0;
}

.annual-leave-page__section {
	padding: var(--alp-section-pad-y) var(--alp-section-pad-x);
}

.annual-leave-page__section--hero {
	padding: 38px 34px;
	background:
		radial-gradient(circle at top left, rgba(255, 255, 255, 0.12), transparent 28%),
		linear-gradient(135deg, rgba(17, 37, 79, 0.97) 0%, rgba(29, 78, 216, 0.94) 100%);
	border-color: rgba(148, 180, 242, 0.4);
	color: #ebf3ff;
	box-shadow: 0 28px 64px rgba(16, 37, 79, 0.3);
}

.annual-leave-page__section--hero h1,
.annual-leave-page__section--hero p {
	position: relative;
	z-index: 1;
}

.annual-leave-page__section--hero h1 {
	margin: 0 0 20px;
	color: #ffffff;
	font-family: "Poppins", "Segoe UI", Arial, sans-serif;
	font-size: clamp(2rem, 4vw, 2.85rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.15;
}

.annual-leave-page__section--hero p {
	max-width: 56rem;
	color: rgba(235, 243, 255, 0.88);
	font-size: 1.05rem;
}

.annual-leave-page__section--hero p + p,
.annual-leave-page__section p + p {
	margin-top: 16px;
}

.annual-leave-page__section h2,
.annual-leave-page__section h3 {
	margin: 0;
	color: var(--alp-heading);
	font-family: "Poppins", "Segoe UI", Arial, sans-serif;
	letter-spacing: -0.02em;
}

.annual-leave-page__section h2 {
	margin-bottom: 18px;
	font-size: clamp(1.7rem, 3vw, 2.15rem);
	font-weight: 700;
	line-height: 1.2;
}

.annual-leave-page__section h3 {
	margin-bottom: 14px;
	font-size: clamp(1.22rem, 2.2vw, 1.5rem);
	font-weight: 600;
	line-height: 1.3;
}

.annual-leave-page__steps {
	display: grid;
	gap: 22px;
	margin-top: 24px;
}

.annual-leave-page__step {
	padding: 22px 24px;
	background: linear-gradient(180deg, var(--alp-surface-strong) 0%, var(--alp-surface-muted) 100%);
	border: 1px solid var(--alp-border);
	border-left: 5px solid var(--alp-primary);
	border-radius: 18px;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.annual-leave-page ul {
	margin: 14px 0 0;
	padding-left: 22px;
}

.annual-leave-page li + li {
	margin-top: 8px;
}

.annual-leave-page__note {
	margin-top: 24px;
	padding: 20px 22px;
	background: linear-gradient(135deg, var(--alp-accent-soft) 0%, #fff8f1 100%);
	border: 1px solid #ffd6b1;
	border-left: 5px solid var(--alp-accent);
	border-radius: 18px;
	box-shadow: 0 14px 28px rgba(249, 115, 22, 0.08);
}

.annual-leave-page__grid--benefits {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 24px;
}

.annual-leave-page__faq-list {
	grid-template-columns: 1fr;
	margin-top: 24px;
}

.annual-leave-page__card {
	padding: 28px 26px;
}

.annual-leave-page__card h3 + p {
	margin-top: 0;
}

.annual-leave-page__card p + p {
	margin-top: 14px;
}

@media (max-width: 960px) {
	.alc-hero,
	.alc-grid,
	.annual-leave-page__grid--benefits {
		grid-template-columns: 1fr;
	}

	.alc-summary__top {
		grid-template-columns: 1fr;
		gap: 18px;
	}

	.alc-summary__value,
	.alc-total {
		justify-content: flex-start;
		text-align: left;
	}

	.alc-total {
		font-size: clamp(2.7rem, 10vw, 4.2rem);
	}
}

@media (max-width: 640px) {
	.alc-shell,
	.annual-leave-page {
		padding: 16px;
		border-radius: 24px;
	}

	.alc-summary__card,
	.alc-copy,
	.alc-form,
	.annual-leave-page__section,
	.annual-leave-page__card {
		padding: 22px 20px;
		border-radius: 20px;
	}

	.annual-leave-page__section--hero {
		padding: 28px 22px;
	}

	.alc-field,
	.alc-field--check,
	.annual-leave-page__step,
	.annual-leave-page__note {
		padding: 18px;
	}

	.alc-number {
		width: 100%;
	}
}
