* {
	box-sizing: border-box;
}

body {
	margin: 0;
}

:root {
	--gjs-t-color-primary: #cf549e;
	--gjs-t-color-secondary: #b9227d;
	--gjs-t-color-accent: #ffb347;
	--gjs-t-color-success: #28a745;
	--gjs-t-color-warning: #ffc107;
	--gjs-t-color-error: #dc3545;
}

html {
	scroll-behavior: smooth;
}

.gjs-t-body {
	background-color: #fffaf7;
	color: #3f3140;
	font-size: 1rem;
	line-height: 1.75rem;
}

.gjs-t-h1 {
	color: #601843;
	font-size: 3.4rem;
	line-height: 4rem;
}
.gjs-tn-h1 {
	color: #601843;
	font-size: 3.0rem;
	line-height: 3.6rem;
}

.gjs-t-h2 {
	color: #601843;
	font-size: 2rem;
	line-height: 2.6rem;
}

.gjs-t-button {
	background-color: var(--gjs-t-color-primary);
	color: #ffffff;
	border-radius: 0.75rem;
}

.gjs-t-link {
	color: var(--gjs-t-color-primary);
	text-decoration: none;
}

.gjs-t-border {
	border-radius: 1rem;
	border-color: #eadfe6;
}

.font-display {
	font-family: "Cormorant Garamond", serif;
}

.font-body {
	font-family: "Inter", sans-serif;
}

.glass {
	backdrop-filter: blur(12px);
}

.section-shell {
	max-width: 1280px;
	margin: 0 auto;
}

.soft-shadow {
	box-shadow: 0 10px 30px rgba(22, 47, 32, .08);
}

.hero-overlay {
	background: linear-gradient(90deg, rgba(17, 46, 31, .88) 0%, rgba(26, 58, 40, .75) 42%, rgba(33, 66, 46, .35) 100%);
	position: absolute;
	inset: 0px;
}

.card-outline {
	border: 1px solid rgba(36, 84, 58, .12);
}

.gold-line {
	height: 1px;
	background: linear-gradient(90deg, rgba(201, 154, 59, .05) 0%, rgba(201, 154, 59, .65) 50%, rgba(201, 154, 59, .05) 100%);
}

*,
::before,
::after {
	box-sizing: border-box;
	border-width: 0;
	border-style: solid;
	border-color: #e5e7eb;
}

html,
:host {
	line-height: 1.5;
	-webkit-text-size-adjust: 100%;
	-moz-tab-size: 4;
	tab-size: 4;
	font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
	font-feature-settings: normal;
	font-variation-settings: normal;
	-webkit-tap-highlight-color: transparent;
}

body {
	margin: 0;
	line-height: inherit;
}

hr {
	height: 0;
	color: inherit;
	border-top-width: 1px;
}

abbr:where([title]) {
	text-decoration: underline dotted;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: inherit;
	font-weight: inherit;
}

a {
	color: inherit;
	text-decoration: inherit;
}

b,
strong {
	font-weight: bolder;
}

code,
kbd,
samp,
pre {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-feature-settings: normal;
	font-variation-settings: normal;
	font-size: 1em;
}

small {
	font-size: 80%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

table {
	text-indent: 0;
	border-color: inherit;
	border-collapse: collapse;
}

button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-feature-settings: inherit;
	font-variation-settings: inherit;
	font-size: 100%;
	font-weight: inherit;
	line-height: inherit;
	letter-spacing: inherit;
	color: inherit;
	margin: 0;
	padding: 0;
}

button,
select {
	text-transform: none;
}

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
	-webkit-appearance: button;
	background-color: transparent;
	background-image: none;
}

:-moz-focusring {
	outline: auto;
}

:-moz-ui-invalid {
	box-shadow: none;
}

progress {
	vertical-align: baseline;
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
	height: auto;
}

[type='search'] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

::-webkit-search-decoration {
	-webkit-appearance: none;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

summary {
	display: list-item;
}

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
	margin: 0;
}

fieldset {
	margin: 0;
	padding: 0;
}

legend {
	padding: 0;
}

ol,
ul,
menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

dialog {
	padding: 0;
}

textarea {
	resize: vertical;
}

input::placeholder,
textarea::placeholder {
	opacity: 1;
	color: #9ca3af;
}

button,
[role="button"] {
	cursor: pointer;
}

:disabled {
	cursor: default;
}

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
	display: block;
	vertical-align: middle;
}

img,
video {
	max-width: 100%;
	height: auto;
}

[hidden] {
	display: none;
}

