/* End custom CSS */

.elementor-widget-container .eael-protected-content-message {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-widget-container .protected-content-error-msg {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-21614 .elementor-element.elementor-element-6a843db2 {
	--display: flex;
}

.elementor-widget-text-editor .eael-protected-content-message {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-widget-text-editor .protected-content-error-msg {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-widget-text-editor {
	font-family: var(--e-global-typography-text-font-family), Sans-serif;
	font-weight: var(--e-global-typography-text-font-weight);
	color: var(--e-global-color-text);
}

.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap {
	background-color: var(--e-global-color-primary);
}

.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap {
	color: var(--e-global-color-primary);
	border-color: var(--e-global-color-primary);
}

.elementor-21614 .elementor-element.elementor-element-6cd8dc52 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-widget-html .eael-protected-content-message {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-widget-html .protected-content-error-msg {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-21614 .elementor-element.elementor-element-da1447f {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-a9c14a0 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-eefe1ed {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-2cc69a2 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-fa51d79 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-9f28533 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-widget-heading .eael-protected-content-message {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-widget-heading .protected-content-error-msg {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-widget-heading .elementor-heading-title {
	font-family: var(--e-global-typography-primary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-primary-font-weight);
	color: var(--e-global-color-primary);
}

.elementor-21614 .elementor-element.elementor-element-d314bc7 > .elementor-widget-container {
	margin: 10px 0px 0px 0px;
}

.elementor-21614 .elementor-element.elementor-element-d314bc7 .elementor-heading-title {
	font-family: "Poppins", Sans-serif;
	font-weight: 600;
	color: var(--e-global-color-474ab4ca);
}

.elementor-widget-nested-accordion .eael-protected-content-message {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-widget-nested-accordion .protected-content-error-msg {
	font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
	font-weight: var(--e-global-typography-secondary-font-weight);
}

.elementor-21614 .elementor-element.elementor-element-383b5c7 {
	--display: flex;
}

.elementor-21614 .elementor-element.elementor-element-730db3e {
	--display: flex;
	--flex-direction: column;
	--container-widget-width: 100%;
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
}

.elementor-21614 .elementor-element.elementor-element-5e2d6c2 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-3798a83 {
	--display: flex;
}

.elementor-21614 .elementor-element.elementor-element-238b509 {
	--display: flex;
	--flex-direction: column;
	--container-widget-width: 100%;
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
}

.elementor-21614 .elementor-element.elementor-element-dd55f19 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-a6ae54b {
	--display: flex;
}

.elementor-21614 .elementor-element.elementor-element-64f7663 {
	--display: flex;
	--flex-direction: column;
	--container-widget-width: 100%;
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
}

.elementor-21614 .elementor-element.elementor-element-028fa58 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-6b4bec1 {
	--display: flex;
}

.elementor-21614 .elementor-element.elementor-element-2ce6728 {
	--display: flex;
	--flex-direction: column;
	--container-widget-width: 100%;
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
}

.elementor-21614 .elementor-element.elementor-element-967f66e {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-2604c03 {
	--display: flex;
}

.elementor-21614 .elementor-element.elementor-element-9a1c785 {
	--display: flex;
	--flex-direction: column;
	--container-widget-width: 100%;
	--container-widget-height: initial;
	--container-widget-flex-grow: 0;
	--container-widget-align-self: initial;
	--flex-wrap-mobile: wrap;
}

.elementor-21614 .elementor-element.elementor-element-ad10f22 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

.elementor-21614 .elementor-element.elementor-element-bbbad7a {
	--n-accordion-title-font-size: 1, 75rem;
	--n-accordion-item-title-space-between: 0px;
	--n-accordion-item-title-distance-from-content: 0px;
	--n-accordion-icon-size: 15px;
}

.elementor-21614 .elementor-element.elementor-element-fdfc922 {
	font-family: "Poppins", Sans-serif;
	font-weight: 400;
}

@media (max-width:1024px) {
	.elementor-21614 .elementor-element.elementor-element-6a843db2 {
		--padding-top: 0rem;
		--padding-bottom: 0rem;
		--padding-left: 0rem;
		--padding-right: 5rem;
	}
}

@media (max-width:767px) {
	.elementor-21614 .elementor-element.elementor-element-6a843db2 {
		--padding-top: 0rem;
		--padding-bottom: 0rem;
		--padding-left: 0rem;
		--padding-right: 0rem;
	}
	
	.elementor-21614 .elementor-element.elementor-element-6cd8dc52 > .elementor-widget-container {
		margin: 0px 0px 0px 0px;
		padding: 0px 0px 0px 0px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-6cd8dc52 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-da1447f > .elementor-widget-container {
		margin: 0px 0px 0px 0px;
		padding: 0px 0px 0px 0px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-da1447f {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-a9c14a0 > .elementor-widget-container {
		margin: 0px 0px 0px 0px;
		padding: 0px 0px 0px 0px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-a9c14a0 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-eefe1ed > .elementor-widget-container {
		margin: 0px 0px 0px 0px;
		padding: 0px 0px 0px 0px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-eefe1ed {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-2cc69a2 > .elementor-widget-container {
		margin: 0px 0px 0px 0px;
		padding: 0px 0px 0px 0px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-2cc69a2 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-fa51d79 > .elementor-widget-container {
		margin: 0px 0px 0px 0px;
		padding: 0px 0px 0px 0px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-fa51d79 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-9f28533 > .elementor-widget-container {
		margin: 0px 0px 0px 0px;
		padding: 0px 0px 0px 0px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-9f28533 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-5e2d6c2 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-dd55f19 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-028fa58 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-967f66e {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-ad10f22 {
		font-size: 15px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-fdfc922 > .elementor-widget-container {
		margin: 0px 0px 0px 0px;
		padding: 0px 0px 0px 0px;
	}
	
	.elementor-21614 .elementor-element.elementor-element-fdfc922 {
		font-size: 15px;
	}
}

/* Start custom CSS for text-editor, class: .elementor-element-6cd8dc52 */
.inheritance-container {
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
	line-height: 1.6;
}

/* DECISION FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

.flowchart-btn {
	flex: 1;
	padding: 15px 25px;
	font-size: 16px;
	font-weight: 600;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: all .3s;
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 8px;
	padding: 25px;
	margin-top: 20px;
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	font-size: 14px;
}

.flowchart-reset:hover {
	background: #5a6268;
}

.progress-bar {
	width: 100%;
	height: 8px;
	background: #e0e0e0;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: #007bff;
	transition: width .3s;
}

/* COMPARISON TABLE STYLES */
.comparison-table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px 0;
	font-size: 14px;
	overflow-x: auto;
	display: block;
}

.comparison-table table {
	width: 100%;
	min-width: 700px;
}

.comparison-table th {
	background: #007bff;
	color: white;
	padding: 15px;
	text-align: left;
	font-weight: 600;
}

.comparison-table td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.comparison-table tr:nth-child(even) {
	background: #f8f9fa;
}

.comparison-table tr:hover {
	background: #e9ecef;
}

.complexity-low {
	color: #28a745;
	font-weight: 600;
}

.complexity-medium {
	color: #ffc107;
	font-weight: 600;
}

.complexity-high {
	color: #dc3545;
	font-weight: 600;
}

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
}

.calc-input-group input {
	width: 100%;
	padding: 12px;
	border: 1px solid #ced4da;
	border-radius: 5px;
	font-size: 16px;
	box-sizing: border-box;
}

.calc-button {
	width: 100%;
	padding: 15px;
	background: #007bff;
	color: white;
	border: none;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 20px;
}

.calc-button:hover {
	background: #0056b3;
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 8px;
}

.calc-results.show {
	display: block;
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 18px;
	color: #28a745;
}

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.checklist-section {
	margin-bottom: 30px;
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 18px;
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 10px;
	border-radius: 5px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
}

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 30px;
	position: relative;
}

.timeline-marker {
	width: 60px;
	height: 60px;
	background: #007bff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 14px;
	flex-shrink: 0;
	z-index: 2;
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 18px;
}

.timeline-content p {
	margin: 0;
	color: #666;
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 30px;
	top: 60px;
	width: 2px;
	height: calc(100% + 30px);
	background: #e0e0e0;
	z-index: 1;
}

.timeline-item:last-child:before {
	display: none;
}

/* MISTAKES SECTION */
.mistake-item {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 20px;
	margin-bottom: 20px;
	border-radius: 5px;
}

.mistake-item h4 {
	color: #856404;
	margin: 0 0 10px 0;
}

.mistake-example {
	color: #856404;
	font-style: italic;
	margin-top: 10px;
	padding-left: 15px;
	border-left: 2px solid #ffc107;
}

/* RED FLAGS SECTION */
.red-flags-container {
	background: #f8d7da;
	border: 2px solid #dc3545;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 10px;
	background: white;
	border-radius: 5px;
}

.red-flag-icon {
	color: #dc3545;
	font-size: 24px;
	margin-right: 15px;
	flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
	}
	
	.comparison-table {
		font-size: 12px;
	}
	
	.timeline-item {
		flex-direction: column;
	}
	
	.timeline-marker {
		margin-bottom: 15px;
	}
	
	.timeline-content {
		margin-left: 0;
	}
	
	.timeline-item:before {
		display: none;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for html, class: .elementor-element-317c319 */

/* FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 12px;
	padding: 30px;
	margin: 0;
}

@media (max-width: 768px) {
	.flowchart-container {
		padding: 20px 15px;
		border-radius: 8px;
	}
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-question h4 {
	font-size: 1.375rem;
	margin-bottom: 10px;
	color: #2c3e50;
}

.flowchart-question p {
	color: #6c757d;
	margin-bottom: 20px;
}

@media (max-width: 768px) {
	.flowchart-question h4 {
		font-size: 1.125rem;
	}
	
	.flowchart-question p {
		font-size: .9375rem;
	}
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
		gap: 12px;
	}
}

.flowchart-btn {
	flex: 1;
	padding: 18px 25px;
	font-size: 1.125rem;
	font-weight: 600;
	border: none;
	border-radius: 8px;
	cursor: pointer;
	transition: all .3s;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .1);
}

@media (max-width: 768px) {
	.flowchart-btn {
		padding: 16px 20px;
		font-size: 1rem;
	}
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(40, 167, 69, .3);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(220, 53, 69, .3);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 12px;
	padding: 30px;
	margin-top: 20px;
}

@media (max-width: 768px) {
	.flowchart-result {
		padding: 20px 15px;
		border-radius: 8px;
	}
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-result h4 {
	color: #155724;
	margin-bottom: 15px;
}

.flowchart-result p {
	color: #155724;
	margin-bottom: 15px;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	font-size: .9375rem;
	transition: all .3s;
}

.flowchart-reset:hover {
	background: #5a6268;
	transform: translateY(-1px);
}

.progress-bar {
	width: 100%;
	height: 10px;
	background: #e0e0e0;
	border-radius: 5px;
	margin-bottom: 25px;
	overflow: hidden;
}

@media (max-width: 768px) {
	.progress-bar {
		height: 8px;
		margin-bottom: 20px;
	}
}

.progress-fill {
	height: 100%;
	background: linear-gradient(90deg, #007bff 0%, #0056b3 100%);
	transition: width .4s ease;
}

.tool-cta {
	background: linear-gradient(135deg, #0056b3 0%, #007bff 100%);
	border: none;
	border-radius: 8px;
	padding: 18px 32px;
	margin-top: 25px;
	color: white;
	font-size: 1.125rem;
	font-weight: 700;
	text-align: center;
	cursor: pointer;
	transition: all .3s ease;
	box-shadow: 0 4px 15px rgba(0, 123, 255, .3);
	text-decoration: none;
	display: inline-block;
	width: 100%;
}

.tool-cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 123, 255, .4);
	background: linear-gradient(135deg, #004494 0%, #0056b3 100%);
	color: white;
	text-decoration: none;
}

.cta-text {
	color: #333;
	font-size: .9375rem;
	margin-top: 15px;
	margin-bottom: 0;
	text-align: center;
}

@media (max-width: 768px) {
	.tool-cta {
		padding: 16px 24px;
		font-size: 1rem;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for text-editor, class: .elementor-element-da1447f */
.inheritance-container {
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
	line-height: 1.6;
}

/* DECISION FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

.flowchart-btn {
	flex: 1;
	padding: 15px 25px;
	font-size: 16px;
	font-weight: 600;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: all .3s;
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 8px;
	padding: 25px;
	margin-top: 20px;
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	font-size: 14px;
}

.flowchart-reset:hover {
	background: #5a6268;
}

.progress-bar {
	width: 100%;
	height: 8px;
	background: #e0e0e0;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: #007bff;
	transition: width .3s;
}

/* COMPARISON TABLE STYLES */
.comparison-table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px 0;
	font-size: 14px;
	overflow-x: auto;
	display: block;
}

.comparison-table table {
	width: 100%;
	min-width: 700px;
}

.comparison-table th {
	background: #007bff;
	color: white;
	padding: 15px;
	text-align: left;
	font-weight: 600;
}

.comparison-table td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.comparison-table tr:nth-child(even) {
	background: #f8f9fa;
}

.comparison-table tr:hover {
	background: #e9ecef;
}

.complexity-low {
	color: #28a745;
	font-weight: 600;
}

.complexity-medium {
	color: #ffc107;
	font-weight: 600;
}

.complexity-high {
	color: #dc3545;
	font-weight: 600;
}

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
}

.calc-input-group input {
	width: 100%;
	padding: 12px;
	border: 1px solid #ced4da;
	border-radius: 5px;
	font-size: 16px;
	box-sizing: border-box;
}

.calc-button {
	width: 100%;
	padding: 15px;
	background: #007bff;
	color: white;
	border: none;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 20px;
}

.calc-button:hover {
	background: #0056b3;
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 8px;
}

.calc-results.show {
	display: block;
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 18px;
	color: #28a745;
}

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.checklist-section {
	margin-bottom: 30px;
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 18px;
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 10px;
	border-radius: 5px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
}

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 30px;
	position: relative;
}

.timeline-marker {
	width: 60px;
	height: 60px;
	background: #007bff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 14px;
	flex-shrink: 0;
	z-index: 2;
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 18px;
}

.timeline-content p {
	margin: 0;
	color: #666;
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 30px;
	top: 60px;
	width: 2px;
	height: calc(100% + 30px);
	background: #e0e0e0;
	z-index: 1;
}

.timeline-item:last-child:before {
	display: none;
}

/* MISTAKES SECTION */
.mistake-item {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 20px;
	margin-bottom: 20px;
	border-radius: 5px;
}

.mistake-item h4 {
	color: #856404;
	margin: 0 0 10px 0;
}

.mistake-example {
	color: #856404;
	font-style: italic;
	margin-top: 10px;
	padding-left: 15px;
	border-left: 2px solid #ffc107;
}

/* RED FLAGS SECTION */
.red-flags-container {
	background: #f8d7da;
	border: 2px solid #dc3545;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 10px;
	background: white;
	border-radius: 5px;
}

.red-flag-icon {
	color: #dc3545;
	font-size: 24px;
	margin-right: 15px;
	flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
	}
	
	.comparison-table {
		font-size: 12px;
	}
	
	.timeline-item {
		flex-direction: column;
	}
	
	.timeline-marker {
		margin-bottom: 15px;
	}
	
	.timeline-content {
		margin-left: 0;
	}
	
	.timeline-item:before {
		display: none;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for html, class: .elementor-element-675afd7 */

/* COMPARISON TABLE STYLES */

/* --- DESKTOP VERSION (Mayor a 769px) --- */
@media (min-width: 769px) {
	.comparison-cards {
		display: none !important;
	}
	
	.comparison-table {
		display: block !important;
		width: 100%;
		border-collapse: collapse;
		font-size: .9375rem;
		overflow-x: auto;
	}
	
	.comparison-table-wrapper {
		margin: 30px 0;
	}
	
	.comparison-table table {
		width: 100%;
		min-width: 900px;
	}
	
	.comparison-table th {
		background: #007bff;
		color: white;
		padding: 18px 15px;
		text-align: left;
		font-weight: 600;
		font-size: 1rem;
	}
	
	.comparison-table td {
		padding: 18px 15px;
		border-bottom: 1px solid #e0e0e0;
		vertical-align: top;
	}
	
	.comparison-table tr:nth-child(even) {
		background: #f8f9fa;
	}
	
	.comparison-table tr:hover {
		background: #e9ecef;
		transition: background .3s;
	}
	
	.complexity-low {
		color: #28a745;
		font-weight: 700;
	}
	
	.complexity-medium {
		color: #ffc107;
		font-weight: 700;
	}
	
	.complexity-high {
		color: #dc3545;
		font-weight: 700;
	}
}

/* --- MOBILE VERSION (Menor a 768px) --- */
@media (max-width: 768px) {
	.comparison-table {
		display: none !important;
	}
	
	.comparison-cards {
		display: block !important;
	}
	
	.comparison-card {
		background: white;
		border: 2px solid #e0e0e0;
		border-radius: 12px;
		padding: 20px;
		margin-bottom: 20px;
		box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
		transition: all .3s;
	}
	
	.comparison-card:hover {
		box-shadow: 0 4px 16px rgba(0, 0, 0, .12);
		transform: translateY(-2px);
	}
	
	.comparison-card-title {
		font-size: 1.25rem;
		font-weight: 700;
		color: #007bff;
		margin-bottom: 15px;
		padding-bottom: 10px;
		border-bottom: 2px solid #007bff;
	}
	
	.comparison-card-row {
		margin-bottom: 12px;
	}
	
	.comparison-card-label {
		font-weight: 600;
		color: #495057;
		font-size: .875rem;
		text-transform: uppercase;
		letter-spacing: .5px;
		margin-bottom: 5px;
	}
	
	.comparison-card-value {
		color: #333;
		font-size: .9375rem;
		line-height: 1.5;
	}
}

/* End custom CSS */

/* Start custom CSS for text-editor, class: .elementor-element-a9c14a0 */
.inheritance-container {
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
	line-height: 1.6;
}

/* DECISION FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

.flowchart-btn {
	flex: 1;
	padding: 15px 25px;
	font-size: 16px;
	font-weight: 600;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: all .3s;
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 8px;
	padding: 25px;
	margin-top: 20px;
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	font-size: 14px;
}

.flowchart-reset:hover {
	background: #5a6268;
}

.progress-bar {
	width: 100%;
	height: 8px;
	background: #e0e0e0;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: #007bff;
	transition: width .3s;
}

/* COMPARISON TABLE STYLES */
.comparison-table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px 0;
	font-size: 14px;
	overflow-x: auto;
	display: block;
}

.comparison-table table {
	width: 100%;
	min-width: 700px;
}

.comparison-table th {
	background: #007bff;
	color: white;
	padding: 15px;
	text-align: left;
	font-weight: 600;
}

.comparison-table td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.comparison-table tr:nth-child(even) {
	background: #f8f9fa;
}

.comparison-table tr:hover {
	background: #e9ecef;
}

.complexity-low {
	color: #28a745;
	font-weight: 600;
}

.complexity-medium {
	color: #ffc107;
	font-weight: 600;
}

.complexity-high {
	color: #dc3545;
	font-weight: 600;
}

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
}

.calc-input-group input {
	width: 100%;
	padding: 12px;
	border: 1px solid #ced4da;
	border-radius: 5px;
	font-size: 16px;
	box-sizing: border-box;
}

.calc-button {
	width: 100%;
	padding: 15px;
	background: #007bff;
	color: white;
	border: none;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 20px;
}

.calc-button:hover {
	background: #0056b3;
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 8px;
}

.calc-results.show {
	display: block;
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 18px;
	color: #28a745;
}

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.checklist-section {
	margin-bottom: 30px;
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 18px;
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 10px;
	border-radius: 5px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
}

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 30px;
	position: relative;
}

.timeline-marker {
	width: 60px;
	height: 60px;
	background: #007bff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 14px;
	flex-shrink: 0;
	z-index: 2;
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 18px;
}

.timeline-content p {
	margin: 0;
	color: #666;
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 30px;
	top: 60px;
	width: 2px;
	height: calc(100% + 30px);
	background: #e0e0e0;
	z-index: 1;
}

.timeline-item:last-child:before {
	display: none;
}

/* MISTAKES SECTION */
.mistake-item {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 20px;
	margin-bottom: 20px;
	border-radius: 5px;
}

.mistake-item h4 {
	color: #856404;
	margin: 0 0 10px 0;
}

.mistake-example {
	color: #856404;
	font-style: italic;
	margin-top: 10px;
	padding-left: 15px;
	border-left: 2px solid #ffc107;
}

/* RED FLAGS SECTION */
.red-flags-container {
	background: #f8d7da;
	border: 2px solid #dc3545;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 10px;
	background: white;
	border-radius: 5px;
}

.red-flag-icon {
	color: #dc3545;
	font-size: 24px;
	margin-right: 15px;
	flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
	}
	
	.comparison-table {
		font-size: 12px;
	}
	
	.timeline-item {
		flex-direction: column;
	}
	
	.timeline-marker {
		margin-bottom: 15px;
	}
	
	.timeline-content {
		margin-left: 0;
	}
	
	.timeline-item:before {
		display: none;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for html, class: .elementor-element-d25a0d7 */

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 12px;
	padding: 30px;
	margin: 30px 0;
}

@media (max-width: 768px) {
	.calculator-container {
		padding: 20px 15px;
		border-radius: 8px;
	}
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
	font-size: .9375rem;
}

@media (max-width: 768px) {
	.calc-input-group label {
		font-size: .875rem;
	}
}

.calc-input-group input {
	width: 100%;
	padding: 14px 16px;
	border: 2px solid #ced4da;
	border-radius: 8px;
	font-size: 1rem;
	box-sizing: border-box;
	transition: all .3s;
}

.calc-input-group input:focus {
	outline: none;
	border-color: #007bff;
	box-shadow: 0 0 0 3px rgba(0, 123, 255, .1);
}

@media (max-width: 768px) {
	.calc-input-group input {
		padding: 12px 14px;
		font-size: .9375rem;
	}
}

.calc-button {
	width: 100%;
	padding: 18px;
	background: linear-gradient(135deg, #28a745 0%, #20c997 100%);
	color: white;
	border: none;
	border-radius: 8px;
	font-size: 1.125rem;
	font-weight: 700;
	cursor: pointer;
	margin-top: 20px;
	transition: all .3s;
	box-shadow: 0 4px 15px rgba(40, 167, 69, .3);
}

.calc-button:hover {
	background: linear-gradient(135deg, #218838 0%, #1ea87a 100%);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(40, 167, 69, .4);
}

@media (max-width: 768px) {
	.calc-button {
		padding: 16px;
		font-size: 1rem;
	}
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 12px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .08);
}

@media (max-width: 768px) {
	.calc-results {
		padding: 20px 15px;
		border-radius: 8px;
	}
}

.calc-results.show {
	display: block;
	animation: fadeIn .5s;
}

.calc-results h4 {
	color: #28a745;
	margin-bottom: 20px;
	font-size: 1.375rem;
}

@media (max-width: 768px) {
	.calc-results h4 {
		font-size: 1.125rem;
	}
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
	font-size: 1rem;
}

@media (max-width: 768px) {
	.calc-result-item {
		flex-direction: column;
		gap: 5px;
		padding: 12px 0;
		font-size: .9375rem;
	}
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 1.25rem;
	color: #28a745;
	padding-top: 20px;
}

@media (max-width: 768px) {
	.calc-result-item:last-child {
		font-size: 1.125rem;
	}
}

.tool-cta {
	background: linear-gradient(135deg, #0056b3 0%, #007bff 100%);
	border: none;
	border-radius: 8px;
	padding: 18px 32px;
	margin-top: 25px;
	color: white;
	font-size: 1.125rem;
	font-weight: 700;
	text-align: center;
	cursor: pointer;
	transition: all .3s ease;
	box-shadow: 0 4px 15px rgba(0, 123, 255, .3);
	text-decoration: none;
	display: inline-block;
	width: 100%;
}

.tool-cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 123, 255, .4);
	background: linear-gradient(135deg, #004494 0%, #0056b3 100%);
	color: white;
	text-decoration: none;
}

.tool-cta-secondary {
	background: white;
	border: 2px solid #007bff;
	color: #007bff;
	padding: 14px 28px;
	font-size: 1rem;
	margin-top: 15px;
	text-decoration: none;
	display: inline-block;
	width: 100%;
	border-radius: 8px;
	text-align: center;
	transition: all .3s;
	box-sizing: border-box;
}

.tool-cta-secondary:hover {
	background: #f8f9fa;
	border-color: #0056b3;
	color: #0056b3;
	text-decoration: none;
}

.cta-text {
	color: #333;
	font-size: .9375rem;
	margin-top: 15px;
	margin-bottom: 0;
	text-align: center;
}

@media (max-width: 768px) {
	.tool-cta {
		padding: 16px 24px;
		font-size: 1rem;
	}
	
	.tool-cta-secondary {
		padding: 12px 20px;
		font-size: .9375rem;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for text-editor, class: .elementor-element-eefe1ed */
.inheritance-container {
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
	line-height: 1.6;
}

/* DECISION FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

.flowchart-btn {
	flex: 1;
	padding: 15px 25px;
	font-size: 16px;
	font-weight: 600;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: all .3s;
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 8px;
	padding: 25px;
	margin-top: 20px;
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	font-size: 14px;
}

.flowchart-reset:hover {
	background: #5a6268;
}

.progress-bar {
	width: 100%;
	height: 8px;
	background: #e0e0e0;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: #007bff;
	transition: width .3s;
}

/* COMPARISON TABLE STYLES */
.comparison-table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px 0;
	font-size: 14px;
	overflow-x: auto;
	display: block;
}

.comparison-table table {
	width: 100%;
	min-width: 700px;
}

.comparison-table th {
	background: #007bff;
	color: white;
	padding: 15px;
	text-align: left;
	font-weight: 600;
}

.comparison-table td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.comparison-table tr:nth-child(even) {
	background: #f8f9fa;
}

.comparison-table tr:hover {
	background: #e9ecef;
}

.complexity-low {
	color: #28a745;
	font-weight: 600;
}

.complexity-medium {
	color: #ffc107;
	font-weight: 600;
}

.complexity-high {
	color: #dc3545;
	font-weight: 600;
}

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
}

.calc-input-group input {
	width: 100%;
	padding: 12px;
	border: 1px solid #ced4da;
	border-radius: 5px;
	font-size: 16px;
	box-sizing: border-box;
}

.calc-button {
	width: 100%;
	padding: 15px;
	background: #007bff;
	color: white;
	border: none;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 20px;
}

.calc-button:hover {
	background: #0056b3;
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 8px;
}

.calc-results.show {
	display: block;
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 18px;
	color: #28a745;
}

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.checklist-section {
	margin-bottom: 30px;
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 18px;
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 10px;
	border-radius: 5px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
}

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 30px;
	position: relative;
}

.timeline-marker {
	width: 60px;
	height: 60px;
	background: #007bff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 14px;
	flex-shrink: 0;
	z-index: 2;
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 18px;
}

.timeline-content p {
	margin: 0;
	color: #666;
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 30px;
	top: 60px;
	width: 2px;
	height: calc(100% + 30px);
	background: #e0e0e0;
	z-index: 1;
}

.timeline-item:last-child:before {
	display: none;
}

/* MISTAKES SECTION */
.mistake-item {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 20px;
	margin-bottom: 20px;
	border-radius: 5px;
}

.mistake-item h4 {
	color: #856404;
	margin: 0 0 10px 0;
}

.mistake-example {
	color: #856404;
	font-style: italic;
	margin-top: 10px;
	padding-left: 15px;
	border-left: 2px solid #ffc107;
}

/* RED FLAGS SECTION */
.red-flags-container {
	background: #f8d7da;
	border: 2px solid #dc3545;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 10px;
	background: white;
	border-radius: 5px;
}

.red-flag-icon {
	color: #dc3545;
	font-size: 24px;
	margin-right: 15px;
	flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
	}
	
	.comparison-table {
		font-size: 12px;
	}
	
	.timeline-item {
		flex-direction: column;
	}
	
	.timeline-marker {
		margin-bottom: 15px;
	}
	
	.timeline-content {
		margin-left: 0;
	}
	
	.timeline-item:before {
		display: none;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for html, class: .elementor-element-6219f72 */

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 12px;
	padding: 30px;
	margin: 30px 0;
}

@media (max-width: 768px) {
	.checklist-container {
		padding: 20px 15px;
		border-radius: 8px;
	}
}

.checklist-section {
	margin-bottom: 30px;
}

@media (max-width: 768px) {
	.checklist-section {
		margin-bottom: 25px;
	}
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 1.125rem;
	padding-bottom: 8px;
	border-bottom: 2px solid #007bff;
}

@media (max-width: 768px) {
	.checklist-section h4 {
		font-size: 1rem;
	}
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 12px;
	border-radius: 6px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 20px;
	height: 20px;
	cursor: pointer;
	flex-shrink: 0;
}

@media (max-width: 768px) {
	.checklist-item {
		padding: 10px;
	}
	
	.checklist-item input[type="checkbox"] {
		width: 18px;
		height: 18px;
	}
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
	font-size: .9375rem;
	line-height: 1.5;
}

@media (max-width: 768px) {
	.checklist-item label {
		font-size: .875rem;
	}
}

.tool-cta {
	background: linear-gradient(135deg, #0056b3 0%, #007bff 100%);
	border: none;
	border-radius: 8px;
	padding: 18px 32px;
	margin-top: 25px;
	color: white;
	font-size: 1.125rem;
	font-weight: 700;
	text-align: center;
	cursor: pointer;
	transition: all .3s ease;
	box-shadow: 0 4px 15px rgba(0, 123, 255, .3);
	text-decoration: none;
	display: inline-block;
	width: 100%;
}

.tool-cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 123, 255, .4);
	background: linear-gradient(135deg, #004494 0%, #0056b3 100%);
	color: white;
	text-decoration: none;
}

.cta-text {
	color: #333;
	font-size: .9375rem;
	margin-top: 15px;
	margin-bottom: 0;
	text-align: center;
}

@media (max-width: 768px) {
	.tool-cta {
		padding: 16px 24px;
		font-size: 1rem;
	}
}

/* End custom CSS */

/* Start custom CSS for text-editor, class: .elementor-element-2cc69a2 */
.inheritance-container {
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
	line-height: 1.6;
}

/* DECISION FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

.flowchart-btn {
	flex: 1;
	padding: 15px 25px;
	font-size: 16px;
	font-weight: 600;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: all .3s;
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 8px;
	padding: 25px;
	margin-top: 20px;
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	font-size: 14px;
}

.flowchart-reset:hover {
	background: #5a6268;
}

.progress-bar {
	width: 100%;
	height: 8px;
	background: #e0e0e0;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: #007bff;
	transition: width .3s;
}

/* COMPARISON TABLE STYLES */
.comparison-table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px 0;
	font-size: 14px;
	overflow-x: auto;
	display: block;
}

.comparison-table table {
	width: 100%;
	min-width: 700px;
}

.comparison-table th {
	background: #007bff;
	color: white;
	padding: 15px;
	text-align: left;
	font-weight: 600;
}

.comparison-table td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.comparison-table tr:nth-child(even) {
	background: #f8f9fa;
}

.comparison-table tr:hover {
	background: #e9ecef;
}

.complexity-low {
	color: #28a745;
	font-weight: 600;
}

.complexity-medium {
	color: #ffc107;
	font-weight: 600;
}

.complexity-high {
	color: #dc3545;
	font-weight: 600;
}

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
}

.calc-input-group input {
	width: 100%;
	padding: 12px;
	border: 1px solid #ced4da;
	border-radius: 5px;
	font-size: 16px;
	box-sizing: border-box;
}

.calc-button {
	width: 100%;
	padding: 15px;
	background: #007bff;
	color: white;
	border: none;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 20px;
}

.calc-button:hover {
	background: #0056b3;
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 8px;
}

.calc-results.show {
	display: block;
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 18px;
	color: #28a745;
}

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.checklist-section {
	margin-bottom: 30px;
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 18px;
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 10px;
	border-radius: 5px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
}

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 30px;
	position: relative;
}

.timeline-marker {
	width: 60px;
	height: 60px;
	background: #007bff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 14px;
	flex-shrink: 0;
	z-index: 2;
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 18px;
}

.timeline-content p {
	margin: 0;
	color: #666;
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 30px;
	top: 60px;
	width: 2px;
	height: calc(100% + 30px);
	background: #e0e0e0;
	z-index: 1;
}

.timeline-item:last-child:before {
	display: none;
}

/* MISTAKES SECTION */
.mistake-item {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 20px;
	margin-bottom: 20px;
	border-radius: 5px;
}

.mistake-item h4 {
	color: #856404;
	margin: 0 0 10px 0;
}

.mistake-example {
	color: #856404;
	font-style: italic;
	margin-top: 10px;
	padding-left: 15px;
	border-left: 2px solid #ffc107;
}

/* RED FLAGS SECTION */
.red-flags-container {
	background: #f8d7da;
	border: 2px solid #dc3545;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 10px;
	background: white;
	border-radius: 5px;
}

.red-flag-icon {
	color: #dc3545;
	font-size: 24px;
	margin-right: 15px;
	flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
	}
	
	.comparison-table {
		font-size: 12px;
	}
	
	.timeline-item {
		flex-direction: column;
	}
	
	.timeline-marker {
		margin-bottom: 15px;
	}
	
	.timeline-content {
		margin-left: 0;
	}
	
	.timeline-item:before {
		display: none;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for html, class: .elementor-element-f1b814a */

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 40px;
	position: relative;
}

@media (max-width: 768px) {
	.timeline-item {
		margin-bottom: 30px;
	}
}

.timeline-marker {
	width: 70px;
	height: 70px;
	background: linear-gradient(135deg, #007bff 0%, #0056b3 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 1rem;
	flex-shrink: 0;
	z-index: 2;
	box-shadow: 0 4px 12px rgba(0, 123, 255, .3);
}

@media (max-width: 1024px) {
	.timeline-marker {
		width: 60px;
		height: 60px;
		font-size: .9375rem;
	}
}

@media (max-width: 768px) {
	.timeline-marker {
		width: 50px;
		height: 50px;
		font-size: .875rem;
	}
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

@media (max-width: 768px) {
	.timeline-content {
		margin-left: 15px;
	}
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 1.25rem;
}

@media (max-width: 768px) {
	.timeline-content h4 {
		font-size: 1.063rem;
	}
}

.timeline-content p {
	margin: 0;
	color: #666;
	font-size: .9375rem;
	line-height: 1.6;
}

@media (max-width: 768px) {
	.timeline-content p {
		font-size: .875rem;
	}
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 35px;
	top: 70px;
	width: 3px;
	height: calc(100% + 40px);
	background: linear-gradient(180deg, #007bff 0%, #0056b3 100%);
	z-index: 1;
}

@media (max-width: 1024px) {
	.timeline-item:before {
		left: 30px;
		top: 60px;
		height: calc(100% + 30px);
	}
}

@media (max-width: 768px) {
	.timeline-item:before {
		left: 25px;
		top: 50px;
		width: 2px;
		height: calc(100% + 30px);
	}
}

.timeline-item:last-child:before {
	display: none;
}

/* End custom CSS */

/* Start custom CSS for text-editor, class: .elementor-element-fa51d79 */
.inheritance-container {
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
	line-height: 1.6;
}

/* DECISION FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

.flowchart-btn {
	flex: 1;
	padding: 15px 25px;
	font-size: 16px;
	font-weight: 600;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: all .3s;
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 8px;
	padding: 25px;
	margin-top: 20px;
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	font-size: 14px;
}

.flowchart-reset:hover {
	background: #5a6268;
}

.progress-bar {
	width: 100%;
	height: 8px;
	background: #e0e0e0;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: #007bff;
	transition: width .3s;
}

/* COMPARISON TABLE STYLES */
.comparison-table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px 0;
	font-size: 14px;
	overflow-x: auto;
	display: block;
}

.comparison-table table {
	width: 100%;
	min-width: 700px;
}

.comparison-table th {
	background: #007bff;
	color: white;
	padding: 15px;
	text-align: left;
	font-weight: 600;
}

.comparison-table td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.comparison-table tr:nth-child(even) {
	background: #f8f9fa;
}

.comparison-table tr:hover {
	background: #e9ecef;
}

.complexity-low {
	color: #28a745;
	font-weight: 600;
}

.complexity-medium {
	color: #ffc107;
	font-weight: 600;
}

.complexity-high {
	color: #dc3545;
	font-weight: 600;
}

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
}

.calc-input-group input {
	width: 100%;
	padding: 12px;
	border: 1px solid #ced4da;
	border-radius: 5px;
	font-size: 16px;
	box-sizing: border-box;
}

.calc-button {
	width: 100%;
	padding: 15px;
	background: #007bff;
	color: white;
	border: none;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 20px;
}

.calc-button:hover {
	background: #0056b3;
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 8px;
}

.calc-results.show {
	display: block;
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 18px;
	color: #28a745;
}

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.checklist-section {
	margin-bottom: 30px;
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 18px;
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 10px;
	border-radius: 5px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
}

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 30px;
	position: relative;
}

.timeline-marker {
	width: 60px;
	height: 60px;
	background: #007bff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 14px;
	flex-shrink: 0;
	z-index: 2;
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 18px;
}

.timeline-content p {
	margin: 0;
	color: #666;
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 30px;
	top: 60px;
	width: 2px;
	height: calc(100% + 30px);
	background: #e0e0e0;
	z-index: 1;
}

.timeline-item:last-child:before {
	display: none;
}

/* MISTAKES SECTION */
.mistake-item {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 20px;
	margin-bottom: 20px;
	border-radius: 5px;
}

.mistake-item h4 {
	color: #856404;
	margin: 0 0 10px 0;
}

.mistake-example {
	color: #856404;
	font-style: italic;
	margin-top: 10px;
	padding-left: 15px;
	border-left: 2px solid #ffc107;
}

/* RED FLAGS SECTION */
.red-flags-container {
	background: #f8d7da;
	border: 2px solid #dc3545;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 10px;
	background: white;
	border-radius: 5px;
}

.red-flag-icon {
	color: #dc3545;
	font-size: 24px;
	margin-right: 15px;
	flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
	}
	
	.comparison-table {
		font-size: 12px;
	}
	
	.timeline-item {
		flex-direction: column;
	}
	
	.timeline-marker {
		margin-bottom: 15px;
	}
	
	.timeline-content {
		margin-left: 0;
	}
	
	.timeline-item:before {
		display: none;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for html, class: .elementor-element-e1464b6 */

/* RED FLAGS STYLES */
.red-flags-container {
	background: linear-gradient(135deg, #fff5f5 0%, #ffe5e5 100%);
	border: 2px solid #dc3545;
	border-radius: 12px;
	padding: 30px;
	margin: 30px 0;
}

@media (max-width: 768px) {
	.red-flags-container {
		padding: 20px 15px;
		border-radius: 8px;
	}
}

.red-flags-container h3 {
	color: #dc3545;
	margin-bottom: 10px;
}

.red-flags-container > p {
	color: #721c24;
	margin-bottom: 20px;
	font-weight: 500;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 15px;
	background: white;
	border-radius: 8px;
	box-shadow: 0 2px 6px rgba(220, 53, 69, .1);
	transition: all .3s;
}

.red-flag-item:hover {
	box-shadow: 0 4px 12px rgba(220, 53, 69, .15);
	transform: translateX(5px);
}

@media (max-width: 768px) {
	.red-flag-item {
		padding: 12px;
	}
}

.red-flag-icon {
	color: #dc3545;
	font-size: 1.75rem;
	margin-right: 15px;
	flex-shrink: 0;
	line-height: 1;
}

@media (max-width: 768px) {
	.red-flag-icon {
		font-size: 1.5rem;
		margin-right: 12px;
	}
}

.red-flag-item div {
	color: #333;
	font-size: .9375rem;
	line-height: 1.5;
}

@media (max-width: 768px) {
	.red-flag-item div {
		font-size: .875rem;
	}
}

/* End custom CSS */

/* Start custom CSS for text-editor, class: .elementor-element-9f28533 */
.inheritance-container {
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
	line-height: 1.6;
}

/* DECISION FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

.flowchart-btn {
	flex: 1;
	padding: 15px 25px;
	font-size: 16px;
	font-weight: 600;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: all .3s;
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 8px;
	padding: 25px;
	margin-top: 20px;
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	font-size: 14px;
}

.flowchart-reset:hover {
	background: #5a6268;
}

.progress-bar {
	width: 100%;
	height: 8px;
	background: #e0e0e0;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: #007bff;
	transition: width .3s;
}

/* COMPARISON TABLE STYLES */
.comparison-table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px 0;
	font-size: 14px;
	overflow-x: auto;
	display: block;
}

.comparison-table table {
	width: 100%;
	min-width: 700px;
}

.comparison-table th {
	background: #007bff;
	color: white;
	padding: 15px;
	text-align: left;
	font-weight: 600;
}

.comparison-table td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.comparison-table tr:nth-child(even) {
	background: #f8f9fa;
}

.comparison-table tr:hover {
	background: #e9ecef;
}

.complexity-low {
	color: #28a745;
	font-weight: 600;
}

.complexity-medium {
	color: #ffc107;
	font-weight: 600;
}

.complexity-high {
	color: #dc3545;
	font-weight: 600;
}

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
}

.calc-input-group input {
	width: 100%;
	padding: 12px;
	border: 1px solid #ced4da;
	border-radius: 5px;
	font-size: 16px;
	box-sizing: border-box;
}

.calc-button {
	width: 100%;
	padding: 15px;
	background: #007bff;
	color: white;
	border: none;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 20px;
}

.calc-button:hover {
	background: #0056b3;
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 8px;
}

.calc-results.show {
	display: block;
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 18px;
	color: #28a745;
}

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.checklist-section {
	margin-bottom: 30px;
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 18px;
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 10px;
	border-radius: 5px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
}

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 30px;
	position: relative;
}

.timeline-marker {
	width: 60px;
	height: 60px;
	background: #007bff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 14px;
	flex-shrink: 0;
	z-index: 2;
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 18px;
}

.timeline-content p {
	margin: 0;
	color: #666;
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 30px;
	top: 60px;
	width: 2px;
	height: calc(100% + 30px);
	background: #e0e0e0;
	z-index: 1;
}

.timeline-item:last-child:before {
	display: none;
}

/* MISTAKES SECTION */
.mistake-item {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 20px;
	margin-bottom: 20px;
	border-radius: 5px;
}

.mistake-item h4 {
	color: #856404;
	margin: 0 0 10px 0;
}

.mistake-example {
	color: #856404;
	font-style: italic;
	margin-top: 10px;
	padding-left: 15px;
	border-left: 2px solid #ffc107;
}

/* RED FLAGS SECTION */
.red-flags-container {
	background: #f8d7da;
	border: 2px solid #dc3545;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 10px;
	background: white;
	border-radius: 5px;
}

.red-flag-icon {
	color: #dc3545;
	font-size: 24px;
	margin-right: 15px;
	flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
	}
	
	.comparison-table {
		font-size: 12px;
	}
	
	.timeline-item {
		flex-direction: column;
	}
	
	.timeline-marker {
		margin-bottom: 15px;
	}
	
	.timeline-content {
		margin-left: 0;
	}
	
	.timeline-item:before {
		display: none;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* End custom CSS */

/* Start custom CSS for text-editor, class: .elementor-element-fdfc922 */
.inheritance-container {
	max-width: 100%;
	margin: 0 auto;
	font-family: inherit;
	line-height: 1.6;
}

/* DECISION FLOWCHART STYLES */
.flowchart-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.flowchart-question {
	display: none;
	animation: fadeIn .5s;
}

.flowchart-question.active {
	display: block;
}

.flowchart-buttons {
	display: flex;
	gap: 15px;
	margin-top: 20px;
}

.flowchart-btn {
	flex: 1;
	padding: 15px 25px;
	font-size: 16px;
	font-weight: 600;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	transition: all .3s;
}

.flowchart-btn-yes {
	background: #28a745;
	color: white;
}

.flowchart-btn-yes:hover {
	background: #218838;
	transform: translateY(-2px);
}

.flowchart-btn-no {
	background: #dc3545;
	color: white;
}

.flowchart-btn-no:hover {
	background: #c82333;
	transform: translateY(-2px);
}

.flowchart-result {
	display: none;
	background: #d4edda;
	border: 2px solid #28a745;
	border-radius: 8px;
	padding: 25px;
	margin-top: 20px;
}

.flowchart-result.show {
	display: block;
	animation: fadeIn .5s;
}

.flowchart-reset {
	margin-top: 20px;
	padding: 12px 24px;
	background: #6c757d;
	color: white;
	border: none;
	border-radius: 5px;
	cursor: pointer;
	font-size: 14px;
}

.flowchart-reset:hover {
	background: #5a6268;
}

.progress-bar {
	width: 100%;
	height: 8px;
	background: #e0e0e0;
	border-radius: 4px;
	margin-bottom: 20px;
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: #007bff;
	transition: width .3s;
}

/* COMPARISON TABLE STYLES */
.comparison-table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px 0;
	font-size: 14px;
	overflow-x: auto;
	display: block;
}

.comparison-table table {
	width: 100%;
	min-width: 700px;
}

.comparison-table th {
	background: #007bff;
	color: white;
	padding: 15px;
	text-align: left;
	font-weight: 600;
}

.comparison-table td {
	padding: 15px;
	border-bottom: 1px solid #e0e0e0;
}

.comparison-table tr:nth-child(even) {
	background: #f8f9fa;
}

.comparison-table tr:hover {
	background: #e9ecef;
}

.complexity-low {
	color: #28a745;
	font-weight: 600;
}

.complexity-medium {
	color: #ffc107;
	font-weight: 600;
}

.complexity-high {
	color: #dc3545;
	font-weight: 600;
}

/* CALCULATOR STYLES */
.calculator-container {
	background: #f8f9fa;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.calc-input-group {
	margin-bottom: 20px;
}

.calc-input-group label {
	display: block;
	margin-bottom: 8px;
	font-weight: 600;
	color: #333;
}

.calc-input-group input {
	width: 100%;
	padding: 12px;
	border: 1px solid #ced4da;
	border-radius: 5px;
	font-size: 16px;
	box-sizing: border-box;
}

.calc-button {
	width: 100%;
	padding: 15px;
	background: #007bff;
	color: white;
	border: none;
	border-radius: 5px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 20px;
}

.calc-button:hover {
	background: #0056b3;
}

.calc-results {
	display: none;
	margin-top: 30px;
	padding: 25px;
	background: white;
	border: 2px solid #28a745;
	border-radius: 8px;
}

.calc-results.show {
	display: block;
}

.calc-result-item {
	display: flex;
	justify-content: space-between;
	padding: 15px 0;
	border-bottom: 1px solid #e0e0e0;
}

.calc-result-item:last-child {
	border-bottom: none;
	font-weight: 700;
	font-size: 18px;
	color: #28a745;
}

/* CHECKLIST STYLES */
.checklist-container {
	background: #fff;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.checklist-section {
	margin-bottom: 30px;
}

.checklist-section h4 {
	color: #007bff;
	margin-bottom: 15px;
	font-size: 18px;
}

.checklist-item {
	display: flex;
	align-items: start;
	margin-bottom: 12px;
	padding: 10px;
	border-radius: 5px;
	transition: background .3s;
}

.checklist-item:hover {
	background: #f8f9fa;
}

.checklist-item input[type="checkbox"] {
	margin-right: 12px;
	margin-top: 4px;
	width: 18px;
	height: 18px;
	cursor: pointer;
}

.checklist-item label {
	cursor: pointer;
	flex: 1;
}

/* TIMELINE STYLES */
.timeline-container {
	margin: 40px 0;
	position: relative;
}

.timeline-item {
	display: flex;
	margin-bottom: 30px;
	position: relative;
}

.timeline-marker {
	width: 60px;
	height: 60px;
	background: #007bff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	font-weight: 700;
	font-size: 14px;
	flex-shrink: 0;
	z-index: 2;
}

.timeline-content {
	margin-left: 25px;
	flex: 1;
}

.timeline-content h4 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 18px;
}

.timeline-content p {
	margin: 0;
	color: #666;
}

.timeline-item:before {
	content: "";
	position: absolute;
	left: 30px;
	top: 60px;
	width: 2px;
	height: calc(100% + 30px);
	background: #e0e0e0;
	z-index: 1;
}

.timeline-item:last-child:before {
	display: none;
}

/* MISTAKES SECTION */
.mistake-item {
	background: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 20px;
	margin-bottom: 20px;
	border-radius: 5px;
}

.mistake-item h4 {
	color: #856404;
	margin: 0 0 10px 0;
}

.mistake-example {
	color: #856404;
	font-style: italic;
	margin-top: 10px;
	padding-left: 15px;
	border-left: 2px solid #ffc107;
}

/* RED FLAGS SECTION */
.red-flags-container {
	background: #f8d7da;
	border: 2px solid #dc3545;
	border-radius: 8px;
	padding: 30px;
	margin: 30px 0;
}

.red-flag-item {
	display: flex;
	align-items: start;
	margin-bottom: 15px;
	padding: 10px;
	background: white;
	border-radius: 5px;
}

.red-flag-icon {
	color: #dc3545;
	font-size: 24px;
	margin-right: 15px;
	flex-shrink: 0;
}

/* RESPONSIVE */
@media (max-width: 768px) {
	.flowchart-buttons {
		flex-direction: column;
	}
	
	.comparison-table {
		font-size: 12px;
	}
	
	.timeline-item {
		flex-direction: column;
	}
	
	.timeline-marker {
		margin-bottom: 15px;
	}
	
	.timeline-content {
		margin-left: 0;
	}
	
	.timeline-item:before {
		display: none;
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
