
	body {
		font-family: Readex Pro, sans-serif;
	}
	@font-face {
		font-family: 'sign';
		src: url('sign.ttf');
	}
	.gradnt {
		background: linear-gradient(90deg, aqua 0%, darkblue 100%);
		background-clip: text;
		-webkit-background-clip: text;
		color: transparent;
	}
	.navBtn {
		color: var(--bs-dark) !important;
		transition: color 0.3s ease-in-out;
		cursor: pointer;
	}
	.navBtn:hover {
		color: var(--bs-primary) !important;
	}
	.txt-sm {
		font-size: small;
	}
	.hero-signature p {
		font-size: 1.25rem; /* Same as your fs-5 */
		margin-bottom: 0;
	}
	.custom-width {
		width: 50%;
	}
	.dollar:before {
		content: "US$";
		margin-right: 2px;
		font-weight: normal;
		font-size: 75%;
		vertical-align: text-top;
	}
	.wordover {
		background:#fff; 
		padding: 0 10px; 
	}
	.cutline {
		width: 100%; 
		text-align: center; 
		border-bottom: 1px solid gray; 
		line-height: 0.1em;
		margin: 10px 0 20px; 		
	}
	@media print {
		body * {
		visibility: hidden;
		}
		#billModal, #billModal * {
		visibility: visible;
		}
		#billModal {
		position: absolute;
		left: 0;
		top: 0;
		}
	}
	.form-floating.custom-class>label {
		top: 0;
		right: 0;
		left: auto;
		transform-origin: 100% 0;
		transition: opacity .1s ease-in-out,transform .1s ease-in-out;
	}
	.form-floating.custom-class>.form-control:focus~label, 
	.form-floating>.form-control:not(:placeholder-shown)~label {
		transform: scale(.85) translateY(-0.5rem) translateX(0.15rem);
	}
	.form-control.is-invalid,
	.form-control.is-valid{
		background-position: left;
		background-origin: content-box;
	}
	input:-webkit-autofill,
	input:-webkit-autofill:focus {
		transition: background-color 600000s 0s, color 600000s 0s;
	}
	:root {
		--anim-slow: 0.9s;
		--anim-fast: 0.3s;
	}
	.btn-premium {
		position: relative;
		overflow: hidden;
		display: inline-grid;
		place-items: center;
		transition: 
		background-color var(--anim-slow) ease-in-out,
		border-color var(--anim-slow) ease-in-out,
		opacity var(--anim-fast) ease-in-out !important;
	}
	.btn-premium.is-loading {
		opacity: 0.65 !important;
		pointer-events: none;
	}
	.btn-premium.is-success,
	.btn-premium:not(.is-loading) {
		opacity: 1 !important;
	}
	.btn-text, .spinner-border-sm, .success-icon {
		grid-area: 1 / 1;
	}
	.btn-text {
		transition: opacity var(--anim-fast) ease;
	}
	.is-loading .btn-text, 
	.is-success .btn-text {
		opacity: 0;
	}
	.spinner-border-sm {
		display: none;
		z-index: 2;
	}
	.is-loading .spinner-border-sm {
		display: inline-block;
	}
	.success-icon {
		position: relative;
		left: -120%;
		opacity: 0;
		pointer-events: none;
		transform: scale(0.4);
		transition: 
		left var(--anim-slow) cubic-bezier(0.34, 1.56, 0.64, 1),
		opacity var(--anim-fast) ease,
		transform var(--anim-slow) cubic-bezier(0.34, 1.56, 0.64, 1);
	}
	.is-success .success-icon {
		left: 0%;
		opacity: 1;
		transform: scale(1);
	}
	.crdhover:hover, 
	.en:hover, 
	.mat:hover {
		background-color: var(--bs-light) !important;
	}
	.footBtn {
		text-decoration: none !important;
	}
	.footBtn:hover {
		text-decoration: underline !important;
	}
	.crdlnk {
		color: var(--bs-secondary) !important;
	}
	.crdlnk:hover {
		color: var(--bs-primary) !important;
	}
	.navBtn, .crdlnk, .crdhover {
		transition: all 0.2s ease-in-out;
	}
	.course-icon {
		width: 24px;
		height: 24px;
		vertical-align: middle;
	}
	.crdhover .arrows {
		display: inline-block;
		transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	}
	.crdhover:hover .arrows {
		transform: translateX(-8px); /* Moves it to the left */
	}
	#vid { 
		opacity: 1; 
		transition: opacity 0.4s ease-in-out; 
	}
	#vid.fade-out { opacity: 0; }
	.accordion-button::after { 
		margin-left: 0 !important; 
		margin-right: auto; 
	}

	/* Making the footer stick perfectly to the bottom of the viewport */
	html, body {
		height: 100%;
		margin: 0;
	}
	body {
		display: flex;
		flex-direction: column;
	}
	.main-content-wrapper {
		flex: 1 0 auto;
	}
	footer {
		flex-shrink: 0;
	}

	/* Google Calendar/Finance Aesthetics: Dense, sharp lines, zero shadows */
	.booking-container {
		font-family: 'Readex Pro', sans-serif;
	}
	.compact-label {
		font-family: 'Almarai', sans-serif;
		font-size: 0.85rem;
		font-weight: 700;
	}
	.calendar-grid-wrapper {
		border: 1px solid var(--bs-border-color-translucent);
		background-color: #ffffff;
	}
	.calendar-header-cell {
		font-size: 0.75rem;
		font-weight: 700;
		border-bottom: 1px solid var(--bs-border-color-translucent);
		background-color: #f8f9fa;
	}
	.calendar-day-cell {
		height: 42px !important;
		vertical-align: middle !important;
		text-align: center !important;
		cursor: pointer;
		transition: background-color 0.1s ease;
	}
	.calendar-day-cell:hover {
		background-color: #f1f3f4;
	}
	.selected-day-active {
		background-color: var(--bs-primary-border-subtle) !important;
		font-weight: bold;
	}
	/* Hourly Matrix Components */
	.hours-scroll-container {
		border: 1px solid var(--bs-border-color-translucent);
		background-color: #ffffff;
		max-height: 334px;
		overflow-y: auto;
		padding: 6px; /* Optimized internal boundaries */
	}
	.hour-slot-pill {
		cursor: pointer;
		border: 1px solid transparent; 
		margin-bottom: 5px;            /* Balanced distance gap (not too close, not too far) */
		padding-top: 6px !important;    /* Adjusted vertical height padding */
		padding-bottom: 6px !important; /* Adjusted vertical height padding */
		border-radius: 5px;            
		transition: all 0.15s ease;    
	}
	.hour-slot-pill:last-child {
		margin-bottom: 0;              
	}
	.hour-slot-pill:hover {
		background-color: #f8f9fa;
		border-color: var(--bs-border-color-translucent);
	}
	.hour-slot-pill.active {
		background-color: #e8f0fe;
		border-color: #d2e3fc;          
		color: #1a73e8 !important;
		font-weight: 700;
	}
	.hour-slot-pill.course-locked {
		background-color: transparent !important;
		color: inherit !important;
		cursor: not-allowed;
	}

	/* Responsive Controls to Prevent Over-stretching */
	@media (min-width: 768px) {
		.max-width-controlled {
			max-width: 460px !important;
			width: 100%;
		}
	}

	@media (max-width: 991.98px) {
		.border-start-lg {
			border-start: none !important;
			border-bottom: 2px solid var(--bs-border-color-translucent) !important;
			padding-bottom: 1.5rem !important;
			margin-bottom: 1rem !important;
		}
		.pe-lg-4, .pe-lg-3, .ps-lg-4 {
			padding-left: 0.75rem !important;
			padding-right: 0.75rem !important;
		}
	}
	
	/* Sidebar Container Setup */
	.custom-help-panel {
		font-family: 'Readex Pro', sans-serif;
		background-color: #ffffff;
		width: 400px;
		border-right: 1px solid #e0e0e0 !important;
		box-shadow: -8px 0 24px rgba(0,0,0,0.05);
	}

	/* Header Context Group */
	.panel-header {
		background-color: #f8f9fa;
		border-bottom: 1px solid #e0e0e0;
	}

	.header-icon-box {
		width: 20px;
		height: 20px;
	}

	.header-icon-box i {
		font-size: 16px;
		color: #5f6368;
	}

	.panel-title {
		font-size: 13px;
		font-weight: 700;
		letter-spacing: 0.2px;
	}

	.close-panel-btn {
		font-size: 11px;
		opacity: 0.7;
	}

	/* Chat Stream Container Layout */
	.chat-canvas-body {
		overflow-y: auto;
		height: calc(100vh - 120px);
		background-color: #ffffff;
	}

	.msg-wrapper {
		max-width: 75%;
	}

	/* Identity Name Tags and Metadata */
	.name-tag-system {
		font-size: 11px;
		font-weight: 700;
		color: #5f6368 !important;
	}

	.system-icon-small {
		font-size: 12px;
		color: #5f6368 !important;
	}

	.name-tag-user {
		font-size: 11px;
		font-weight: 700;
		color: #1a73e8 !important;
	}

	/* Fluid iMessage Bubble Layout Structure */
	.bubble-msg {
		font-size: 13px;
		font-weight: 500;
		line-height: 1.4;
	}

	/* Inbound System Notification Bubble */
	.bubble-system {
		background-color: #e9e9eb;
		border-radius: 18px;
		border-top-left-radius: 4px;
		text-align: right;
	}

	/* Outbound User Message Bubble */
	.bubble-user {
		background-color: #1a73e8;
		border-radius: 18px;
		border-top-right-radius: 4px;
	}

	/* Footer Control Dock Elements */
	.panel-footer-dock {
		background-color: #f8f9fa;
		border-top: 1px solid #e0e0e0;
	}

	.input-container-box {
		background-color: #ffffff;
		border: 1px solid #dadce0;
		border-radius: 4px;
	}

	.paperclip-btn i {
		font-size: 14px;
		cursor: pointer;
		color: #5f6368;
	}

	.chat-input {
		font-size: 12px;
		font-weight: 500;
		outline: none;
	}

	.send-btn i {
		font-size: 20px;
		color: #1a73e8;
		cursor: pointer;
	}
