/**
 * Utility Classes
 *
 * Reusable utility classes for common styling patterns.
 * Includes spacing, flexbox, typography, and admin-specific utilities.
 */

/* ===== Utility Classes ===== */

.mb-05 { margin-bottom: 0.5rem; }
.mb-1 { margin-bottom: 1rem; }
.mb-15 { margin-bottom: 1.5rem; }
.mb-2 { margin-bottom: 2rem; }
.mb-3 { margin-bottom: 3rem; }
.mt-025 { margin-top: 0.25rem; }
.mt-05 { margin-top: 0.5rem; }
.mt-1 { margin-top: 1rem; }
.mt-2 { margin-top: 2rem; }
.m-0 { margin: 0; }
.ml-05 { margin-left: 0.5rem; }
.mr-025 { margin-right: 0.25rem; }

.p-1 { padding: 1rem; }
.p-15 { padding: 1.5rem; }
.p-2 { padding: 2rem; }

.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.flex-1 { flex: 1; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.justify-end { justify-content: flex-end; }
.align-center { align-items: center; }
.align-start { align-items: flex-start; }
.align-end { align-items: flex-end; }
.gap-025 { gap: 0.25rem; }
.gap-05 { gap: 0.5rem; }
.gap-075 { gap: 0.75rem; }
.gap-1 { gap: 1rem; }
.gap-15 { gap: 1.5rem; }
.gap-2 { gap: 2rem; }
.flex-wrap { flex-wrap: wrap; }

.text-muted { color: var(--color-text-muted); }
.text-primary { color: var(--color-primary); }
.text-success { color: var(--color-success); }
.text-danger { color: var(--color-danger); }
.text-warning { color: var(--color-warning); }
.text-dark { color: var(--color-text); }
.text-sm { font-size: 0.875rem; }
.text-xs { font-size: 0.75rem; }
.text-center { text-align: center; }
.text-right { text-align: right; }

.font-normal { font-weight: normal; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }

.admin-stat-card-purple { border-left-color: var(--color-purple); }
.admin-stat-card-pink { border-left-color: var(--color-primary); }
.admin-stat-card-blue { border-left-color: var(--color-primary); }

.admin-stat-meta {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    margin-top: 0.5rem;
}

.admin-action-title {
    margin-bottom: 0.5rem;
}

.admin-action-description {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    margin-bottom: 1.5rem;
}

.admin-page-title {
    margin-bottom: 0.5rem;
}

.admin-filter-tabs {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 2rem;
    border-bottom: 2px solid var(--color-border);
}

.admin-filter-tab {
    padding: 0.75rem 1.5rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    font-weight: 500;
    color: var(--color-text-muted);
    transition: all var(--transition-fast);
    margin-bottom: -2px;
}

.admin-filter-tab:hover {
    color: var(--color-primary);
}

.admin-filter-tab.active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.admin-empty-state-box {
    padding: 3rem;
    text-align: center;
    background: var(--color-bg-light);
    border-radius: var(--radius-md);
}

.admin-badge-yellow { background: var(--color-warning); color: white; }
.admin-badge-green { background: var(--color-success); color: white; }
.admin-badge-red { background: var(--color-danger); color: white; }
.admin-badge-blue { background: var(--color-primary); color: white; }
.admin-badge-indigo { background: var(--color-primary); color: white; }

.admin-packages-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: var(--space-lg);
}

