:root {
	--terms-primary: #1e3a5f;
	--terms-secondary: #2c5282;
	--terms-accent: #c9a227;
	--terms-light: #f7fafc;
	--terms-slate: #4a5568;
	--terms-dark: #1a202c;
	--terms-border: #e2e8f0;
	--terms-highlight: #ebf4ff;
	--terms-success: #48bb78;
	--terms-warning: #ed8936;
}

.terms-hero-subtitle {
	font-weight: 300;
	letter-spacing: 0.5px;
}

.terms-intro-section {
	background: linear-gradient(135deg, var(--terms-light) 0%, #edf2f7 100%);
	padding: 80px 0;
}

.terms-intro-card {
	background: white;
	border-radius: 16px;
	box-shadow: 0 10px 40px rgba(30, 58, 95, 0.1);
	padding: 50px;
	max-width: 1000px;
	margin: 0 auto;
	border-top: 5px solid var(--terms-primary);
}

.terms-intro-icon {
	width: 80px;
	height: 80px;
	background: linear-gradient(135deg, var(--terms-primary) 0%, var(--terms-secondary) 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 30px;
	box-shadow: 0 8px 25px rgba(30, 58, 95, 0.3);
}

.terms-intro-icon i {
	font-size: 36px;
	color: white;
}

.terms-intro-title {
	font-size: 32px;
	color: var(--terms-primary);
	font-weight: 700;
	text-align: center;
	margin-bottom: 25px;
}

.terms-intro-text {
	color: var(--terms-slate);
	font-size: 17px;
	line-height: 1.9;
	text-align: center;
}

.terms-effective-badge {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--terms-highlight);
	border: 1px solid var(--terms-secondary);
	border-radius: 30px;
	padding: 12px 25px;
	margin-top: 30px;
	color: var(--terms-primary);
	font-weight: 600;
}

.terms-definitions-section {
	background: white;
	padding: 80px 0;
}

.section-header {
	text-align: center;
	margin-bottom: 50px;
}

.section-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	background: linear-gradient(135deg, var(--terms-primary) 0%, var(--terms-secondary) 100%);
	color: white;
	font-size: 22px;
	font-weight: 700;
	border-radius: 50%;
	margin-bottom: 20px;
	box-shadow: 0 4px 15px rgba(30, 58, 95, 0.3);
}

.section-title {
	font-size: 36px;
	color: var(--terms-primary);
	font-weight: 700;
	margin-bottom: 15px;
}

.section-subtitle {
	color: var(--terms-slate);
	font-size: 18px;
	max-width: 700px;
	margin: 0 auto;
}

.definitions-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 30px;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

.definition-card {
	background: var(--terms-light);
	border-radius: 12px;
	padding: 35px;
	border-left: 4px solid var(--terms-accent);
	transition: all 0.3s ease;
}

.definition-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 15px 40px rgba(30, 58, 95, 0.15);
}

.definition-term {
	font-size: 20px;
	color: var(--terms-primary);
	font-weight: 700;
	margin-bottom: 15px;
	display: flex;
	align-items: center;
	gap: 12px;
}

.definition-term i {
	color: var(--terms-accent);
}

.definition-desc {
	color: var(--terms-slate);
	font-size: 15px;
	line-height: 1.8;
}

.terms-eligibility-section {
	background: linear-gradient(135deg, var(--terms-primary) 0%, var(--terms-secondary) 100%);
	padding: 80px 0;
	position: relative;
	overflow: hidden;
}

.terms-eligibility-section::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
	opacity: 0.5;
}

.eligibility-content {
	position: relative;
	z-index: 1;
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 20px;
}

.eligibility-header {
	text-align: center;
	margin-bottom: 50px;
}

.eligibility-header .section-number {
	background: white;
	color: var(--terms-primary);
}

.eligibility-header .section-title {
	color: white;
}

.eligibility-header .section-subtitle {
	color: rgba(255, 255, 255, 0.85);
}

.eligibility-box {
	background: white;
	border-radius: 16px;
	padding: 50px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}

.eligibility-intro {
	text-align: center;
	margin-bottom: 40px;
	padding-bottom: 40px;
	border-bottom: 2px dashed var(--terms-border);
}

.eligibility-intro p {
	color: var(--terms-slate);
	font-size: 17px;
	line-height: 1.9;
	max-width: 800px;
	margin: 0 auto;
}

.eligibility-requirements {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 30px;
}

.requirement-item {
	display: flex;
	align-items: flex-start;
	gap: 20px;
	padding: 25px;
	background: var(--terms-light);
	border-radius: 12px;
	transition: all 0.3s ease;
}

.requirement-item:hover {
	background: var(--terms-highlight);
}

