/**
 * Utility Classes
 * JTSC Pro Website
 */

/* Text Utilities */
.text-center { text-align: center !important; }
.text-left { text-align: left !important; }
.text-right { text-align: right !important; }

.text-primary { color: var(--text-primary) !important; }
.text-secondary { color: var(--text-secondary) !important; }
.text-muted { color: var(--text-muted) !important; }
.text-white { color: white !important; }

/* Background Utilities */
.bg-primary { background: var(--bg-primary) !important; }
.bg-secondary { background: var(--bg-secondary) !important; }
.bg-tertiary { background: var(--bg-tertiary) !important; }

/* Display Utilities */
.hidden { display: none !important; }
.visible { display: block !important; }
.flex { display: flex !important; }
.inline-flex { display: inline-flex !important; }
.grid { display: grid !important; }

/* Spacing Utilities */
.m-0 { margin: 0 !important; }
.mt-0 { margin-top: 0 !important; }
.mb-0 { margin-bottom: 0 !important; }
.ml-0 { margin-left: 0 !important; }
.mr-0 { margin-right: 0 !important; }

.m-1 { margin: var(--space-1) !important; }
.mt-1 { margin-top: var(--space-1) !important; }
.mb-1 { margin-bottom: var(--space-1) !important; }
.ml-1 { margin-left: var(--space-1) !important; }
.mr-1 { margin-right: var(--space-1) !important; }

.m-2 { margin: var(--space-2) !important; }
.mt-2 { margin-top: var(--space-2) !important; }
.mb-2 { margin-bottom: var(--space-2) !important; }
.ml-2 { margin-left: var(--space-2) !important; }
.mr-2 { margin-right: var(--space-2) !important; }

.m-4 { margin: var(--space-4) !important; }
.mt-4 { margin-top: var(--space-4) !important; }
.mb-4 { margin-bottom: var(--space-4) !important; }
.ml-4 { margin-left: var(--space-4) !important; }
.mr-4 { margin-right: var(--space-4) !important; }

.m-6 { margin: var(--space-6) !important; }
.mt-6 { margin-top: var(--space-6) !important; }
.mb-6 { margin-bottom: var(--space-6) !important; }
.ml-6 { margin-left: var(--space-6) !important; }
.mr-6 { margin-right: var(--space-6) !important; }

.m-8 { margin: var(--space-8) !important; }
.mt-8 { margin-top: var(--space-8) !important; }
.mb-8 { margin-bottom: var(--space-8) !important; }
.ml-8 { margin-left: var(--space-8) !important; }
.mr-8 { margin-right: var(--space-8) !important; }

.p-0 { padding: 0 !important; }
.pt-0 { padding-top: 0 !important; }
.pb-0 { padding-bottom: 0 !important; }
.pl-0 { padding-left: 0 !important; }
.pr-0 { padding-right: 0 !important; }

.p-1 { padding: var(--space-1) !important; }
.pt-1 { padding-top: var(--space-1) !important; }
.pb-1 { padding-bottom: var(--space-1) !important; }
.pl-1 { padding-left: var(--space-1) !important; }
.pr-1 { padding-right: var(--space-1) !important; }

.p-2 { padding: var(--space-2) !important; }
.pt-2 { padding-top: var(--space-2) !important; }
.pb-2 { padding-bottom: var(--space-2) !important; }
.pl-2 { padding-left: var(--space-2) !important; }
.pr-2 { padding-right: var(--space-2) !important; }

.p-4 { padding: var(--space-4) !important; }
.pt-4 { padding-top: var(--space-4) !important; }
.pb-4 { padding-bottom: var(--space-4) !important; }
.pl-4 { padding-left: var(--space-4) !important; }
.pr-4 { padding-right: var(--space-4) !important; }

.p-6 { padding: var(--space-6) !important; }
.pt-6 { padding-top: var(--space-6) !important; }
.pb-6 { padding-bottom: var(--space-6) !important; }
.pl-6 { padding-left: var(--space-6) !important; }
.pr-6 { padding-right: var(--space-6) !important; }

.p-8 { padding: var(--space-8) !important; }
.pt-8 { padding-top: var(--space-8) !important; }
.pb-8 { padding-bottom: var(--space-8) !important; }
.pl-8 { padding-left: var(--space-8) !important; }
.pr-8 { padding-right: var(--space-8) !important; }

/* Flexbox Utilities */
.justify-center { justify-content: center !important; }
.justify-between { justify-content: space-between !important; }
.justify-around { justify-content: space-around !important; }
.justify-evenly { justify-content: space-evenly !important; }

.items-center { align-items: center !important; }
.items-start { align-items: flex-start !important; }
.items-end { align-items: flex-end !important; }

.flex-col { flex-direction: column !important; }
.flex-row { flex-direction: row !important; }

.flex-wrap { flex-wrap: wrap !important; }
.flex-nowrap { flex-wrap: nowrap !important; }

/* Border Utilities */
.border { border: 1px solid var(--border) !important; }
.border-t { border-top: 1px solid var(--border) !important; }
.border-b { border-bottom: 1px solid var(--border) !important; }
.border-l { border-left: 1px solid var(--border) !important; }
.border-r { border-right: 1px solid var(--border) !important; }

.rounded { border-radius: var(--radius) !important; }
.rounded-lg { border-radius: var(--radius-lg) !important; }
.rounded-xl { border-radius: var(--radius-xl) !important; }
.rounded-full { border-radius: var(--radius-full) !important; }

/* Shadow Utilities */
.shadow { box-shadow: var(--shadow) !important; }
.shadow-lg { box-shadow: var(--shadow-lg) !important; }
.shadow-xl { box-shadow: var(--shadow-xl) !important; }
.shadow-none { box-shadow: none !important; }

/* Animation Utilities */
.fade-in {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

.slide-in-left {
    opacity: 0;
    transform: translateX(-30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.slide-in-left.visible {
    opacity: 1;
    transform: translateX(0);
}

.slide-in-right {
    opacity: 0;
    transform: translateX(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.slide-in-right.visible {
    opacity: 1;
    transform: translateX(0);
}

/* Hover Effects */
.hover-scale:hover {
    transform: scale(1.05);
}

.hover-lift:hover {
    transform: translateY(-3px);
}

/* Responsive Utilities */
@media (max-width: 768px) {
    .hidden-mobile { display: none !important; }
    .visible-mobile { display: block !important; }
}

@media (min-width: 769px) {
    .hidden-desktop { display: none !important; }
    .visible-desktop { display: block !important; }
}