.admin-modules-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.admin-card {
    background: var(--color-card-bg);
    border: 1px solid var(--color-card-border);
    border-left: 4px solid var(--color-role-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    padding: var(--space-lg);
    transition: all var(--transition-fast);
}

.admin-card:hover {
    background: var(--color-card-hover);
    border-left-width: 6px;
}

.admin-card-title {
    margin-bottom: var(--space-lg);
}

.admin-grid-2col {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}

.admin-label {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.25rem;
}

.admin-value {
    font-size: 1rem;
    color: var(--color-text);
    font-weight: 500;
}

.admin-text {
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

.admin-danger-zone {
    margin-top: 2rem;
    padding-top: 2rem;
    border-top: 2px solid var(--color-border);
}

.admin-danger-title {
    color: var(--color-danger);
    margin-bottom: 1rem;
}

.admin-info-box {
    background: var(--color-bg-light);
    padding: 1rem;
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
}

.admin-info-box-blue {
    background: var(--color-info-light);
    border-left: 4px solid var(--color-primary);
    padding: 1rem;
    border-radius: var(--radius-sm);
}

.admin-section-title {
    margin-bottom: var(--space-lg);
}

.admin-subsection-title {
    font-size: 1.125rem;
    margin-bottom: var(--space-md);
}

.admin-divider {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: 2rem 0;
}

.admin-package-item {
    padding: var(--space-lg);
    background: var(--color-bg-light);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--color-primary);
}

.admin-package-name {
    font-size: 1.125rem;
    margin-bottom: 0.5rem;
}

.admin-package-description {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    margin-bottom: 0.5rem;
}

.admin-module-item {
    padding: var(--space-lg);
    background: var(--color-card-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.admin-module-via-package {
    background: var(--color-bg-light);
    border-left: 4px solid var(--color-primary);
}

.admin-module-name {
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.admin-module-meta {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    margin-bottom: 0.25rem;
}

.admin-module-source {
    font-size: 0.75rem;
    margin-top: 0.25rem;
}

.admin-module-date {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.admin-empty-state {
    padding: 2rem;
    text-align: center;
    color: var(--color-text-muted);
    background: var(--color-bg-light);
    border-radius: var(--radius-md);
}

.admin-empty-state-sm {
    padding: 1rem;
    text-align: center;
    color: var(--color-text-muted);
}

.form-label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 500;
}

.form-hint {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    margin-top: 0.25rem;
}

.checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    cursor: pointer;
}

.checkbox {
    margin-top: 0.25rem;
}

.admin-module-selector {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem;
    background: var(--color-card-bg);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.admin-module-selector:hover {
    border-color: var(--color-primary);
    background: var(--color-bg-light);
}

.admin-module-selector.selected {
    border-color: var(--color-primary);
    background: var(--color-info-light);
}

.admin-module-selector-name {
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.admin-summary-card {
    background: var(--color-bg-light);
    padding: var(--space-lg);
    border-radius: var(--radius-md);
}

.admin-summary-title {
    font-size: 1.125rem;
    margin-bottom: var(--space-md);
}

.admin-summary-title-sm {
    font-size: 1rem;
    margin-bottom: 0.5rem;
}

.admin-summary-grid {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.admin-summary-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.admin-code {
    background: var(--color-bg-dark);
    padding: 0.125rem 0.5rem;
    border-radius: var(--radius-sm);
    font-family: monospace;
    font-size: 0.875rem;
}

.admin-warning-box {
    background: var(--color-warning-light);
    border-left: 4px solid var(--color-warning);
    padding: 1rem;
    border-radius: var(--radius-sm);
}

.admin-warning-title {
    color: var(--color-warning);
    margin-bottom: 0.5rem;
}

.admin-back-button {
    display: inline-block;
    color: var(--color-primary);
    text-decoration: none;
    margin-bottom: 1rem;
    transition: color var(--transition-fast);
}

.admin-back-button:hover {
    color: var(--color-primary-dark);
}

.admin-module-title {
    margin: 0 0 1rem 0;
}

.wizard-options {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
}

.wizard-option {
    padding: 1.5rem;
    background: var(--color-card-bg);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    text-align: center;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.wizard-option:hover {
    border-color: var(--color-primary);
    transform: translateY(-2px);
}

.wizard-option.selected {
    border-color: var(--color-primary);
    background: var(--color-info-light);
}

.wizard-option-icon {
    font-size: 2rem;
    margin-bottom: 0.5rem;
}

.wizard-option-label {
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.wizard-option-badge {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}