.requirement-icon {
	width: 50px;
	height: 50px;
	background: linear-gradient(135deg, var(--terms-success) 0%, #38a169 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.requirement-icon i {
	color: white;
	font-size: 20px;
}

.requirement-content h4 {
	color: var(--terms-primary);
	font-size: 18px;
	font-weight: 600;
	margin-bottom: 8px;
}

.requirement-content p {
	color: var(--terms-slate);
	font-size: 14px;
	line-height: 1.7;
}

.terms-obligations-section {
	background: var(--terms-light);
	padding: 80px 0;
}

.obligations-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

.obligations-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	gap: 40px;
	margin-top: 50px;
}

.obligation-category {
	background: white;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 10px 40px rgba(30, 58, 95, 0.1);
}

.obligation-header {
	background: linear-gradient(135deg, var(--terms-primary) 0%, var(--terms-secondary) 100%);
	padding: 25px 30px;
	display: flex;
	align-items: center;
	gap: 15px;
}

.obligation-header.donor-header {
	background: linear-gradient(135deg, var(--terms-accent) 0%, #b8941f 100%);
}

.obligation-header.beneficiary-header {
	background: linear-gradient(135deg, #48bb78 0%, #38a169 100%);
}

.obligation-header-icon {
	width: 50px;
	height: 50px;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.obligation-header-icon i {
	color: white;
	font-size: 22px;
}

.obligation-header h3 {
	color: white;
	font-size: 22px;
	font-weight: 700;
}

.obligation-body {
	padding: 35px;
}

.obligation-item {
	display: flex;
	align-items: flex-start;
	gap: 15px;
	padding: 18px 0;
	border-bottom: 1px solid var(--terms-border);
}

.obligation-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.obligation-item:first-child {
	padding-top: 0;
}

.obligation-check {
	width: 24px;
	height: 24px;
	background: var(--terms-highlight);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-top: 2px;
}

.obligation-check i {
	color: var(--terms-primary);
	font-size: 12px;
}

.obligation-item p {
	color: var(--terms-slate);
	font-size: 15px;
	line-height: 1.7;
}

.terms-donations-section {
	background: white;
	padding: 80px 0;
}

.donations-container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 20px;
}

.donations-visual {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin: 50px 0;
	position: relative;
}

.donations-visual::before,
.donations-visual::after {
	content: '';
	position: absolute;
	top: 50%;
	width: 60px;
	height: 3px;
	background: var(--terms-accent);
}

.donations-visual::before {
	left: calc(33.33% - 30px);
}

.donations-visual::after {
	left: calc(66.66% - 30px);
}

.donation-step {
	text-align: center;
	padding: 30px 20px;
	background: var(--terms-light);
	border-radius: 16px;
	position: relative;
}

.donation-step-number {
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
	width: 30px;
	height: 30px;
	background: var(--terms-accent);
	color: white;
	font-weight: 700;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
}

.donation-step-icon {
	width: 70px;
	height: 70px;
	background: linear-gradient(135deg, var(--terms-primary) 0%, var(--terms-secondary) 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 15px auto 20px;
	box-shadow: 0 8px 25px rgba(30, 58, 95, 0.25);
}

.donation-step-icon i {
	color: white;
	font-size: 28px;
}

.donation-step h4 {
	color: var(--terms-primary);
	font-size: 18px;
	font-weight: 700;
	margin-bottom: 10px;
}

.donation-step p {
	color: var(--terms-slate);
	font-size: 14px;
	line-height: 1.7;
}

.donations-details {
	background: var(--terms-highlight);
	border-radius: 16px;
	padding: 40px;
	border: 1px solid rgba(44, 82, 130, 0.2);
}

.donations-details-title {
	display: flex;
	align-items: center;
	gap: 15px;
	margin-bottom: 25px;
}

.donations-details-title i {
	color: var(--terms-primary);
	font-size: 24px;
}

.donations-details-title h4 {
	color: var(--terms-primary);
	font-size: 22px;
	font-weight: 700;
}

.donations-detail-item {
	display: flex;
	align-items: flex-start;
	gap: 15px;
	padding: 15px 0;
	border-bottom: 1px dashed rgba(44, 82, 130, 0.2);
}

.donations-detail-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.donations-detail-item i {
	color: var(--terms-warning);
	font-size: 18px;
	margin-top: 3px;
}

.donations-detail-item p {
	color: var(--terms-slate);
	font-size: 15px;
	line-height: 1.8;
}

.terms-appreciation-section {
	background: linear-gradient(135deg, #f6e05e 0%, var(--terms-accent) 100%);
	padding: 80px 0;
	position: relative;
}

.appreciation-container {
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 20px;
}

.appreciation-header {
	text-align: center;
	margin-bottom: 50px;
}

.appreciation-header .section-number {
	background: white;
	color: var(--terms-accent);
}

.appreciation-header .section-title {
	color: var(--terms-dark);
}

.appreciation-header .section-subtitle {
	color: rgba(26, 32, 44, 0.8);
}

.appreciation-card {
	background: white;
	border-radius: 16px;
	padding: 50px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.appreciation-intro {
	text-align: center;
	margin-bottom: 40px;
}

.appreciation-intro p {
	color: var(--terms-slate);
	font-size: 17px;
	line-height: 1.9;
}

.appreciation-methods {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 25px;
	margin-bottom: 40px;
}

.appreciation-method {
	text-align: center;
	padding: 30px 20px;
	background: var(--terms-light);
	border-radius: 12px;
	transition: all 0.3s ease;
}

.appreciation-method:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 30px rgba(30, 58, 95, 0.15);
}

.appreciation-method-icon {
	width: 60px;
	height: 60px;
	background: linear-gradient(135deg, var(--terms-accent) 0%, #b8941f 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 15px;
}

.appreciation-method-icon i {
	color: white;
	font-size: 24px;
}

.appreciation-method h4 {
	color: var(--terms-primary);
	font-size: 16px;
	font-weight: 600;
}

.appreciation-warning {
	background: linear-gradient(135deg, #fff5f5 0%, #fed7d7 100%);
	border-radius: 12px;
	padding: 25px 30px;
	display: flex;
	align-items: flex-start;
	gap: 20px;
	border-left: 4px solid #e53e3e;
}

.appreciation-warning-icon {
	width: 45px;
	height: 45px;
	background: #e53e3e;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.appreciation-warning-icon i {
	color: white;
	font-size: 20px;
}

.appreciation-warning-content h4 {
	color: #c53030;
	font-size: 18px;
	font-weight: 700;
	margin-bottom: 8px;
}

.appreciation-warning-content p {
	color: #742a2a;
	font-size: 15px;
	line-height: 1.7;
}

.terms-suspension-section {
	background: var(--terms-dark);
	padding: 80px 0;
	position: relative;
}

.suspension-container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 20px;
}

.suspension-header {
	text-align: center;
	margin-bottom: 50px;
}

.suspension-header .section-number {
	background: #e53e3e;
	color: white;
}

.suspension-header .section-title {
	color: white;
}

.suspension-header .section-subtitle {
	color: rgba(255, 255, 255, 0.7);
}

.suspension-content {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 30px;
}

.suspension-card {
	background: rgba(255, 255, 255, 0.05);
	border-radius: 16px;
	padding: 35px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	transition: all 0.3s ease;
}

.suspension-card:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.2);
}

.suspension-card-icon {
	width: 60px;
	height: 60px;
	background: linear-gradient(135deg, #e53e3e 0%, #c53030 100%);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
}

.suspension-card-icon i {
	color: white;
	font-size: 26px;
}

.suspension-card h4 {
	color: white;
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 15px;
}

.suspension-card p {
	color: rgba(255, 255, 255, 0.7);
	font-size: 15px;
	line-height: 1.8;
}

.suspension-violations {
	margin-top: 50px;
	background: rgba(229, 62, 62, 0.1);
	border-radius: 16px;
	padding: 40px;
	border: 1px solid rgba(229, 62, 62, 0.3);
}

.suspension-violations h4 {
	color: #fc8181;
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 25px;
	display: flex;
	align-items: center;
	gap: 12px;
}

.violations-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 15px;
}

.violation-item {
	display: flex;
	align-items: center;
	gap: 12px;
	color: rgba(255, 255, 255, 0.8);
	font-size: 14px;
}

.violation-item i {
	color: #fc8181;
	font-size: 14px;
}

.terms-liability-section {
	background: var(--terms-light);
	padding: 80px 0;
}

.liability-container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 20px;
}

.liability-card {
	background: white;
	border-radius: 16px;
	box-shadow: 0 10px 40px rgba(30, 58, 95, 0.1);
	overflow: hidden;
}

.liability-header-bar {
	background: linear-gradient(135deg, var(--terms-primary) 0%, var(--terms-secondary) 100%);
	padding: 30px 40px;
	display: flex;
	align-items: center;
	gap: 20px;
}

.liability-header-icon {
	width: 60px;
	height: 60px;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.liability-header-icon i {
	color: white;
	font-size: 28px;
}

.liability-header-text h3 {
	color: white;
	font-size: 24px;
	font-weight: 700;
}

.liability-header-text p {
	color: rgba(255, 255, 255, 0.8);
	font-size: 14px;
	margin-top: 5px;
}

.liability-body {
	padding: 50px;
}

.liability-intro {
	text-align: center;
	margin-bottom: 40px;
	padding-bottom: 40px;
	border-bottom: 2px dashed var(--terms-border);
}

.liability-intro p {
	color: var(--terms-slate);
	font-size: 17px;
	line-height: 1.9;
	max-width: 800px;
	margin: 0 auto;
}

.liability-items {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 25px;
}

.liability-item {
	background: var(--terms-light);
	border-radius: 12px;
	padding: 30px;
	border-left: 4px solid var(--terms-secondary);
}

.liability-item h4 {
	color: var(--terms-primary);
	font-size: 18px;
	font-weight: 600;
	margin-bottom: 12px;
	display: flex;
	align-items: center;
	gap: 10px;
}

.liability-item h4 i {
	color: var(--terms-secondary);
}

.liability-item p {
	color: var(--terms-slate);
	font-size: 14px;
	line-height: 1.8;
}

.terms-amendments-section {
	background: white;
	padding: 80px 0;
}

.amendments-container {
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 20px;
}

.amendments-card {
	background: linear-gradient(135deg, var(--terms-highlight) 0%, #e6f2ff 100%);
	border-radius: 16px;
	padding: 50px;
	border: 2px solid rgba(44, 82, 130, 0.2);
	text-align: center;
}

.amendments-icon {
	width: 90px;
	height: 90px;
	background: linear-gradient(135deg, var(--terms-primary) 0%, var(--terms-secondary) 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 30px;
	box-shadow: 0 10px 30px rgba(30, 58, 95, 0.3);
}

.amendments-icon i {
	color: white;
	font-size: 40px;
}

.amendments-title {
	color: var(--terms-primary);
	font-size: 28px;
	font-weight: 700;
	margin-bottom: 20px;
}

.amendments-text {
	color: var(--terms-slate);
	font-size: 17px;
	line-height: 1.9;
	margin-bottom: 30px;
}

.amendments-points {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px;
	margin-top: 30px;
}

.amendment-point {
	display: flex;
	align-items: center;
	gap: 10px;
	background: white;
	padding: 15px 25px;
	border-radius: 30px;
	box-shadow: 0 4px 15px rgba(30, 58, 95, 0.1);
}

.amendment-point i {
	color: var(--terms-success);
	font-size: 18px;
}

.amendment-point span {
	color: var(--terms-primary);
	font-weight: 600;
	font-size: 14px;
}

.terms-contact-section {
	background: linear-gradient(135deg, var(--terms-primary) 0%, var(--terms-secondary) 100%);
	padding: 80px 0;
}

.contact-container {
	max-width: 900px;
	margin: 0 auto;
	padding: 0 20px;
	text-align: center;
}

.contact-icon {
	width: 80px;
	height: 80px;
	background: rgba(255, 255, 255, 0.15);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 30px;
}

.contact-icon i {
	color: white;
	font-size: 36px;
}

.contact-title {
	color: white;
	font-size: 32px;
	font-weight: 700;
	margin-bottom: 20px;
}

.contact-text {
	color: rgba(255, 255, 255, 0.85);
	font-size: 17px;
	line-height: 1.9;
	margin-bottom: 40px;
}

.contact-info-box {
	background: rgba(255, 255, 255, 0.1);
	border-radius: 16px;
	padding: 40px;
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.contact-info-item {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 15px;
	color: white;
	font-size: 18px;
	padding: 15px 0;
}

.contact-info-item i {
	color: var(--terms-accent);
	font-size: 22px;
}

.terms-acceptance-section {
	background: var(--terms-dark);
	padding: 50px 0;
}

.acceptance-container {
	max-width: 900px;
	margin: 0 auto;
	padding: 0 20px;
	text-align: center;
}

.acceptance-text {
	color: rgba(255, 255, 255, 0.8);
	font-size: 16px;
	line-height: 1.8;
}

.acceptance-text strong {
	color: var(--terms-accent);
}

@media (max-width: 768px) {
	.terms-intro-card {
		padding: 30px 20px;
	}

	.section-title {
		font-size: 28px;
	}

	.donations-visual {
		grid-template-columns: 1fr;
	}

	.donations-visual::before,
	.donations-visual::after {
		display: none;
	}

	.eligibility-box,
	.appreciation-card,
	.liability-body {
		padding: 30px 20px;
	}

	.obligations-grid {
		grid-template-columns: 1fr;
	}

	.obligation-body {
		padding: 25px 20px;
	}

	.suspension-violations {
		padding: 25px 20px;
	}

	.amendments-card {
		padding: 30px 20px;
	}

	.contact-info-box {
		padding: 25px 20px;
	}
}