/* ============================================
   WIBOC - Utility Classes
   ============================================ */

/* Display */
.d-block { display: block; }
.d-inline { display: inline; }
.d-inline-block { display: inline-block; }
.d-none { display: none; }
.d-flex { display: flex; }
.d-grid { display: grid; }

/* Spacing - Margin */
.m-0 { margin: 0; }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.mt-sm { margin-top: var(--wiboc-spacing-sm); }
.mt-md { margin-top: var(--wiboc-spacing-md); }
.mt-lg { margin-top: var(--wiboc-spacing-lg); }
.mt-xl { margin-top: var(--wiboc-spacing-xl); }
.mb-sm { margin-bottom: var(--wiboc-spacing-sm); }
.mb-md { margin-bottom: var(--wiboc-spacing-md); }
.mb-lg { margin-bottom: var(--wiboc-spacing-lg); }
.mb-xl { margin-bottom: var(--wiboc-spacing-xl); }

/* Spacing - Padding */
.p-0 { padding: 0; }
.p-sm { padding: var(--wiboc-spacing-sm); }
.p-md { padding: var(--wiboc-spacing-md); }
.p-lg { padding: var(--wiboc-spacing-lg); }
.p-xl { padding: var(--wiboc-spacing-xl); }

/* Width */
.w-full { width: 100%; }
.w-auto { width: auto; }
.w-half { width: 50%; }

/* Border */
.border { border: 1px solid var(--wiboc-gray-300); }
.border-top { border-top: 1px solid var(--wiboc-gray-300); }
.border-bottom { border-bottom: 1px solid var(--wiboc-gray-300); }
.rounded { border-radius: var(--wiboc-radius); }
.rounded-lg { border-radius: var(--wiboc-radius-lg); }

/* Background */
.bg-white { background: var(--wiboc-white); }
.bg-light { background: var(--wiboc-gray-50); }
.bg-primary { background: var(--wiboc-primary); }
.bg-accent { background: var(--wiboc-accent); }

/* Overflow */
.overflow-hidden { overflow: hidden; }
.overflow-auto { overflow: auto; }

/* Position */
.relative { position: relative; }
.absolute { position: absolute; }
.sticky { position: sticky; top: 0; }

/* Visibility */
.visible { visibility: visible; }
.invisible { visibility: hidden; }

/* Cursor */
.cursor-pointer { cursor: pointer; }
.cursor-not-allowed { cursor: not-allowed; }

/* Animation */
.animate-pulse { animation: pulse 2s infinite; }

@keyframes pulse {
    0% { box-shadow: 0 0 0 0 rgba(199, 154, 61, 0.7); }
    70% { box-shadow: 0 0 0 15px rgba(199, 154, 61, 0); }
    100% { box-shadow: 0 0 0 0 rgba(199, 154, 61, 0); }
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: var(--wiboc-spacing-2xl);
    color: var(--wiboc-gray-500);
}

.empty-state-icon {
    font-size: 4em;
    display: block;
    margin-bottom: var(--wiboc-spacing-md);
}

/* Status Badges */
.badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: var(--wiboc-radius-full);
    font-size: var(--wiboc-font-size-xs);
    font-weight: var(--wiboc-weight-semibold);
}

.badge-primary { background: var(--wiboc-primary-light); color: var(--wiboc-primary); }
.badge-accent { background: var(--wiboc-accent-light); color: var(--wiboc-accent); }
.badge-success { background: var(--wiboc-success-light); color: var(--wiboc-success); }
.badge-danger { background: var(--wiboc-danger-light); color: var(--wiboc-danger); }
.badge-warning { background: var(--wiboc-warning-light); color: #856404; }