.cls-dpywjr {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.page-wrapper {
	min-height: 100vh;
	background-color: rgb(247 244 236 / 1);
	color: rgb(33 49 39 / 1);
	width: 100%;
}

.site-header {
	position: sticky;
	top: 0px;
	z-index: 50;
	border-bottom-width: 1px;
	border-color: rgb(234 223 215 / 1);
	background-color: rgba(255, 250, 246, 0.92);
	backdrop-filter: blur(12px);
}

.utility-bar {
	border-bottom-width: 1px;
	border-color: rgb(230 234 223 / 1);
	background-color: rgb(238 242 231 / 1);
}

.utility-container {
	margin-left: auto;
	margin-right: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
}

.utility-left {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(57 81 63 / 1);
}

.utility-link {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.utility-link:hover {
	color: rgb(201 154 59 / 1);
}

.utility-icon {
	height: 1rem;
	width: 1rem;
}

.utility-info {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.utility-right {
	display: flex;
	align-items: center;
	gap: 1rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
}

.utility-action {
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.utility-action:hover {
	color: rgb(201 154 59 / 1);
}

.utility-divider {
	height: 1rem;
	width: 1px;
	background-color: rgb(202 211 192 / 1);
}

.social-link {
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(214 221 207 / 1);
	padding: 0.5rem;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.social-link:hover {
	border-color: rgb(201 154 59 / 1);
	background-color: rgb(255 250 240 / 1);
}

.social-icon {
	height: 1rem;
	width: 1rem;
}

.main-header {
	margin-left: auto;
	margin-right: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 1.25rem;
	padding-bottom: 1.25rem;
}

.brand-group {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.brand-mark {
	display: flex;
	height: 3rem;
	width: 3rem;
	align-items: center;
	justify-content: center;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(240 217 232 / 1);
	background-color: rgb(255 253 248 / 1);
	background-image: linear-gradient(to bottom right, #fff7ef, #fbe8f4);
	font-size: 1.125rem;
	line-height: 1.75rem;
	font-weight: 600;
	color: rgb(140 46 102 / 1);
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.brand-icon {
	height: 1.75rem;
	width: 1.75rem;
}

.brand-text {
	display: flex;
	flex-direction: column;
	gap: 0px;
}

.brand-title {
	font-size: 1.5rem;
	line-height: 1;
	font-weight: 700;
	color: rgb(96 24 67 / 1);
}

.brand-subtitle {
	font-size: 0.875rem;
	line-height: 1.25rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(122 101 116 / 1);
	font-weight: 500;
}

.primary-navigation {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 500;
	color: rgb(94 75 87 / 1);
}

.nav-link {
	border-radius: 9999px;
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 500;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.nav-link:hover {
	background-color: rgb(238 242 231 / 1);
	color: rgb(23 56 38 / 1);
}

.header-button {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	border-width: 1px;
	border-color: rgb(36 84 58 / 1);
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.header-button:hover {
	background-color: rgb(28 68 47 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #c99a3b;
}

.hero-section {
	position: relative;
	overflow: hidden;
	border-bottom-width: 1px;
	border-color: rgb(240 229 234 / 1);
}

.hero-background {
	position: absolute;
	inset: 0px;
}

.hero-image {
	height: 620px;
	width: 100%;
	object-fit: cover;
	border-radius: 1.5rem;
	opacity: 20%;
}

.hero-container {
	position: relative;
	margin-left: auto;
	margin-right: auto;
	display: grid;
	min-height: 760px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	align-items: center;
	gap: 1.5rem;
	padding-left: 1.3rem;
	padding-right: 1.3rem;
	padding-top: 3rem;
	padding-bottom: 3rem;
	max-width: 80rem;
}

.hero-content {
	display: flex;
	max-width: 42rem;
	flex-direction: column;
	gap: 1.25rem;
}

.hero-eyebrow {
	display: inline-flex;
	width: fit-content;
	align-items: center;
	gap: 0.5rem;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(215 193 140 / 1);
	background-color: rgb(255 247 223 / 0.1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(246 230 183 / 1);
}

.hero-eyebrow-icon {
	height: 1rem;
	width: 1rem;
}

.hero-heading-group {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.hero-title {
	font-weight: 700;
	color: rgb(255 255 255 / 1);
	max-width: 48rem;
}

.hero-description {
	max-width: 42rem;
	font-size: 1.125rem;
	line-height: 2rem;
	color: rgb(247 236 244);
}

.hero-actions {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.primary-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: 9999px;
	background-color: rgb(201 154 59 / 1);
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 0.875rem;
	padding-bottom: 0.875rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	color: rgb(29 36 27 / 1);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.primary-cta:hover {
	background-color: rgb(217 171 77 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #fff3d1;
}

.secondary-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(223 232 223 / 1);
	background-color: rgb(255 255 255 / 0.1);
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 0.875rem;
	padding-bottom: 0.875rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	color: rgb(255 255 255 / 1);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.secondary-cta:hover {
	background-color: rgb(255 255 255 / 1);
	color: rgb(23 56 38 / 1);
}

.hero-metrics {
	display: grid;
	max-width: 42rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	padding-top: 0.5rem;
}

.metric-card {
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(240 223 232 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1.25rem;
	color: rgb(255 255 255 / 1);
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.metric-value {
	font-size: 2.25rem;
	line-height: 2.5rem;
	font-weight: 700;
}

.metric-label {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(111 98 112 / 1);
}

.hero-side-panel {
	margin-left: auto;
	width: 100%;
	max-width: 36rem;
	border-radius: 28px;
	border-width: 1px;
	border-color: rgb(255 255 255 / 0.15);
	background-color: rgb(252 251 247 / 44%);
	padding: 2rem;
}

.panel-header {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.panel-eyebrow {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(116 84 20);
}

.panel-title {
	font-size: 2.25rem;
	line-height: 1.25;
	font-weight: 700;
	color: rgb(29 59 42 / 1);
}

.panel-divider {
	margin-top: 1.5rem;
	margin-bottom: 1.5rem;
}

.priority-list {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.priority-item {
	display: flex;
	gap: 1rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(224 230 218 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1rem;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.priority-item:hover {
	border-color: rgb(201 154 59 / 1);
}

.priority-icon-box {
	display: flex;
	height: 3rem;
	width: 3rem;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	background-color: rgb(238 244 234 / 1);
}

.priority-icon {
	height: 1.25rem;
	width: 1.25rem;
}

.priority-content {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.priority-title {
	font-size: 1.125rem;
	line-height: 1.75rem;
	font-weight: 600;
	color: rgb(28 56 39 / 1);
}

.priority-text {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(91 109 95 / 1);
}

.about-section {
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
	border-bottom-width: 1px;
	border-color: rgb(239 227 233 / 1);
}

.about-grid {
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 2.5rem;
}

.about-content {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.section-label {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: rgb(228 200 133 / 1);
}

.section-title {
	margin-top: 0.75rem;
	font-weight: 700;
	font-size: 3rem;
	line-height: 1;
}

.section-paragraph {
	color: rgb(77 95 82 / 1);
}

.feature-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
}

.feature-card {
	border-radius: 1.5rem;
	border-width: 1px;
	border-color: rgb(221 228 215 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1.5rem;
}

.feature-title {
	margin-bottom: 0.5rem;
	font-size: 1.125rem;
	line-height: 1.75rem;
	font-weight: 600;
	color: rgb(93 36 69 / 1);
}

.feature-text {
	font-size: 0.875rem;
	line-height: 1.5rem;
	color: rgb(107 91 104 / 1);
}

.about-side-column {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.image-card {
	overflow: hidden;
	border-radius: 28px;
	border-width: 1px;
	border-color: rgb(219 225 213 / 1);
	background-color: rgb(255 255 255 / 1);
}

.about-image {
	height: 280px;
	width: 100%;
	object-fit: cover;
}

.stats-card {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
	border-radius: 28px;
	border-width: 1px;
	border-color: rgb(219 225 213 / 1);
	background-color: rgb(240 244 235 / 1);
	padding: 1.5rem;
}

.stat-item {
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(215 223 207 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1.25rem;
}

.stat-number {
	font-size: 2.25rem;
	line-height: 2.5rem;
	font-weight: 700;
	color: rgb(28 56 39 / 1);
}

.stat-label {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(91 109 95 / 1);
}

.research-section {
	border-top-width: 1px;
	border-bottom-width: 1px;
	border-color: rgb(234 223 215 / 1);
	background-color: rgb(255 255 255 / 1);
}

.research-container {
	margin-left: auto;
	margin-right: auto;
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.section-header {
	margin-bottom: 2.5rem;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.5rem;
}

.header-content {
	max-width: 42rem;
}

.section-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(215 223 207 / 1);
	background-color: rgb(255 255 255 / 1);
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.section-link:hover {
	border-color: rgb(201 154 59 / 1);
	color: rgb(201 154 59 / 1);
}

.research-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.5rem;
}

.research-card {
	border-radius: 1.5rem;
	background-color: rgb(255 253 250 / 1);
	padding: 1.5rem;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
	border-width: 1px;
}

.research-card:hover {
	transform: translate(0, -0.25rem) rotate(0) skewX(0) skewY(0) scaleX(1) scaleY(1);
	border-color: rgb(207 84 158 / 1);
	box-shadow: 0 0 #0000, 0 0 #0000, 0 18px 40px rgba(185, 34, 125, 0.08);
}

.research-icon-box {
	margin-bottom: 1.25rem;
	display: flex;
	height: 3.5rem;
	width: 3.5rem;
	align-items: center;
	justify-content: center;
	border-radius: 1rem;
	background-color: rgb(247 239 220 / 1);
}

.research-icon {
	height: 1.5rem;
	width: 1.5rem;
}

.research-title {
	margin-bottom: 0.75rem;
	font-size: 1.5rem;
	line-height: 2rem;
	font-weight: 600;
	color: rgb(96 24 67 / 1);
	margin-top: 1rem;
}

.research-text {
	font-size: 0.875rem;
	line-height: 1.75rem;
	color: rgb(107 88 82 / 1);
	margin-top: 0.75rem;
}

.programs-section {
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
	border-bottom-width: 1px;
	border-color: rgb(238 225 232 / 1);
}

.programs-header {
	margin-bottom: 2.5rem;
	max-width: 48rem;
}

.programs-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.5rem;
}

.program-card {
	overflow: hidden;
	border-radius: 1.5rem;
	border-width: 1px;
	border-color: rgb(236 216 228 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1.75rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.program-image {
	height: 16rem;
	width: 100%;
	object-fit: cover;
}

.program-content {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: 1.75rem;
}

.program-title {
	font-size: 1.875rem;
	line-height: 2.25rem;
	font-weight: 600;
	color: rgb(96 24 67 / 1);
}

.program-text {
	color: rgb(104 90 103 / 1);
	margin-top: 1rem;
}

.program-link {
	width: fit-content;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(215 223 207 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.program-link:hover {
	border-color: rgb(201 154 59 / 1);
	color: rgb(201 154 59 / 1);
}

.news-section {
	border-top-width: 1px;
	border-bottom-width: 1px;
	border-color: rgb(221 227 214 / 1);
	background-color: rgb(241 245 238 / 1);
}

.news-container {
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.news-header {
	margin-bottom: 2.5rem;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.5rem;
}

.header-link {
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(230 215 222 / 1);
	background-color: rgb(255 255 255 / 1);
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
	color: rgb(125 36 88 / 1);
	text-decoration-line: none;
}

.header-link:hover {
	border-color: rgb(207 84 158 / 1);
	color: rgb(201 154 59 / 1);
	background-color: rgb(255 240 246 / 1);
}

.news-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.5rem;
}

.news-card {
	border-radius: 28px;
	border-width: 1px;
	border-color: rgb(219 226 213 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1.5rem;
}

.news-date {
	font-size: 0.75rem;
	line-height: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(201 154 59 / 1);
}

.news-title {
	margin-top: 1rem;
	font-size: 1.25rem;
	line-height: 1.75rem;
	font-weight: 600;
	color: rgb(29 59 42 / 1);
}

.news-excerpt {
	margin-top: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(91 109 95 / 1);
}

.news-link {
	margin-top: 1.25rem;
	display: inline-flex;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.news-link:hover {
	color: rgb(201 154 59 / 1);
}

.partners-section {
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.partners-wrapper {
	border-radius: 32px;
	border-width: 1px;
	border-color: rgb(217 224 210 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 2rem;
}

.partners-header {
	margin-bottom: 2rem;
	max-width: 42rem;
}

.partners-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1rem;
}

.partner-item {
	display: flex;
	min-height: 120px;
	align-items: center;
	justify-content: center;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(225 231 219 / 1);
	background-color: rgb(248 250 245 / 1);
	padding: 1.5rem;
	text-align: center;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	color: rgb(70 96 76 / 1);
}

.contact-cta-section {
	position: relative;
	overflow: hidden;
	background-color: rgb(23 56 38 / 1);
}

.cta-background {
	position: absolute;
	inset: 0px;
	opacity: 0.2;
}

.cta-image {
	height: 100%;
	width: 100%;
	object-fit: cover;
}

.cta-container {
	position: relative;
	margin-left: auto;
	margin-right: auto;
	display: grid;
	grid-template-columns: 1fr .9fr;
	gap: 2.5rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.cta-content {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	color: rgb(255 255 255 / 1);
}

.cta-title {
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.25;
}

.cta-text {
	max-width: 42rem;
	color: rgb(216 231 218 / 1);
}

.cta-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
	padding-top: 0.5rem;
}

.cta-bullet {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(255 255 255 / 0.1);
	background-color: rgb(255 255 255 / 0.05);
	padding: 1rem;
}

.cta-icon {
	height: 1.25rem;
	width: 1.25rem;
}

.cta-bullet-text {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(237 244 238 / 1);
}

.contact-form-card {
	border-radius: 2rem;
	border-width: 1px;
	border-color: rgb(234 221 229 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 2rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.form-header {
	margin-bottom: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.form-title {
	font-size: 1.875rem;
	line-height: 2.25rem;
	font-weight: 700;
	color: rgb(29 59 42 / 1);
}

.form-text {
	margin-top: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(91 109 95 / 1);
}

.contact-form {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.form-row {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
}

.input-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.input-label {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 500;
	color: rgb(54 80 60 / 1);
}

.text-input {
	width: 100%;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(215 223 207 / 1);
	background-color: rgb(255 253 253 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(63 49 64 / 1);
	outline: 2px solid transparent;
	outline-offset: 2px;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.text-input:focus {
	border-color: rgb(207 84 158 / 1);
	box-shadow: 0 0 0 0px #fff, 0 0 0 calc(2px + 0px) rgb(240 221 174 / 1), 0 0 #0000;
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f7dcec;
}

.email-input {
	width: 100%;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(215 223 207 / 1);
	background-color: rgb(255 253 253 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(63 49 64 / 1);
	outline: 2px solid transparent;
	outline-offset: 2px;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.email-input:focus {
	border-color: rgb(207 84 158 / 1);
	box-shadow: 0 0 0 0px #fff, 0 0 0 calc(2px + 0px) rgb(240 221 174 / 1), 0 0 #0000;
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f7dcec;
}

.phone-input {
	width: 100%;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(215 223 207 / 1);
	background-color: rgb(255 253 251 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(63 45 43 / 1);
	outline: 2px solid transparent;
	outline-offset: 2px;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.phone-input:focus {
	border-color: rgb(207 84 158 / 1);
	box-shadow: 0 0 0 0px #fff, 0 0 0 calc(2px + 0px) rgb(240 221 174 / 1), 0 0 #0000;
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f4d7e7;
}

.select-input {
	width: 100%;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(215 223 207 / 1);
	background-color: rgb(255 253 251 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(63 45 43 / 1);
	outline: 2px solid transparent;
	outline-offset: 2px;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.select-input:focus {
	border-color: rgb(207 84 158 / 1);
	box-shadow: 0 0 0 0px #fff, 0 0 0 calc(2px + 0px) rgb(240 221 174 / 1), 0 0 #0000;
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f4d7e7;
}

.textarea-input {
	width: 100%;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(215 223 207 / 1);
	background-color: rgb(255 253 253 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(63 49 64 / 1);
	outline: 2px solid transparent;
	outline-offset: 2px;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.textarea-input:focus {
	border-color: rgb(207 84 158 / 1);
	box-shadow: 0 0 0 0px #fff, 0 0 0 calc(2px + 0px) rgb(240 221 174 / 1), 0 0 #0000;
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f7dcec;
}

.checkbox-wrapper {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(227 231 220 / 1);
	background-color: rgb(250 249 244 / 1);
	padding: 1rem;
}

.checkbox-input {
	margin-top: 0.25rem;
	height: 1.25rem;
	width: 1.25rem;
	border-radius: 0.25rem;
	border-color: rgb(217 191 208 / 1);
	color: rgb(207 84 158 / 1);
	accent-color: #cf549e;
	outline: 2px solid transparent;
	outline-offset: 2px;
}

.checkbox-text {
	font-size: 0.875rem;
	line-height: 1.5rem;
	color: rgb(111 91 86 / 1);
}

.submit-button {
	display: inline-flex;
	width: fit-content;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	border-width: 1px;
	border-color: rgb(207 84 158 / 1);
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
	border-radius: 0.75rem;
	color: rgb(255 255 255 / 1);
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.submit-button:hover {
	background-color: rgb(185 34 125 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f2bfdc;
}

.site-footer {
	background-color: rgb(55 4 58 / 91%);
	color: rgb(219 231 221 / 1);
	border-top-width: 1px;
	border-color: rgb(234 223 215 / 1);
}

.footer-container {
	margin-left: auto;
	margin-right: auto;
	display: flex;
	grid-template-columns: 1.2fr .8fr .8fr 1fr;
	gap: 2.5rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 3.5rem;
	padding-bottom: 3.5rem;
	max-width: 80rem;
	flex-direction: column;
}

.footer-brand-column {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.footer-brand-group {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.footer-brand-mark {
	display: flex;
	height: 3rem;
	width: 3rem;
	align-items: center;
	justify-content: center;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(255 255 255 / 0.15);
	background-color: rgb(255 255 255 / 0.1);
	font-size: 1.125rem;
	line-height: 1.75rem;
	font-weight: 600;
}

.footer-brand-icon {
	height: 1.75rem;
	width: 1.75rem;
}

.footer-brand-text {
	display: flex;
	flex-direction: column;
	gap: 0px;
}

.footer-brand-title {
	font-size: 1.5rem;
	line-height: 2rem;
	font-weight: 700;
	color: rgb(239 183 216);
}

.footer-brand-subtitle {
	font-size: 0.875rem;
	line-height: 1.25rem;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: rgb(255 255 255 / 0.7);
}

.footer-text {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(233 183 172);
}

.footer-socials {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.footer-social-link {
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(255 255 255 / 0.1);
	background-color: rgb(255 255 255 / 0.05);
	padding: 0.75rem;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.footer-social-link:hover {
	border-color: rgb(201 154 59 / 1);
	background-color: rgb(255 255 255 / 0.1);
}

.footer-social-icon {
	height: 1rem;
	width: 1rem;
}

.footer-links-column {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.footer-heading {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	color: rgb(255 255 255 / 1);
	text-transform: uppercase;
	letter-spacing: 0.18em;
}

.footer-link {
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(255 255 255 / 0.75);
	text-decoration-line: none;
	border-radius: 0.5rem;
	padding-left: 0.25rem;
	padding-right: 0.25rem;
	padding-top: 0.25rem;
	padding-bottom: 0.25rem;
}

.footer-link:hover {
	color: rgb(255 255 255 / 1);
	outline-style: solid;
	outline-width: 1px;
	outline-color: rgb(255 255 255 / 0.2);
}

.footer-contact-column {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.footer-contact-item {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
}

.footer-contact-icon {
	margin-top: 0.25rem;
	height: 1rem;
	width: 1rem;
}

.footer-contact-text {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(189 208 192 / 1);
}

.footer-newsletter-column {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.newsletter-form {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.newsletter-input {
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(255 255 255 / 0.1);
	background-color: rgb(255 255 255 / 0.05);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(255 255 255 / 1);
	outline: 2px solid transparent;
	outline-offset: 2px;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.newsletter-input::placeholder {
	color: rgb(165 183 168 / 1);
}

.newsletter-input:focus {
	border-color: rgb(228 200 133 / 1);
	box-shadow: 0 0 0 0px #fff, 0 0 0 calc(2px + 0px) rgb(111 91 46 / 1), 0 0 #0000;
}

.newsletter-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(201 154 59 / 1);
	background-color: rgb(201 154 59 / 1);
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	color: rgb(22 36 24 / 1);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.newsletter-button:hover {
	background-color: rgb(215 170 74 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f2dca2;
}

.footer-bottom {
	border-top-width: 1px;
	border-color: rgb(255 255 255 / 0.1);
	margin-top: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-top: 1.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(255 255 255 / 0.6);
}

.footer-bottom-container {
	margin-left: auto;
	margin-right: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 1.25rem;
	padding-bottom: 1.25rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(158 177 162 / 1);
}

.footer-bottom-links {
	display: flex;
	align-items: center;
	gap: 1.25rem;
}

.footer-bottom-link {
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.footer-bottom-link:hover {
	color: rgb(228 200 133 / 1);
}

* {
	box-sizing: border-box;
}

.soft-panel {
	background: linear-gradient(180deg, #fffdfb 0%, #fff7fb 100%);
	backdrop-filter: blur(8px);
}

.hero-glow {
	background: linear-gradient(135deg, #fff8fc 0%, #fff6ee 45%, #fffdf8 100%);
}

.leaf-tint {
	background: linear-gradient(180deg, #fffdf9 0%, #fff7ef 100%);
}

.rose-tint {
	background: linear-gradient(180deg, #fff8fb 0%, #fffdf9 100%);
}

.cls-i3c6k0 {
	background-color: rgb(255 250 246 / 1);
	color: rgb(63 45 43 / 1);
}

.header-container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 1rem;
	padding-bottom: 1rem;
	margin-left: auto;
	margin-right: auto;
	max-width: 80rem;
}

.brand-link {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	text-decoration-line: none;
}

.brand-emblem {
	display: flex;
	height: 3.5rem;
	width: 3.5rem;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(233 215 203 / 1);
	background-image: linear-gradient(to bottom right, #fff5ea, #f9e2ee);
	text-align: center;
	font-size: 10px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(138 77 93 / 1);
}

.main-navigation {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 500;
	color: rgb(91 69 65 / 1);
}

.navigation-link {
	border-radius: 0.5rem;
	border-width: 1px;
	border-color: rgb(231 215 222 / 1);
	padding-left: 0.5rem;
	padding-right: 0.5rem;
	padding-top: 0.25rem;
	padding-bottom: 0.25rem;
	color: rgb(94 75 87 / 1);
	text-decoration-line: none;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.navigation-link:hover {
	border-color: rgb(207 84 158 / 1);
	background-color: rgb(255 240 246 / 1);
	color: rgb(185 34 125 / 1);
	outline-style: solid;
	outline-width: 1px;
	outline-color: #f0d9e8;
}

.main-content {
	width: 100%;
}

.hero-intro {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.eyebrow {
	display: inline-flex;
	width: fit-content;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(236 217 200 / 1);
	background-color: rgb(255 248 241 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.25rem;
	padding-bottom: 0.25rem;
	font-size: 0.75rem;
	line-height: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.22em;
	color: rgb(142 111 75 / 1);
}

.hero-heading {
	font-size: 3.25rem;
	font-weight: 600;
	letter-spacing: -0.02em;
	color: rgb(96 24 67 / 1);
}

.primary-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(207 84 158 / 1);
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	color: rgb(255 255 255 / 1);
	text-decoration-line: none;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
	gap: 0.5rem;
}

.primary-button:hover {
	background-color: rgb(185 34 125 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f2bfdc;
}

.secondary-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(234 216 228 / 1);
	background-color: rgb(255 255 255 / 1);
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	color: rgb(111 54 92 / 1);
	text-decoration-line: none;
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
	gap: 0.5rem;
}

.secondary-button:hover {
	border-color: rgb(207 84 158 / 1);
	color: rgb(185 34 125 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-offset: 2px;
	outline-color: #f7dcec;
}

.metric-number {
	font-size: 2.25rem;
	line-height: 2.5rem;
	font-weight: 700;
	color: rgb(96 24 67 / 1);
}

.hero-visual-column {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	position: relative;
}

.hero-image-card {
	overflow: hidden;
	border-radius: 2rem;
	border-width: 1px;
	border-color: rgb(234 223 215 / 1);
	padding: 0.75rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 20px 60px rgba(96, 24, 67, 0.08);
}

.hero-highlight-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
}

.highlight-card {
	border-radius: 1rem;
	border-width: 1px;
	background-color: rgb(255 255 255 / 1);
	padding: 1.25rem;
}

.highlight-header {
	margin-bottom: 0.75rem;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.highlight-icon {
	height: 1.25rem;
	width: 1.25rem;
}

.highlight-title {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(123 83 96 / 1);
}

.highlight-text {
	font-size: 0.875rem;
	line-height: 1.75rem;
	color: rgb(106 86 81 / 1);
}

.trust-bar-section {
	border-bottom-width: 1px;
	border-color: rgb(234 223 215 / 1);
	background-color: rgb(255 255 255 / 1);
}

.trust-bar-container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 1.5rem;
	padding-bottom: 1.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(123 102 97 / 1);
}

.trust-item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.trust-icon {
	height: 1.25rem;
	width: 1.25rem;
}

.about-container {
	display: grid;
	grid-template-columns: 1.15fr 0.85fr;
	gap: 2.5rem;
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.section-eyebrow {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: rgb(185 34 125 / 1);
}

.section-heading {
	font-size: 2rem;
	font-weight: 600;
	color: rgb(96 24 67 / 1);
}

.about-paragraph {
	color: rgb(95 76 71 / 1);
}

.mission-vision-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.5rem;
}

.content-card {
	border-radius: 1rem;
	border-width: 1px;
	background-color: rgb(255 255 255 / 1);
	padding: 1.5rem;
}

.card-heading {
	font-size: 1.5rem;
	line-height: 2rem;
	font-weight: 600;
	color: rgb(96 24 67 / 1);
}

.card-text {
	margin-top: 1.25rem;
	font-size: 0.875rem;
	line-height: 1.75rem;
	color: rgb(106 91 103 / 1);
}

.about-side-panel {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.info-panel {
	border-radius: 1.6rem;
	border-width: 1px;
	background-color: rgb(255 255 255 / 1);
	padding: 1.75rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.panel-heading {
	font-size: 1.5rem;
	line-height: 2rem;
	font-weight: 600;
	color: rgb(96 24 67 / 1);
}

.value-list {
	margin-top: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.value-item {
	display: flex;
	gap: 1rem;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(240 228 218 / 1);
	background-color: rgb(255 253 250 / 1);
	padding: 1rem;
}

.value-icon {
	margin-top: 0.25rem;
	height: 1.25rem;
	width: 1.25rem;
}

.value-content {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.value-title {
	font-weight: 600;
	color: rgb(90 56 72 / 1);
}

.value-description {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(116 95 89 / 1);
}

.image-panel {
	overflow: hidden;
	border-radius: 1.6rem;
	border-width: 1px;
	border-color: rgb(234 223 215 / 1);
}

.header-text {
	max-width: 42rem;
}

.programs-container {
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.program-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
}

.program-title-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.program-description {
	color: rgb(107 88 82 / 1);
}

.program-icon {
	height: 1.75rem;
	width: 1.75rem;
}

.program-tags {
	margin-top: 1.25rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.program-tag {
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(238 222 231 / 1);
	background-color: rgb(255 248 251 / 1);
	padding-left: 0.75rem;
	padding-right: 0.75rem;
	padding-top: 0.25rem;
	padding-bottom: 0.25rem;
	font-size: 0.75rem;
	line-height: 1rem;
	font-weight: 500;
	color: rgb(135 76 105 / 1);
}

.publications-section {
	border-bottom-width: 1px;
	border-color: rgb(240 230 210 / 1);
	background-color: rgb(255 255 255 / 1);
}

.publications-container {
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.publications-layout {
	display: grid;
	grid-template-columns: 0.95fr 1.05fr;
	gap: 1.5rem;
}

.publications-image-card {
	overflow: hidden;
	border-radius: 1.8rem;
	border-width: 1px;
	border-color: rgb(234 223 215 / 1);
}

.publications-image {
	height: 100%;
	min-height: 460px;
	width: 100%;
	object-fit: cover;
}

.publication-cards-column {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.5rem;
}

.publication-card {
	border-radius: 1.5rem;
	border-width: 1px;
	background-color: rgb(255 255 255 / 1);
	padding: 1.75rem;
	border-color: rgb(240 227 192 / 1);
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.publication-number {
	font-size: 0.75rem;
	line-height: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.22em;
	color: rgb(154 122 82 / 1);
}

.publication-title {
	margin-top: 1rem;
	font-size: 1.875rem;
	line-height: 2.25rem;
	font-weight: 600;
	color: rgb(111 84 23 / 1);
}

.publication-text {
	margin-top: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.75rem;
	color: rgb(108 98 87 / 1);
}

.events-section {
	border-bottom-width: 1px;
	border-color: rgb(234 223 215 / 1);
}

.events-container {
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.events-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.5rem;
}

.event-card {
	border-radius: 1.7rem;
	border-width: 1px;
	background-color: rgb(255 255 255 / 1);
	padding: 1.5rem;
}

.event-date {
	margin-bottom: 1.25rem;
	display: inline-flex;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(239 224 213 / 1);
	background-color: rgb(255 249 241 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.25rem;
	padding-bottom: 0.25rem;
	font-size: 0.75rem;
	line-height: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(143 107 68 / 1);
}

.event-title {
	font-size: 1.5rem;
	line-height: 2rem;
	font-weight: 600;
	color: rgb(96 24 67 / 1);
}

.event-description {
	margin-top: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.75rem;
	color: rgb(107 88 82 / 1);
}

.membership-section {
	border-bottom-width: 1px;
	border-color: rgb(234 223 215 / 1);
	background-color: rgb(255 255 255 / 1);
}

.membership-container {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	gap: 2rem;
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.membership-intro {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.section-description {
	color: rgb(96 80 74 / 1);
}

.membership-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
}

.membership-card {
	border-radius: 2rem;
	border-width: 1px;
	background-color: rgb(255 247 251 / 1);
	padding: 2rem;
	border-color: rgb(234 220 229 / 1);
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.membership-title {
	font-weight: 600;
	color: rgb(94 35 69 / 1);
}

.membership-text {
	margin-top: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.5rem;
	color: rgb(109 93 105 / 1);
}

.contact-container {
	display: grid;
	grid-template-columns: 0.8fr 1.2fr;
	gap: 2rem;
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.contact-details-column {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.contact-intro {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.contact-cards {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.contact-card {
	border-radius: 1rem;
	border-width: 1px;
	background-color: rgb(255 255 255 / 1);
	padding: 1.25rem;
}

.contact-card-header {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.contact-icon {
	height: 1.25rem;
	width: 1.25rem;
	margin-top: 0.25rem;
}

.contact-label {
	font-weight: 600;
	color: rgb(90 56 72 / 1);
}

.contact-value {
	margin-top: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(110 91 85 / 1);
}

.contact-form-panel {
	border-radius: 1.8rem;
	border-width: 1px;
	background-color: rgb(255 255 255 / 1);
	padding: 2rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.inquiry-form {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.form-heading {
	font-size: 1.875rem;
	line-height: 2.25rem;
	font-weight: 600;
	color: rgb(96 24 67 / 1);
}

.form-description {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(115 96 90 / 1);
}

.form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
}

.form-field {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.field-label {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 500;
	color: rgb(95 75 70 / 1);
}

.text-input::placeholder {
	color: rgb(158 143 153 / 1);
}

.text-input:hover {
	border-color: rgb(207 84 158 / 1);
}

.email-input::placeholder {
	color: rgb(158 143 153 / 1);
}

.email-input:hover {
	border-color: rgb(207 84 158 / 1);
}

.phone-input::placeholder {
	color: rgb(178 154 147 / 1);
}

.phone-input:hover {
	border-color: rgb(207 84 158 / 1);
}

.select-input:hover {
	border-color: rgb(207 84 158 / 1);
}

.textarea-input::placeholder {
	color: rgb(158 143 153 / 1);
}

.textarea-input:hover {
	border-color: rgb(207 84 158 / 1);
}

.checkbox-field {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(241 227 219 / 1);
	background-color: rgb(255 253 250 / 1);
	padding: 1rem;
}

.form-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.form-note {
	font-size: 0.875rem;
	line-height: 1.25rem;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: rgb(122 107 118 / 1);
}

.footer-top {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr 0.9fr 1fr;
	gap: 2rem;
}

.footer-brand {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.footer-emblem {
	display: flex;
	height: 3rem;
	width: 3rem;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(231 216 205 / 1);
	background-color: rgb(255 255 255 / 1);
	font-size: 10px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(138 77 93 / 1);
}

.footer-description {
	max-width: 28rem;
	font-size: 0.875rem;
	line-height: 1.75rem;
	color: rgb(255 255 255 / 0.75);
}

.footer-column {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.font-heading {
	font-family: "Cormorant Garamond", serif;
}

.rose-panel {
	background: linear-gradient(135deg, #fff7fb 0%, #fff3ea 100%);
}

.gold-panel {
	background: linear-gradient(135deg, #fff9ef 0%, #fffdf8 100%);
}

.site-wrapper {
	min-height: 100vh;
	background-color: rgb(255 250 247 / 1);
	color: rgb(63 49 64 / 1);
}

.header {
	position: sticky;
	top: 0px;
	z-index: 40;
	border-bottom-width: 1px;
	border-color: rgb(239 228 234 / 1);
	background-color: rgb(255 255 255 / 0.9);
	backdrop-filter: blur(8px);
}

.brand-row {
	display: flex;
	width: 100%;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.header-cta-mobile {
	display: none;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(207 84 158 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.header-cta-mobile:hover {
	background-color: rgb(185 34 125 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-color: #f2bfdc;
}

.header-navigation-area {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}

.header-cta {
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(207 84 158 / 1);
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.header-cta:hover {
	background-color: rgb(185 34 125 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-color: #f2bfdc;
}

.hero-badge-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
}

.hero-badge {
	display: inline-flex;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(244 233 206 / 1);
	background-color: rgb(255 250 240 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	font-size: 0.75rem;
	line-height: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: rgb(154 107 24 / 1);
}

.hero-cta-group {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1rem;
}

.button-icon {
	height: 1rem;
	width: 1rem;
}

.hero-visual-panel {
	overflow: hidden;
	border-radius: 2rem;
	border-width: 1px;
	border-color: rgb(239 220 231 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
}

.floating-card-top {
	position: absolute;
	left: -2rem;
	top: 2.5rem;
	display: flex;
	max-width: 260px;
	flex-direction: column;
	gap: 0.75rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(240 223 232 / 1);
	background-color: rgb(255 255 255 / 0.95);
	padding: 1.25rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
}

.floating-card-icon {
	display: flex;
	height: 2.75rem;
	width: 2.75rem;
	align-items: center;
	justify-content: center;
	border-radius: 0.75rem;
	background-color: rgb(255 244 221 / 1);
}

.icon-image {
	height: 1.5rem;
	width: 1.5rem;
}

.floating-card-title {
	font-weight: 600;
	color: rgb(107 83 24 / 1);
}

.floating-card-text {
	font-size: 0.875rem;
	line-height: 1.5rem;
	color: rgb(109 96 112 / 1);
}

.floating-card-bottom {
	position: absolute;
	right: -2rem;
	bottom: 2.5rem;
	display: flex;
	max-width: 280px;
	flex-direction: column;
	gap: 0.75rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(244 234 210 / 1);
	background-color: rgb(255 253 248 / 0.95);
	padding: 1.25rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
}

.section-container {
	margin-left: auto;
	margin-right: auto;
	display: grid;
	max-width: 80rem;
	grid-template-columns: 0.9fr 1.1fr;
	gap: 2rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.section-heading-row {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 2.5rem;
}

.section-intro {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.section-supporting-text {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	color: rgb(98 85 96 / 1);
}

.info-card {
	border-radius: 1.5rem;
	border-width: 1px;
	border-color: rgb(232 221 233 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 2rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.card-icon {
	margin-bottom: 1.25rem;
	height: 2rem;
	width: 2rem;
}

.card-title {
	margin-top: 1rem;
	font-size: 3rem;
	line-height: 1;
	font-weight: 700;
	color: rgb(96 24 67 / 1);
}

.focus-areas-section {
	border-bottom-width: 1px;
	border-color: rgb(238 227 232 / 1);
	background-color: rgb(255 255 255 / 1);
}

.heading-group {
	display: flex;
	max-width: 48rem;
	flex-direction: column;
	gap: 1rem;
}

.section-summary {
	max-width: 36rem;
	color: rgb(102 88 103 / 1);
}

.focus-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.5rem;
}

.focus-card {
	border-radius: 1.5rem;
	border-width: 1px;
	border-color: rgb(234 223 229 / 1);
	background-color: rgb(255 253 252 / 1);
	padding: 1.75rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.focus-card:hover {
	transform: translate(0, -0.25rem) rotate(0) skewX(0) skewY(0) scaleX(1) scaleY(1);
	border-color: rgb(207 84 158 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-color: #f8d8ea;
}

.programs-layout {
	display: grid;
	grid-template-columns: 1.2fr 0.8fr;
	gap: 1.5rem;
}

.program-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.programs-sidebar {
	border-radius: 2rem;
	border-width: 1px;
	border-color: rgb(236 216 228 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 2rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.sidebar-header {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.sidebar-label {
	display: inline-flex;
	width: fit-content;
	border-radius: 9999px;
	border-width: 1px;
	border-color: rgb(240 215 231 / 1);
	background-color: rgb(255 246 251 / 1);
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	font-size: 0.75rem;
	line-height: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(185 34 125 / 1);
}

.sidebar-title {
	font-size: 2.25rem;
	line-height: 2.5rem;
	font-weight: 600;
	color: rgb(96 24 67 / 1);
}

.sidebar-list {
	margin-top: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.sidebar-item {
	display: flex;
	gap: 1rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(241 229 235 / 1);
	background-color: rgb(255 253 253 / 1);
	padding: 1rem;
}

.item-icon {
	margin-top: 0.25rem;
	height: 1.25rem;
	width: 1.25rem;
}

.item-text {
	font-size: 0.875rem;
	line-height: 1.5rem;
	color: rgb(103 90 102 / 1);
}

.research-highlights-section {
	border-bottom-width: 1px;
	border-color: rgb(237 226 232 / 1);
	background-color: rgb(255 255 255 / 1);
}

.image-column {
	overflow: hidden;
	border-radius: 2rem;
	border-width: 1px;
	border-color: rgb(235 223 229 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.section-image {
	height: 100%;
	min-height: 560px;
	width: 100%;
	border-radius: 1.5rem;
	object-fit: cover;
}

.content-column {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.research-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
}

.research-item {
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(234 223 229 / 1);
	background-color: rgb(255 253 253 / 1);
	padding: 1.25rem;
}

.research-item-title {
	font-weight: 600;
	color: rgb(95 34 69 / 1);
}

.research-item-text {
	margin-top: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.5rem;
	color: rgb(106 91 103 / 1);
}

.publications-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: 0.75rem;
	border-width: 1px;
	border-color: rgb(234 216 174 / 1);
	background-color: rgb(255 255 255 / 1);
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
	font-weight: 600;
	color: rgb(123 91 22 / 1);
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
	transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
	transition-duration: 150ms;
}

.publications-link:hover {
	border-color: rgb(199 155 52 / 1);
	outline-style: solid;
	outline-width: 2px;
	outline-color: #f5e6b8;
}

.link-icon {
	height: 1rem;
	width: 1rem;
}

.publication-cards {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.5rem;
}

.publication-meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.75rem;
	line-height: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgb(154 107 24 / 1);
}

.events-membership-section {
	border-bottom-width: 1px;
	border-color: rgb(238 226 232 / 1);
	background-color: rgb(255 255 255 / 1);
}

.events-card {
	border-radius: 2rem;
	border-width: 1px;
	border-color: rgb(234 220 229 / 1);
	background-color: rgb(255 253 253 / 1);
	padding: 2rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.card-eyebrow {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: rgb(185 34 125 / 1);
}

.card-list {
	margin-top: 2rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.feature-row {
	display: flex;
	gap: 1rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(240 227 232 / 1);
	padding: 1rem;
}

.feature-icon {
	margin-top: 0.25rem;
	height: 1.25rem;
	width: 1.25rem;
}

.feature-text-wrap {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.membership-types {
	margin-top: 2rem;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
}

.membership-item {
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(239 220 231 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1.25rem;
}

.section-text {
	color: rgb(102 88 102 / 1);
}

.contact-info-list {
	margin-top: 1rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.contact-info-item {
	display: flex;
	gap: 1rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(234 223 229 / 1);
	background-color: rgb(255 255 255 / 1);
	padding: 1rem;
	box-shadow: 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.form-label {
	font-size: 0.875rem;
	line-height: 1.25rem;
	font-weight: 600;
	color: rgb(95 75 89 / 1);
}

.checkbox-row {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	border-radius: 1rem;
	border-width: 1px;
	border-color: rgb(241 228 234 / 1);
	background-color: rgb(255 250 252 / 1);
	padding: 1rem;
}

.checkbox-label {
	font-size: 0.875rem;
	line-height: 1.5rem;
	color: rgb(103 90 102 / 1);
}

.form-action {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.footer {
	border-top-width: 1px;
	border-color: rgb(234 223 229 / 1);
	background-color: rgb(47 23 39 / 1);
	color: rgb(255 255 255 / 1);
}

.footer-links-list {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(255 255 255 / 0.75);
}

.footer-contact-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgb(255 255 255 / 0.75);
}

@media (max-width: 992px) {
	.gjs-t-h1 {
		font-size: 2.7rem;
		line-height: 3.2rem;
	}

	.gjs-t-h2 {
		font-size: 1.75rem;
		line-height: 2.2rem;
	}

	.utility-container {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.utility-left {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.5rem;
	}

	.main-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
	}

	.primary-navigation {
		width: 100%;
		flex-wrap: wrap;
		gap: 0.75rem;
	}

	.hero-container {
		grid-template-columns: repeat(1, minmax(0, 1fr));
		gap: 2.5rem;
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.hero-side-panel {
		margin-left: 0px;
	}

	.about-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.section-header {
		flex-direction: column;
		align-items: flex-start;
	}

	.research-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.programs-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.news-header {
		flex-direction: column;
		align-items: flex-start;
	}

	.news-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.partners-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cta-container {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.footer-container {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.footer-bottom-container {
		flex-direction: column;
		align-items: flex-start;
	}

	.header-container {
		padding-left: 1rem;
		padding-right: 1rem;
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
	}

	.main-navigation {
		flex-wrap: wrap;
		justify-content: flex-end;
	}

	.hero-heading {
		font-size: 2.5rem;
	}

	.hero-image {
		height: 420px;
	}

	.trust-bar-container {
		flex-wrap: wrap;
		padding-left: 1.25rem;
		padding-right: 1.25rem;
	}

	.about-container {
		grid-template-columns: repeat(1, minmax(0, 1fr));
		padding-left: 1.25rem;
		padding-right: 1.25rem;
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.research-container {
		padding-left: 1.25rem;
		padding-right: 1.25rem;
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.programs-container {
		padding-left: 1.25rem;
		padding-right: 1.25rem;
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.publications-container {
		padding-left: 1.25rem;
		padding-right: 1.25rem;
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.publications-layout {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.publications-image {
		min-height: 320px;
	}

	.events-container {
		padding-left: 1.25rem;
		padding-right: 1.25rem;
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.events-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.membership-container {
		grid-template-columns: repeat(1, minmax(0, 1fr));
		padding-left: 1.25rem;
		padding-right: 1.25rem;
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.contact-container {
		grid-template-columns: repeat(1, minmax(0, 1fr));
		padding-left: 1.25rem;
		padding-right: 1.25rem;
		padding-top: 4rem;
		padding-bottom: 4rem;
	}

	.footer-top {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.footer-bottom {
		flex-direction: column;
		align-items: flex-start;
	}

	.header-cta-mobile {
		display: inline-flex;
	}

	.header-navigation-area {
		width: 100%;
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.header-cta {
		display: none;
	}

	.hero-description {
		font-size: 1rem;
		line-height: 1.5rem;
	}

	.hero-metrics {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.floating-card-top {
		position: static;
		margin-top: 1rem;
		max-width: 100%;
	}

	.floating-card-bottom {
		position: static;
		margin-top: 1rem;
		max-width: 100%;
	}

	.section-container {
		grid-template-columns: repeat(1, minmax(0, 1fr));
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.section-heading-row {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.section-title {
		font-size: 2.25rem;
		line-height: 2.5rem;
	}

	.mission-vision-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.card-title {
		font-size: 2.25rem;
		line-height: 2.5rem;
	}

	.focus-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.programs-layout {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.section-image {
		min-height: 360px;
	}

	.publication-cards {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}
}

@media (max-width: 480px) {
	.gjs-t-h1 {
		font-size: 2.2rem;
		line-height: 2.7rem;
	}

	.gjs-t-h2 {
		font-size: 1.45rem;
		line-height: 1.95rem;
	}

	.utility-container {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.main-header {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.brand-title {
		font-size: 1.5rem;
		line-height: 2rem;
	}

	.hero-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.hero-description {
		font-size: 1rem;
		line-height: 1.75rem;
	}

	.hero-actions {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}

	.hero-metrics {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.hero-side-panel {
		padding: 1.25rem;
	}

	.panel-title {
		font-size: 1.875rem;
		line-height: 2.25rem;
	}

	.about-section {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.feature-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.about-image {
		height: 220px;
	}

	.stats-card {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.research-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.research-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.programs-section {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.news-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.partners-section {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.partners-wrapper {
		padding: 1.25rem;
	}

	.partners-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.cta-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3.5rem;
		padding-bottom: 3.5rem;
	}

	.cta-title {
		font-size: 1.875rem;
		line-height: 2.25rem;
	}

	.cta-list {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.contact-form-card {
		padding: 1.25rem;
	}

	.form-row {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.footer-container {
		grid-template-columns: repeat(1, minmax(0, 1fr));
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.footer-bottom-container {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.footer-bottom-links {
		flex-direction: column;
		align-items: flex-start;
	}

	.header-container {
		flex-direction: column;
		align-items: flex-start;
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 1rem;
		padding-bottom: 1rem;
	}

	.main-navigation {
		width: 100%;
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.hero-heading {
		font-size: 2rem;
	}

	.hero-image {
		height: 320px;
	}

	.hero-highlight-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.trust-bar-container {
		flex-direction: column;
		align-items: flex-start;
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.about-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.mission-vision-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.programs-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.publications-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.publications-image {
		min-height: 220px;
	}

	.publication-cards-column {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.events-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.membership-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.membership-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.contact-container {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.contact-form-panel {
		padding: 1.25rem;
	}

	.form-heading {
		font-size: 1.5rem;
		line-height: 2rem;
	}

	.form-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.form-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.footer-top {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.section-title {
		font-size: 1.875rem;
		line-height: 2.25rem;
	}

	.card-title {
		font-size: 1.875rem;
		line-height: 2.25rem;
	}

	.focus-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.programs-grid {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.section-image {
		min-height: 280px;
	}

	.research-list {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}

	.membership-types {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}
}
/* DHANVANTARI THEME */

.dhanvantari-theme {
    background: linear-gradient(
        rgba(12, 40, 25, 0.85),
        rgba(12, 40, 25, 0.9)
    ),
    url('../images/dhanvantari-bg.jpg');
    background-size: cover;
    background-position: center;
}

/* Golden Ayurvedic Glow */
.hero-title {
    color: #e4c885;
    text-shadow: 0 0 20px rgba(228, 200, 133, 0.4);
}

/* Sacred aura animation */
.hero-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle, rgba(255,215,0,0.08), transparent);
    animation: aura 6s infinite alternate;
}

@keyframes aura {
    from { opacity: 0.3; }
    to { opacity: 0.7; }
}